Make deployments checkout repos, use bun global #88
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 }} |