You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
You can copy the files located at `.github/workflows` and add them to your own project.
14
+
You can copy the files located at [`.github/workflows/`](./.github/workflows/) and add them to your own project.
9
15
10
16
You will then need to set the following secrets in your repository:
11
17
18
+
-`FLY_API_TOKEN`: Your Fly.io API token, you can find it in your Fly.io account settings.
12
19
-`NEON_PROJECT_ID`: The ID of your Neon project, you can find it in your Neon project settings.
13
20
-`NEON_API_KEY`: Your Neon API key, you can find it in your Neon account settings.
14
-
-`FLY_API_TOKEN`: Your Fly.io API token, you can find it in your Fly.io account settings.
21
+
-`NEON_DATABASE_USERNAME`: The username for your Neon database. This is the same as the username for your production database.
15
22
-`DATABASE_URL`: The connection string for your production database. You can find it in your Neon project's connection details.
16
23
-`GH_TOKEN`: A GitHub token with access to your repository, you can create one in your GitHub account settings. You will need to give it access to the `repo` scope so that the `deploy-preview` workflow can comment on the pull request. You can uncomment the step which uses this token in the `.github/workflows/deploy-preview.yml` workflow file.
17
-
-`NEON_DATABASE_USERNAME`: The username for your Neon database. This is the same as the username for your production database.
18
-
19
24
20
25
## How it works
21
26
22
-
### Creating a preview deployment
23
-
`.github/workflows/deploy-preview.yml` automates the deployment process to a preview environment. It is activated on a `pull_request` event and uses the `NEON_API_KEY`, `NEON_PROJECT_ID`, `GH_TOKEN`, `FLY_API_TOKEN` and `NEON_DATABASE_USERNAME` secrets that are set in the repository.
27
+
### Preview deployment
28
+
[`.github/workflows/deploy-preview.yml`](./.github/workflows/deploy-preview.yml) automates the deployment process to a preview environment.
24
29
25
-
The workflow has a single job called `deploy-preview` and it consists of the following steps:
30
+
Activated on a `pull_request` event
31
+
```yaml
32
+
on: [pull_request]
33
+
```
26
34
27
-
1. Ensures concurrency control, allowing only one deployment at a time per pull request.
28
-
1. Checks out the codebase using [`actions/checkout@v4`](https://github.com/marketplace/actions/checkout).
29
-
2. Sets up PNPM with [`pnpm/action-setup@v2`](https://github.com/marketplace/actions/setup-pnpm). (You can use another package manager depending on your setup.)
30
-
3. Configures Node.js version with caching for PNPM via actions/setup-node@v4.
31
-
4. Installs dependencies using `pnpm install`.
32
-
5. Retrieves the branch name using [`tj-actions/branch-names@v8`](https://github.com/marketplace/actions/branch-names).
33
-
6. Creates a Neon database branch for the pull request with [`neondatabase/create-branch-action@v4`](https://github.com/marketplace/actions/neon-database-create-branch-action). By default, the branch name will be `preview/<git-branch-name>-<commit_SHA>`
34
-
7. Executes database migrations by setting up the `.env` file and running migration scripts.
35
-
8. Deploys the application with [`superfly/[email protected]`](https://github.com/marketplace/actions/github-action-for-deplying-staging-apps-on-fly-io), while including the Neon database URL.
36
-
9. Comments on the pull request with deployment and database branch details using `thollander/actions-comment-pull-request@v2`.
35
+
Requires the `NEON_API_KEY`, `NEON_PROJECT_ID`, `GH_TOKEN`, `FLY_API_TOKEN` and `NEON_DATABASE_USERNAME` secrets that are set in the repository.
37
36
38
-
### Creating a production deployment
37
+
The workflow has a single job called `deploy-preview`
38
+
```yaml
39
+
jobs:
40
+
deploy-preview:
41
+
```
42
+
43
+
In that job it consists of the following steps:
39
44
40
-
`.github/workflows/deploy-production.yml` automates the deployment process to a production environment. It is activated on a `push` event to the `main` branch and uses the `FLY_API_TOKEN` and `DATABASE_URL` secrets that are set in the repository.
45
+
1. Ensures concurrency control, allowing only one deployment at a time per pull request.
46
+
```yaml
47
+
concurrency:
48
+
group: pr-${{ github.event.number }}
49
+
```
50
+
51
+
2. Check out the codebase using [`actions/checkout@v4`](https://github.com/marketplace/actions/checkout).
52
+
```yaml
53
+
- uses: actions/checkout@v4
54
+
```
55
+
3. Sets up PNPM with [`pnpm/action-setup@v2`](https://github.com/marketplace/actions/setup-pnpm). (You can use another package manager depending on your setup.)
56
+
```yaml
57
+
- uses: pnpm/action-setup@v2
58
+
with:
59
+
version: 8
60
+
```
61
+
4. Configures Node.js version with caching for PNPM via `actions/setup-node@v4`.
62
+
```yaml
63
+
- name: Use Node.js 18
64
+
uses: actions/setup-node@v4
65
+
with:
66
+
node-version: 18
67
+
cache: "pnpm"
68
+
```
69
+
5. Installs dependencies using `pnpm install`.
70
+
```yaml
71
+
- name: Install dependencies
72
+
run: pnpm install
73
+
```
74
+
6. Retrieves and normalizes the branch name using [`tj-actions/branch-names@v8`](https://github.com/marketplace/actions/branch-names).
75
+
```yaml
76
+
- name: Get branch name
77
+
id: branch-name
78
+
uses: tj-actions/branch-names@v8
79
+
```
80
+
7. Creates a Neon database branch for the pull request with [`neondatabase/create-branch-action@v4`](https://github.com/marketplace/actions/neon-database-create-branch-action). By default, the branch name will be `preview/<git-branch-name>-<commit_SHA>`
81
+
```yaml
82
+
- name: Create Neon Branch
83
+
id: create-branch
84
+
uses: neondatabase/create-branch-action@v4
85
+
with:
86
+
project_id: ${{ env.NEON_PROJECT_ID }}
87
+
# parent: dev # optional (defaults to your primary branch)
9. Deploys the application with [`superfly/[email protected]`](https://github.com/marketplace/actions/github-action-for-deplying-staging-apps-on-fly-io), while including the Neon database URL.
10. Comments on the pull request with deployment and database branch details using `thollander/actions-comment-pull-request@v2`. Here's an [example comment](https://github.com/neondatabase/preview-branches-with-fly/pull/9#issuecomment-1924660371)
111
+
```yaml
112
+
- name: Comment on Pull Request
113
+
uses: thollander/actions-comment-pull-request@v2
114
+
with:
115
+
# GITHUB_TOKEN: ${{ env.GH_TOKEN }} # Required for commenting on pull requests for private repos
[`.github/workflows/deploy-production.yml`](./.github/workflows/deploy-production.yml) automates the deployment process to a production environment. It is activated on a `push` event to the `main` branch and uses the `FLY_API_TOKEN` and `DATABASE_URL` secrets that are set in the repository.
41
124
42
125
The workflow has a single job called `production-deploy` and it consists of the following steps:
43
-
1. Checks out the codebase using actions/checkout@v4.
44
-
2. Sets up PNPM using pnpm/action-setup@v2 and specifies version 8. (You can use another package manager depending on your setup.)
126
+
1. Checks out the codebase using `actions/checkout@v4`
127
+
2. Sets up PNPM using `pnpm/action-setup@v2` and specifies version 8. (You can use another package manager depending on your setup.)
45
128
3. Configures the environment to use Node.js version 18 using actions/setup-node@v4, with a cache configured for PNPM.
46
129
4. Installs project dependencies using pnpm install.
47
130
5. Runs database migrations with the command pnpm run db:migrate.
@@ -53,4 +136,4 @@ The workflow has a single job called `production-deploy` and it consists of the
53
136
54
137
`.github/workflows/delete-neon-branch.yml`automates the cleanup of branches in Neon. It is activated on a `pull_request` event with the action `closed`. This will ensure that Neon branches are deleted when a pull request is closed/merged.
55
138
56
-
The workflow uses [`neondatabase/[email protected]`](https://github.com/neondatabase/delete-branch-action/tree/v3.1.3/) action which uses the `NEON_API_KEY` and `NEON_PROJECT_ID` secrets that are set in the repository.
139
+
The workflow uses [`neondatabase/[email protected]`](https://github.com/neondatabase/delete-branch-action/tree/v3.1.3/) action which uses the `NEON_API_KEY` and `NEON_PROJECT_ID` secrets that are set in the repository.
0 commit comments