This action performs a database schema diff on specified Neon branches for each pull request and writes a comment to the pull request highlighting the schema differences.
It supports workflows where schema changes are made on a branch. When you create or update a pull request containing schema changes, the action automatically generates a comment within the pull request. By including the schema diff as part of the comment, reviewers can easily assess the changes directly within the pull request.
You can take a look at the example PR comment to see what the output looks like.
If you would like to contribute to the development of this GitHub Action, see docs/development.md.
Using the action requires adding a Neon API key to your GitHub Secrets. There are two ways you can perform this setup:
-
Using the Neon GitHub Integration (recommended 👍) — this integration connects your Neon project to your GitHub repository, creates an API key, and sets the API key in your GitHub repository for you. See Neon GitHub Integration for instructions.
-
Manual setup — this method requires obtaining a Neon API key and configuring it manually in your GitHub repository.
- Obtain a Neon API key. See Create an API key for instructions.
- In your GitHub repository, go to Project settings and locate Secrets at the bottom of the left sidebar.
- Click Actions > New Repository Secret.
- Name the secret
NEON_API_KEY
and paste your API key in the Secret field - Click Add Secret.
Setup the action:
permissions:
pull-requests: write
contents: read
steps:
- uses: neondatabase/schema-diff-action@v1
with:
project_id: rapid-haze-373089
compare_branch: dev/sunny_plant
api_key: ${{ secrets.NEON_API_KEY }}
Alternatively, you can use ${{ vars.NEON_PROJECT_ID }}
to get your
project_id
. If you have set up the
Neon GitHub Integration,
the NEON_PROJECT_ID
variable will be defined as a variable in your GitHub
repository.
By default, the schema diff is calculated between the compare_branch
and its
parent. If it has no parent, then it will fail. If you want to define the base
branch, add the base_branch
field. Both the compare_branch
and base_branch
accept either the name or the ID of the branch, and you can use both (i.e.,
the compare_branch
can use the branch name while the base_branch
uses the
branch ID or vice-versa).
To enable the action to create pull request (PR) comments, you must configure the appropriate job permissions. To do this, add the following permissions to your job configuration:
jobs:
your_job:
permisions:
pull-request: write
contents: read
...other permissions needed for the rest of the job
steps:
- uses: neondatabase/schema-diff-action@v1
...
When setting permissions, make sure to account for all actions your workflow
performs to avoid missing any required permissions. For example, if your
repository is private, you must also grant read or write access to the
repository with contents: read
or contents: write
.
For a complete list of permissions, refer to the GitHub documentation on Defining access for the GITHUB_TOKEN permissions.
If your branch has more than one database, see the advanced usage section below.
The following fields are required to run the Schema Diff action:
project_id
— the Neon project ID. If you have the Neon GitHub Integration installed, you can specify${{ vars.NEON_PROJECT_ID }}
.api_key
— the Neon API key for your Neon project or organization. If you have the GitHub integration installed, specify${{ secrets.NEON_API_KEY }}
.compare_branch
— the name or ID of the branch to compare. This is typically the branch where you made schema changes.
If you don't provide values for the following fields explicitly, the action will use these default values:
github-token
—${{ github.token }}
, the ephemeral GitHub token used to create commentsapi_host
—https://console.neon.tech/api/v2
database
—neondb
, the default database name for new Neon projects
The GitHub token is required to create PR comments. The (${{ github.token }}
)
value is
automatically populated by GitHub
with a unique value for each workflow job.
By default, Neon creates a database with the name neondb
with a neondb_owner
role. If you intend to use other names, please add the fields explicitly in the
action.
If you don't want to compare the schema of your compare_branch
with the schema
of its parent branch, you can explicitly specify a different base branch with
the base_branch
field. The action below compares the schema with the main
branch explicitly.
steps:
- uses: neondatabase/schema-diff-action@v1
with:
project_id: ${{ vars.NEON_PROJECT_ID }}
compare_branch:
preview/pr-${{ github.event.number }}-${{ needs.setup.outputs.branch }}
base_branch: main
api_key: ${{ secrets.NEON_API_KEY }}
database: mydatabase
Additionally, you can set up extra parameters to define the state of your
compare_branch
. The fields timestamp
and lsn
allow you to specify a point
in time in your compare_branch
to be used for schema comparison. Only one of
these two values can be defined at a time.
Supported parameters:
Field | Required/optional | Default value |
---|---|---|
project_id |
required | n/a |
compare_branch |
required | n/a |
api_key |
required | n/a |
base_branch |
optional | empty, will default to the parent branch |
api_host |
optional | https://console.neon.tech/api/v2 |
database |
optional | neondb |
lsn |
optional | empty, will default to the branch's head |
timestamp |
optional | empty, will default to the branch's head |
The action provides two outputs:
diff
— the SQL schema diff between thecompare_branch
and thebase_branch
.comment_url
— the URL of the created or updated comment.