2021-05-25 12:07:45 -04:00
# This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
# This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
2021-09-10 11:05:35 -07:00
name : Deploy of main (AWS CDN)
2021-05-25 12:07:45 -04:00
on :
2021-07-27 12:37:17 -04:00
pull_request :
2021-09-10 11:05:35 -07:00
types : [ closed]
2021-05-25 12:07:45 -04:00
branches : [ main]
paths :
2021-09-10 11:05:35 -07:00
- "client/**/*"
2021-05-25 12:07:45 -04:00
jobs :
build :
runs-on : ubuntu-latest
defaults :
run :
working-directory : client
strategy :
matrix :
node-version : [ 14. x]
steps :
- uses : actions/checkout@v2
- name : Use Node.js ${{ matrix.node-version }}
uses : actions/setup-node@v2
with :
node-version : ${{ matrix.node-version }}
2021-06-14 10:42:09 -04:00
# If this is just a PR branch, put content in a hash directory. Otherwise, put it in "main"
2021-06-28 10:59:08 -04:00
# This variable is used by gatsby-config.js to set a prefixPath
- name : Set DESTINATION_FOLDER for main
2021-09-10 11:05:35 -07:00
# if: github.event_name == 'pull_request' && github.event.action == 'closed' && github.event.pull_request.merged == true
2021-06-28 10:59:08 -04:00
run : |
echo "DESTINATION_FOLDER=main" >> $GITHUB_ENV
2021-09-10 11:05:35 -07:00
# - name: Set DESTINATION_FOLDER for branch
# if: github.event.pull_request.merged != true
# run: |
# echo "DESTINATION_FOLDER=$(echo $GITHUB_SHA | cut -c 1-6)" >> $GITHUB_ENV
2021-05-25 12:07:45 -04:00
- name : Install
run : npm ci
- name : Build
run : npm run build --if-present
2021-09-07 10:35:11 -07:00
env :
DATA_SOURCE : development
2021-05-25 12:07:45 -04:00
- name : Get directory contents
run : ls -la public
2021-05-25 16:21:21 -04:00
- name : Lint
run : npm run lint
2021-06-16 18:16:49 -04:00
# Disabling for now due to jsonlint - TODO: put this back
# - name: License Check
# run: npm run licenses
2021-05-25 12:07:45 -04:00
- name : Test
run : npm test
2021-06-02 13:21:23 -04:00
- name : Check for security vulnerabilities
run : npm audit --production
2021-05-25 12:07:45 -04:00
- name : Upload Artifact
uses : actions/upload-artifact@v2
with :
name : J40Static
# Upload-artifact does not support the default working directory
# See more: https://github.com/actions/upload-artifact/issues/87
path : ./client/public
deploy :
runs-on : ubuntu-latest
needs : build
steps :
- name : Checkout source
uses : actions/checkout@v2
- name : Download Artifacts
uses : actions/download-artifact@v2
with :
name : J40Static
path : ./public
2021-06-14 10:42:09 -04:00
# If this is just a PR branch, put content in a hash directory. Otherwise, put it in "main"
2021-06-28 10:59:08 -04:00
- name : Set DESTINATION_FOLDER for main
2021-09-10 11:05:35 -07:00
# if: github.event_name == 'pull_request' && github.event.action == 'closed' && github.event.pull_request.merged == true
2021-06-28 10:59:08 -04:00
run : |
echo "DESTINATION_FOLDER=main" >> $GITHUB_ENV
2021-09-10 11:05:35 -07:00
# - name: Set DESTINATION_FOLDER for branch
# if: github.event.pull_request.merged != true
# run: |
# echo "DESTINATION_FOLDER=$(echo $GITHUB_SHA | cut -c 1-6)" >> $GITHUB_ENV
# - name: Deploy to Github Pages
# uses: JamesIves/github-pages-deploy-action@4.1.0
# with:
# BRANCH: gh-pages # The branch the action should deploy to.
# FOLDER: public # The folder the action should deploy.
# TARGET-FOLDER: ${{env.DESTINATION_FOLDER}} # If we're on a PR branch, merge to PR folder
# CLEAN: true
2021-06-07 11:57:46 -04:00
- name : Configure AWS Credentials
uses : aws-actions/configure-aws-credentials@v1
with :
2021-08-16 14:25:34 -04:00
aws-access-key-id : ${{ secrets.CLIENT_DEV_AWS_ACCESS_KEY_ID }}
2021-08-16 14:47:15 -04:00
aws-secret-access-key : ${{ secrets.CLIENT_DEV_AWS_SECRET_ACCESS_KEY }}
2021-06-07 11:57:46 -04:00
aws-region : us-east-1
- name : Deploy to Geoplatform AWS
2021-08-12 14:17:25 -04:00
run : aws s3 sync ./public/ s3://usds-geoplatform-justice40-website/justice40-tool/${{env.DESTINATION_FOLDER}} --acl public-read --delete
2021-09-10 11:05:35 -07:00
- name : Invalidate cache on AWS CDNs
uses : chetan/invalidate-cloudfront-action@master
env :
DISTRIBUTION : "ED03LPVC4OXSW" # TODO: set this as ENV var above
PATHS : "/*"
AWS_REGION : "us-east-1"
AWS_ACCESS_KEY_ID : ${{ secrets.CLIENT_DEV_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY : ${{ secrets.CLIENT_DEV_AWS_SECRET_ACCESS_KEY }}
2021-07-27 12:37:17 -04:00
- name : Update PR with deployed URL
uses : mshick/add-pr-comment@v1
2021-09-10 11:05:35 -07:00
# if: (github.event_name == 'pull_request' && github.event.action == 'opened') || github.event_name == 'push' # Only comment if the PR has been opened or a push has updated it
2021-07-27 12:37:17 -04:00
with :
message : |
**🚢 PR Deployed! 🚢**
Find it here : https://d2zjid6n5ja2pt.cloudfront.net/justice40-tool/${{env.DESTINATION_FOLDER}}/en/cejst/ !
repo-token : ${{ secrets.GITHUB_TOKEN }}
2021-09-10 11:05:35 -07:00
repo-token-user-login : "github-actions[bot]" # The user.login for temporary GitHub tokens
2021-07-27 12:37:17 -04:00
allow-repeats : false # This is the default
- name : Printing deployment URLs
run : |
echo "Github pages: https://usds.github.io/justice40-tool/$DESTINATION_FOLDER/en"
echo "Standard S3 bucket version (http only) : http://usds-geoplatform-justice40-website.s3-website-us-east-1.amazonaws.com/justice40-tool/$DESTINATION_FOLDER/en"
2021-08-12 14:17:25 -04:00
echo "Cloudfront https: https://d2zjid6n5ja2pt.cloudfront.net/justice40-tool/$DESTINATION_FOLDER/en"