Skip to content

Make deployments checkout repos, use bun global #88

Make deployments checkout repos, use bun global

Make deployments checkout repos, use bun global #88

Workflow file for this run

name: Deployments
on:
push:
branches:
- main
env:
CI: true
jobs:
create-release-pr:
name: Create release pr
timeout-minutes: 15
runs-on: ubuntu-latest
permissions:
contents: write # to create release (changesets/action)
issues: write # to post issue comments (changesets/action)
pull-requests: write # to create pull request (changesets/action)
steps:
- name: Checkout repo
uses: actions/checkout@v3
- name: Fetch tags
run: git fetch --tags origin
- name: Setup bun
uses: oven-sh/setup-bun@v1
- name: Install dependencies
run: bun install
- name: Create release pr / create tags
id: changesets
uses: changesets/action@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
version: bun run version-packages
publish: bun run publish-packages
- name: Echo outputs
run: |
echo "hasChangesets=${{ steps.changesets.outputs.hasChangesets }}"
echo "publishedPackages=${{ steps.changesets.outputs.publishedPackages }}"
echo "publishedPackageNames=${{ toJSON(fromJSON(steps.changesets.outputs.publishedPackages).*['name']) }}"
outputs:
hasChangesets: ${{ steps.changesets.outputs.hasChangesets }}
publishedPackages: ${{ steps.changesets.outputs.publishedPackages }}
publishedPackageNames: ${{ toJSON(fromJSON(steps.changesets.outputs.publishedPackages).*['name']) }}
publish-frontend:
needs: create-release-pr
name: Publish frontend
runs-on: ubuntu-latest
env:
RAILWAY_TOKEN: ${{ secrets.RAILWAY_TOKEN }}
if: |
needs.create-release-pr.outputs.hasChangesets == 'false' && (
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/tsconfig') == true ||
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/utils') == true ||
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/frontend') == true
)
steps:
- name: Checkout repo
uses: actions/checkout@v3
- name: Setup bun
uses: oven-sh/setup-bun@v1
- name: Install dependencies
run: bun install
- name: Install Railway
run: bun install --global @railway/cli
- name: Set service
run: railway service frontend
- name: Deploy
run: railway up
publish-backend:
needs: create-release-pr
name: Publish backend
runs-on: ubuntu-latest
env:
RAILWAY_TOKEN: ${{ secrets.RAILWAY_TOKEN }}
if: |
needs.create-release-pr.outputs.hasChangesets == 'false' && (
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/tsconfig') == true ||
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/utils') == true ||
contains(needs.create-release-pr.outputs.publishedPackageNames, '@haishin/backend') == true
)
steps:
- name: Checkout repo
uses: actions/checkout@v3
- name: Setup bun
uses: oven-sh/setup-bun@v1
- name: Install dependencies
run: bun install
- name: Install Railway
run: bun install --global @railway/cli
- name: Set service
run: railway service backend
- name: Deploy
run: railway up
cleanup-old-release-tags:
needs: create-release-pr
name: Cleanup old release tags
runs-on: ubuntu-latest
continue-on-error: true
permissions:
contents: write
if: |
needs.create-release-pr.outputs.hasChangesets == 'false' && needs.create-release-pr.outputs.publishedPackages != '[]'
strategy:
matrix:
package: ${{ fromJSON(needs.create-release-pr.outputs.publishedPackages).*['name'] }}
steps:
- name: 'Delete release tags'
uses: jay2610/[email protected]
with:
keep_latest: 1
delete_tags: true
delete_tag_pattern: ${{ matrix.package }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}