Show Netlify Preview URL #2
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: Test and Build the Application | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
branches: | |
- main | |
env: | |
BRANCH_NAME: ${{ github.ref_name }} | |
permissions: | |
pull-requests: write | |
jobs: | |
lint: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout the code | |
uses: actions/checkout@v4 | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "20.11.1" | |
- name: Load & cache dependencies | |
uses: ./.github/actions/cached-deps | |
- name: Run the linter | |
run: npm run lint -- --max-warnings=0 | |
test: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout the code | |
uses: actions/checkout@v4 | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "20.11.1" | |
- name: Load & cache dependencies | |
uses: ./.github/actions/cached-deps | |
- name: Run tests | |
run: npm test | |
build: | |
runs-on: ubuntu-latest | |
needs: test | |
environment: development | |
env: | |
VITE_CI: true | |
VITE_API_KEY: ${{vars.VITE_API_KEY}} | |
VITE_AUTH_DOMAIN: ${{vars.VITE_AUTH_DOMAIN}} | |
VITE_PROJECT_ID: ${{vars.VITE_PROJECT_ID}} | |
VITE_STORAGE_BUCKET: ${{vars.VITE_STORAGE_BUCKET}} | |
VITE_MESSAGING_SENDER_ID: ${{vars.VITE_MESSAGING_SENDER_ID}} | |
VITE_APP_ID: ${{vars.VITE_APP_ID}} | |
steps: | |
- name: Checkout the code | |
uses: actions/checkout@v4 | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "20.11.1" | |
- name: Load & cache dependencies | |
uses: ./.github/actions/cached-deps | |
id: chached-deps | |
- name: Build the application | |
run: npm run build | |
- name: Upload artifacts | |
if: success() | |
uses: actions/upload-artifact@v4 | |
with: | |
name: dist-files | |
path: dist | |
deploy: | |
runs-on: ubuntu-latest | |
needs: build | |
outputs: | |
NETLIFY_PREVIEW_URL: ${{ steps.url_preview.outputs.NETLIFY_PREVIEW_URL }} | |
steps: | |
- name: Get build artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
name: dist-files | |
path: ./dist | |
- name: Output files | |
working-directory: ./dist | |
run: ls -l | |
- name: Install Netlify CLI | |
run: npm install -g netlify-cli | |
- name: Deploy to Netlify | |
run: | | |
prod_flag="" | |
if [ "$BRANCH_NAME" = "main" ]; then prod_flag="--prod"; fi | |
netlify deploy \ | |
--dir dist \ | |
--site ${{ secrets.NETLIFY_SITE_ID }} \ | |
--auth ${{ secrets.NETLIFY_API_TOKEN }} \ | |
$prod_flag \ | |
--json \ | |
> deploy_output.json | |
- name: Generate URL Preview | |
id: url_preview | |
if: ${{ env.BRANCH_NAME != 'main' }} | |
run: | | |
NETLIFY_PREVIEW_URL=$(jq -r '.deploy_url' deploy_output.json) | |
echo "NETLIFY_PREVIEW_URL=$NETLIFY_PREVIEW_URL" >> "$GITHUB_OUTPUT" | |
report: | |
runs-on: ubuntu-latest | |
needs: [lint, build] | |
if: failure() | |
steps: | |
- name: Output information | |
run: | | |
echo "Something went wrong!" | |
echo "${{ toJson(github)}}" | |
preview_url: | |
runs-on: ubuntu-latest | |
needs: deploy | |
if: ${{ github.ref_name != 'main' }} | |
steps: | |
- name: Output URL | |
run: echo ${{ needs.deploy.outputs.NETLIFY_PREVIEW_URL }} | |
- name: Comment URL Preview on PR | |
uses: actions/github-script@v7 | |
env: | |
NETLIFY_PREVIEW_URL: ${{ needs.deploy.outputs.NETLIFY_PREVIEW_URL }} | |
with: | |
script: | | |
async function comment(){ | |
const result = await github.rest.repos.listPullRequestsAssociatedWithCommit({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
commit_sha: context.sha, | |
}) | |
const issueNumber = result.data[0].number | |
if(issueNumber){ | |
await github.rest.issues.createComment({ | |
issue_number: issueNumber, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Preview URL: ' + process.env.NETLIFY_PREVIEW_URL | |
}) | |
} else { | |
console.log('No PR found for commit ' + context.sha) | |
} | |
} | |
comment() |