Skip to content

Commit

Permalink
Feat/add workflow preview prs (#348)
Browse files Browse the repository at this point in the history
* fix: improve comments and name for deploy workflow

* feat: clean up and improve config files

* feat: add workflow to preview prs

* feat: add workflow to remove preview files when pr closed
  • Loading branch information
f-hollow authored Dec 9, 2024
1 parent 3dbc1ff commit b0821d3
Show file tree
Hide file tree
Showing 6 changed files with 142 additions and 19 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Deploy Hugo site
name: Deploy production

on:
# Run on pushes to the default branch
Expand All @@ -8,10 +8,9 @@ on:
# Allow manual runs from the Actions tab
workflow_dispatch:

# Set permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
# Set permissions of the GITHUB_TOKEN
permissions:
contents: read
pages: write
id-token: write

# Allow only one concurrent deployment
Expand Down Expand Up @@ -68,7 +67,7 @@ jobs:
runs-on: ubuntu-latest
steps:

- name: Invalidate cloudfront cache
- name: Invalidate CloudFront cache
uses: chetan/invalidate-cloudfront-action@v2
env:
PATHS: "/*"
Expand Down
89 changes: 89 additions & 0 deletions .github/workflows/pr-deploy-preview.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
name: Deploy preview for PR

on:
pull_request:
types: [opened, synchronize, reopened]
# Allow manual runs from the Actions tab
workflow_dispatch:

# Set permissions of the GITHUB_TOKEN
permissions:
contents: read
id-token: write
pull-requests: write

# Allow only one concurrent deployment
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: false

# Define environment variables
env:
HUGO_BASEURL: "https://preview-developer.espressif.com/pr${{ github.event.pull_request.number }}/"

# Default to bash
defaults:
run:
shell: bash

jobs:
build-and-deploy-preview:
runs-on: ubuntu-latest

steps:

- name: Install Hugo CLI
env:
HUGO_VERSION: 0.135.0
run: |
wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \
&& sudo dpkg -i ${{ runner.temp }}/hugo.deb
- name: Check out repo
uses: actions/checkout@v4
with:
submodules: recursive

- name: Build website with Hugo
env:
# For maximum backward compatibility with Hugo modules
HUGO_ENVIRONMENT: preview
HUGO_ENV: preview
run: |
hugo \
--gc \
--minify
- name: Deploy to AWS S3 PR-specific subdirectory
uses: jakejarvis/s3-sync-action@master
with:
args: --follow-symlinks --delete --cache-control no-cache
env:
AWS_S3_BUCKET: ${{ secrets.PREVIEW_AWS_BUCKET_NAME }}
SOURCE_DIR: './public'
# Subdirectory for the PR
DEST_DIR: "pr${{ github.event.pull_request.number }}"
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}

- name: Post Preview Link to PR
uses: actions/github-script@v7
with:
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: `🎉 A preview of this PR is available at: ${{ env.HUGO_BASEURL }} `
})
- name: Invalidate CloudFront cache for PR
uses: chetan/invalidate-cloudfront-action@v2
env:
PATHS: "/pr-${{ github.event.pull_request.number }}/*"
DISTRIBUTION: ${{ secrets.PREVIEW_CLOUDFRONT_DISTRIBUTION }}
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
31 changes: 31 additions & 0 deletions .github/workflows/pr-remove-preview.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
name: Remove preview for PR

on:
pull_request:
types:
- closed

jobs:
remove-preview:
name: Remove preview for PR
runs-on: ubuntu-latest

steps:
# Remove the PR-specific folder from S3
- name: Remove PR-specific subdirectory from S3
run: |
echo "Cleaning up preview folder for PR #${{ github.event.pull_request.number }}"
aws s3 rm "s3://${{ secrets.PREVIEW_AWS_BUCKET_NAME }}/pr${{ github.event.pull_request.number }}" --recursive
env:
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}

- name: Invalidate CloudFront cache for PR
uses: chetan/invalidate-cloudfront-action@v2
env:
PATHS: "/pr-${{ github.event.pull_request.number }}/*"
DISTRIBUTION: ${{ secrets.PREVIEW_CLOUDFRONT_DISTRIBUTION }}
AWS_REGION: ${{ secrets.AWS_REGION }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
12 changes: 6 additions & 6 deletions config/_default/hugo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,11 @@
# Refer to the theme docs for more details about each of these parameters.
# https://blowfish.page/docs/getting-started/

theme = "blowfish"
baseURL = "https://developer.espressif.com"
baseURL = "https://preview-developer.espressif.com/"
languageCode = "en"
defaultContentLanguage = "en"
title = "Espressif Developer Portal Preview"
theme = "blowfish"

# Keep English on top level
defaultContentLanguageInSubdir = false
Expand All @@ -14,10 +16,8 @@ defaultContentLanguageInSubdir = false
enableRobotsTXT = true
summaryLength = 0

buildDrafts = false
buildFuture = false

googleAnalytics = "G-K9NTMXPGN3"
buildDrafts = true
buildFuture = true

[pagination]
pagerSize = 30
Expand Down
13 changes: 13 additions & 0 deletions config/production/hugo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# -- Site Configuration --
# Refer to the theme docs for more details about each of these parameters.
# https://blowfish.page/docs/getting-started/

baseURL = "https://developer.espressif.com/"
title = "Espressif Developer Portal"

buildDrafts = false
buildFuture = false

[services]
[services.googleAnalytics]
id = "G-K9NTMXPGN3"
9 changes: 0 additions & 9 deletions hugo.toml

This file was deleted.

0 comments on commit b0821d3

Please sign in to comment.