Skip to content

Commit

Permalink
test dev deploy
Browse files Browse the repository at this point in the history
  • Loading branch information
codemonkey800 committed Nov 7, 2024
1 parent 968988c commit c4f0d6a
Show file tree
Hide file tree
Showing 2 changed files with 100 additions and 19 deletions.
35 changes: 35 additions & 0 deletions .github/get-deploy-data.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
async function getDeployData({ event, eventName }) {
let ref = ''

switch (eventName) {
case 'pull_request': {
ref = event.pull_request.head.ref
break
}

default: {
ref = event.ref.replace('refs/heads/', '')
break
}
}

ref = ref.replaceAll('/', '-').slice(0, 25)

const isPr = eventName === 'pull_request'
const isPreview =
event?.pull_request?.labels?.some(label => label.name === 'preview') ??
false

return JSON.stringify({
ref,
url: `https://${ref}.cryoet.dev.si.czi.technology`,
isPush: eventName === 'push',
isDelete: eventName === 'delete',
isLabeled: isPr && event.action === 'labeled',
isUnlabeled: isPr && event.action === 'unlabeled',
isSync: isPr && event.action === 'synchronize' && isPreview,
isClosed: isPr && event.action === 'closed' && isPreview,
})
}

module.exports = getDeployData
84 changes: 65 additions & 19 deletions .github/workflows/dev-deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ on:
delete:
branches:
- 'dev-*'
pull_request:
types: [labeled, unlabeled, synchronize, closed]

# https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
permissions:
Expand All @@ -18,25 +20,53 @@ jobs:
name: deploy dev branch
runs-on: ubuntu-latest
environment: dev
if: github.repository == 'chanzuckerberg/cryoet-data-portal'
if: |
github.repository == 'chanzuckerberg/cryoet-data-portal' && (
github.event_name != 'pull_request' ||
(
startsWith(github.head_ref, 'dev-') != true &&
(
contains(github.event.pull_request.labels.*.name, 'preview') ||
(
github.event.action == 'unlabeled' &&
github.event.label.name == 'preview'
)
)
)
)
steps:
- name: Checkout Repo
uses: actions/checkout@v3

- id: deploy-data
name: get stack name
uses: actions/github-script@v7
with:
script: |
const getDeployData = require('./.github/get-deploy-data')
return getDeployData({
event: ${{ toJson(github.event) }},
eventName: '${{ github.event_name }}',
})
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v4
with:
mask-aws-account-id: true
aws-region: ${{ secrets.AWS_REGION }}
role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
role-duration-seconds: 1200
- name: Setting up stack name
run: |
if [[ ${#GITHUB_REF_NAME} -gt 25 ]]; then
echo "branch name: ${GITHUB_REF_NAME}, length ${#GITHUB_REF_NAME}, is $((${#GITHUB_REF_NAME} - 25)) characters too long, please use a branch name that's 25 characters or shorter"
exit 1
else
echo $GITHUB_REF_NAME | tr '[:upper:]' '[:lower:]' | xargs -I {} -n 1 echo STACK_NAME={} >> $GITHUB_ENV
fi

- name: check value
if: ${{ fromJson(steps.deploy-data.outputs.result).isSync }}
run: ${{ fromJson(steps.deploy-data.outputs.result).isSync }}

- name: Create or update dev stack
if: ${{ github.event_name == 'push' }}
if: |
fromJson(steps.deploy-data.outputs.result).isPush ||
fromJson(steps.deploy-data.outputs.result).isLabeled ||
fromJson(steps.deploy-data.outputs.result).isSync == 'true'
uses: chanzuckerberg/github-actions/.github/actions/[email protected]
env:
# Force using BuildKit instead of normal Docker, required so that metadata
Expand All @@ -46,31 +76,47 @@ jobs:
DOCKER_REPO: ${{ secrets.ECR_REPO }}/
ENV: dev
with:
stack-name: ${{ env.STACK_NAME }}
stack-name: ${{ fromJson(steps.deploy-data.outputs.result).ref }}
create-tag: true
tfe-token: ${{ secrets.TFE_TOKEN }}
working-directory: ./frontend
env: dev
operation: create-or-update

- name: Annotate workflow run with frontend URL
if: ${{ github.event_name == 'push' }} && success()
if: |
success() && (
fromJson(steps.deploy-data.outputs.result).isPush ||
fromJson(steps.deploy-data.outputs.result).isLabeled ||
fromJson(steps.deploy-data.outputs.result).isSync
)
run: |
echo "# Frontend URL:" >> $GITHUB_STEP_SUMMARY
echo >> $GITHUB_STEP_SUMMARY
echo "https://${{ env.STACK_NAME }}.cryoet.dev.si.czi.technology" >> $GITHUB_STEP_SUMMARY
echo "https://${{ steps.deploy-data.outputs.result }}.cryoet.dev.si.czi.technology" >> $GITHUB_STEP_SUMMARY
- name: Post comment on PR
if: success() && fromJson(steps.deploy-data.outputs.result).isLabeled
uses: actions/github-script@v7
with:
script: |
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: '# Frontend Preview URL\n\n${{ fromJson(steps.deploy-data.outputs.result).url }}'
})
- name: Delete dev set up stack name
if: ${{ github.event_name == 'delete' && startsWith(github.event.ref, 'dev-') }}
run: |
echo ${{ github.event.ref }} | tr '[:upper:]' '[:lower:]' | xargs -I {} -n 1 echo DELETE_STACK_NAME={} >> $GITHUB_ENV
- name: Delete dev
if: ${{ github.event_name == 'delete' && startsWith(github.event.ref, 'dev-') }}
if: |
fromJson(steps.deploy-data.outputs.result).isDelete ||
fromJson(steps.deploy-data.outputs.result).isUnlabeled ||
fromJson(steps.deploy-data.outputs.result).isClosed
uses: chanzuckerberg/github-actions/.github/actions/[email protected]
env:
ENV: dev
with:
stack-name: ${{ env.DELETE_STACK_NAME }}
stack-name: ${{ fromJson(steps.deploy-data.outputs.result).ref }}
operation: delete
tfe-token: ${{ secrets.TFE_TOKEN }}
env: dev
Expand Down

0 comments on commit c4f0d6a

Please sign in to comment.