amos-kibet / fly-preview-apps

Github Action for PR Review Apps on Fly.io

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Fly.io Pull Request Review Apps

This GitHub action wraps the Fly.io CLI to automatically deploy pull requests to fly.io for review. These are useful for testing changes on a branch without having to setup explicit staging environments.

This action will create, deploy, and destroy Fly apps. Just set an Action Secret for FLY_API_TOKEN.

If you have an existing fly.toml in your repo, this action will copy it with a new name when deploying. By default, Fly apps will be named with the scheme pr-{number}-{repo_name}.

Inputs

name description
name The name of the Fly app. Alternatively, set the env FLY_APP. For safety, must include the PR number. Example: myapp-pr-${{ github.event.number }}. Defaults to pr-{number}-{repo_name}.
image Optional pre-existing Docker image to use
config Optional path to a custom Fly toml config. Config path should be relative to path parameter, if specified.
region Which Fly region to run the app in. Alternatively, set the env FLY_REGION. Defaults to iad.
org Which Fly organization to launch the app under. Alternatively, set the env FLY_ORG. Defaults to personal.
path Path to run the flyctl commands from. Useful if you have an existing fly.toml in a subdirectory.
update Whether or not to update this Fly app when the PR is updated. Default true.
secrets Runtime environment variables.
vm Changes the type of the VM. Defaults to shared-cpu-1x.
vm_memory Adjusts VM's memory. Default to 256.

Required Secrets

FLY_API_TOKEN - Required. The token to use for authentication. You can find a token by running flyctl auth token or going to your user settings on fly.io.

Basic Example

name: Staging App
on:
  pull_request:
    types: [opened, reopened, synchronize, closed]

env:
  FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
  FLY_REGION: <put your desired region>
  FLY_ORG: <put your fly org name>

jobs:
  staging_app:
    runs-on: ubuntu-latest

    # Only run one deployment at a time per PR.
    concurrency:
      group: pr-${{ github.event.number }}

    # Create a GitHub deployment environment per staging app so it shows up
    # in the pull request UI.
    environment:
      name: pr-${{ github.event.number }}
      url: ${{ steps.deploy.outputs.url }}

    steps:
      - uses: actions/checkout@v3

      - name: Deploy
        id: deploy
        uses: optimumBA/fly-pr-review-apps@main

With Secrets

      - name: Deploy
        id: deploy
        uses: optimumBA/fly-pr-review-apps@main
        with:
          name: pr-${{ github.event.number }}-${{ env.REPO_NAME }}
          secrets: 'SECRET_1=${{ secrets.SECRET_1 }} SECRET_2=${{ secrets.SECRET_2 }}'

Cleaning up GitHub environments

This action will destroy the Fly app, but it will not destroy the GitHub environment, so those will hang around in the GitHub UI. If this is bothersome, use an action like strumwolf/delete-deployment-environment to delete the environment when the PR is closed.

on:
  pull_request:
    types: [opened, reopened, synchronize, closed]

# ...

jobs:
  staging_app:
    # ...

    # Create a GitHub deployment environment per review app.
    environment:
      name: pr-${{ github.event.number }}
      url: ${{ steps.deploy.outputs.url }}

    steps:
      - uses: actions/checkout@v3

      - name: Deploy app
        id: deploy
        uses: optimumBA/fly-pr-review-apps@main

      - name: Clean up GitHub environment
        uses: strumwolf/delete-deployment-environment@v1
        uses: strumwolf/delete-deployment-environment@v1
        if: ${{ github.event.action == 'closed' }}
        with:
          # ⚠️ The provided token needs permission for admin write:org
          token: ${{ secrets.GITHUB_TOKEN }}
          environment: pr-${{ github.event.number }}

Example with multiple Fly apps

If you need to run multiple Fly apps per staging app, for example Redis, memcached, etc, just give each app a unique name. Your application code will need to be able to discover the app hostnames.

Redis example:

steps:
  - uses: actions/checkout@v3

  - name: Deploy redis
    uses: optimumBA/fly-pr-review-apps@main
    with:
      update: false # Don't need to re-deploy redis when the PR is updated
      path: redis # Keep fly.toml in a subdirectory to avoid confusing flyctl
      image: flyio/redis:6.2.6
      name: pr-${{ github.event.number }}-myapp-redis

  - name: Deploy app
    id: deploy
    uses: optimumBA/fly-pr-review-apps@main
    with:
      name: pr-${{ github.event.number }}-myapp-app

About

Github Action for PR Review Apps on Fly.io

License:Apache License 2.0


Languages

Language:Shell 95.7%Language:Dockerfile 4.3%