Skip to content

leo-build-tag-publish-and-run-tests #6113

leo-build-tag-publish-and-run-tests

leo-build-tag-publish-and-run-tests #6113

# Github action to Build Leonardo, add/promote semantic tagging and then run tests
name: leo-build-tag-publish-and-run-tests
on:
pull_request:
branches: [ develop ]
paths-ignore: [ '**.md' ]
push:
branches: [ develop ]
paths-ignore: [ '**.md' ]
workflow_run:
workflows: [ automerge ]
types:
- completed
workflow_dispatch:
inputs:
terra-env:
description: 'Terra env this test run is triggered for. This is mainly used to indicate this workflow was triggered from a staging run'
required: true
default: 'develop'
type: string
automation-branch:
description: 'Branch of leo to run tests from'
required: true
default: 'develop'
type: string
env:
BEE_NAME: '${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt}}-gcp-dev'
TOKEN: '${{ secrets.BROADBOT_TOKEN }}' # github token for access to kick off a job in the private repo
LEO_BUILD_RUN_NAME: 'leonardo-build-${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt }}'
LEO_SWAT_TESTS_RUN_NAME: 'leonardo-swat-tests-${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt }}'
BEE_CREATE_RUN_NAME: 'bee-create-${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt }}'
BEE_DESTROY_RUN_NAME: 'bee-destroy-${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt }}'
# AZURE_SWAT_TESTS_RUN_NAME: 'azure-swat-tests-${{ github.event.repository.name }}-${{ github.run_id }}-${{ github.run_attempt }}'
concurrency:
# Don't run this workflow concurrently on the same branch
group: ${{ github.workflow }}-${{ github.ref }}
# For PRs, don't wait for completion of existing runs, cancel them instead
cancel-in-progress: ${{ github.event_name == 'pull_request' }}
jobs:
#
# Environment Initialization
#
init-github-context:
runs-on: ubuntu-latest
if: ${{ github.event_name != 'workflow_run' || github.event.workflow_run.conclusion == 'success' }}
outputs:
# automation-branch: the git branch automation test application to be used, running on the gha runner
# build-branch: the git branch to checkout to build a new app-version
# app-version: the version of the leonardo app artifact that will be tested against, usually running in a BEE
# these are often the same string, but all represent distinct artifacts
automation-branch: ${{ steps.extract-branch.outputs.automation-branch }}
build-branch: ${{ steps.extract-branch.outputs.build-branch }}
app-version: ${{ steps.extract-branch.outputs.app-version }}
create-bee: ${{ steps.prepare-outputs.outputs.delete-bee }}
delete-bee: ${{ steps.prepare-outputs.outputs.delete-bee }}
owner-subject: ${{ steps.prepare-outputs.outputs.owner-subject }}
service-account: ${{ steps.prepare-outputs.outputs.service-account }}
log-results: ${{ steps.prepare-outputs.outputs.log-results }}
test-context: ${{ steps.prepare-outputs.outputs.test-context }}
relates-to-chart-releases: ${{ steps.prepare-outputs.outputs.relates-to-chart-releases }}
notify-failure-channel: ${{ steps.prepare-outputs.outputs.notify-failure-channel }}
test-env: ${{ steps.prepare-outputs.outputs.test-env }}
leo-test-command: ${{ steps.prepare-outputs.outputs.leo-test-command }}
steps:
- name: Get inputs and/or set defaults
id: prepare-outputs
run: |
echo 'notify-failure-channel=ia-notification-test' >> $GITHUB_OUTPUT
echo 'delete-bee=true' >> $GITHUB_OUTPUT
echo 'log-results=true' >> $GITHUB_OUTPUT
if ${{ github.ref_name == 'develop' }}; then
echo 'test-context=dev-merge' >> $GITHUB_OUTPUT
echo 'relates-to-chart-releases=leonardo-dev' >> $GITHUB_OUTPUT
echo 'leo-test-command=testOnly -- -l ExcludeFromJenkins' >> $GITHUB_OUTPUT
else
echo 'test-context=pr-test' >> $GITHUB_OUTPUT
echo 'leo-test-command=testOnly -- -l ExcludeFromJenkins -l ExcludeFromPRCommit' >> $GITHUB_OUTPUT
fi
ENV=local
if ${{ github.event_name == 'workflow_dispatch' }}; then
ENV=${{ inputs.terra-env }}
fi
echo "test-env=$ENV" >> $GITHUB_OUTPUT
# we need this because github can't actually provide the branch name reliably
# https://github.com/orgs/community/discussions/5251
- name: Extract branch
id: extract-branch
run: |
if [[ '${{ github.event_name }}' == 'push' || '${{ github.event_name }}' == 'workflow_run' ]]; then
BRANCH_NAME=${{ github.ref_name }}
elif [[ '${{ github.event_name }}' == 'pull_request' ]]; then
BRANCH_NAME=${{ github.head_ref }}
elif [[ '${{ github.event_name }}' == 'workflow_dispatch' ]]; then
BRANCH_NAME=${{ inputs.automation-branch }}
else
echo "Failed to extract branch information"
exit 1
fi
echo "build-branch=$BRANCH_NAME" >> $GITHUB_OUTPUT
echo "automation-branch=$BRANCH_NAME" >> $GITHUB_OUTPUT
#
# Artifact Build and Promotion
#
leo-build-tag-publish-job:
runs-on: ubuntu-latest
needs: [init-github-context]
permissions:
contents: 'read'
id-token: 'write'
outputs:
tag: ${{ steps.tag.outputs.tag }}
steps:
- uses: 'actions/checkout@v4'
- name: Bump the tag to a new version
uses: databiosphere/github-actions/actions/bumper@bumper-0.0.6
id: tag
env:
DEFAULT_BUMP: patch
GITHUB_TOKEN: ${{ secrets.BROADBOT_TOKEN }}
RELEASE_BRANCHES: develop
WITH_V: true
# Builds Leonardo elsewhere to protect secrets. Upon success, will tag the commit in git.
- name: dispatch to terra-github-workflows
uses: broadinstitute/workflow-dispatch@v4.0.0
with:
workflow: leonardo-build
repo: broadinstitute/terra-github-workflows
ref: refs/heads/main
token: ${{ secrets.BROADBOT_TOKEN }} # github token for access to kick off a job in the private repo
inputs: '{
"repository": "${{ github.event.repository.full_name }}",
"ref": "${{ needs.init-github-context.outputs.build-branch }}",
"leonardo-release-tag": "${{ steps.tag.outputs.tag }}"
}'
report-to-sherlock:
# Report new Leonardo version to Broad DevOps
uses: broadinstitute/sherlock/.github/workflows/client-report-app-version.yaml@main
needs: [ leo-build-tag-publish-job ]
with:
new-version: ${{ needs.leo-build-tag-publish-job.outputs.tag }}
chart-name: 'leonardo'
permissions:
contents: 'read'
id-token: 'write'
set-version-in-dev:
# Put new Leonardo version in Broad dev environment
uses: broadinstitute/sherlock/.github/workflows/client-set-environment-app-version.yaml@main
needs: [ leo-build-tag-publish-job, report-to-sherlock ]
if: ${{ github.ref_name == 'develop' }}
with:
new-version: ${{ needs.leo-build-tag-publish-job.outputs.tag }}
chart-name: 'leonardo'
environment-name: 'dev'
secrets:
sync-git-token: ${{ secrets.BROADBOT_TOKEN }}
permissions:
id-token: 'write'
report-workflow:
uses: broadinstitute/sherlock/.github/workflows/client-report-workflow.yaml@main
needs: [ init-github-context ]
if: ${{ github.ref_name == 'develop' }}
with:
notify-slack-channels-upon-workflow-failure: ${{ needs.init-github-context.outputs.notify-failure-channel }}
relates-to-chart-releases: ${{ needs.init-github-context.outputs.relates-to-chart-releases }}
permissions:
id-token: 'write'
#
# E2E Tests - Setup and Run
#
create-bee-workflow:
runs-on: ubuntu-latest
needs: [ leo-build-tag-publish-job, report-to-sherlock ]
permissions:
contents: 'read'
id-token: 'write'
steps:
# format the app version string to be usable by create-bee
- name: Render Leonardo version
id: render-leo-version
env:
GITHUB_CONTEXT: ${{ toJSON(github) }}
run: |
echo "$GITHUB_CONTEXT"
echo 'custom-version-json={\"leonardo\":{\"appVersion\":\"${{ needs.leo-build-tag-publish-job.outputs.tag }}\"}}' >> $GITHUB_OUTPUT
- name: dispatch to terra-github-workflows
uses: broadinstitute/workflow-dispatch@v4.0.0
with:
run-name: "${{ env.BEE_CREATE_RUN_NAME }}"
workflow: bee-create
repo: broadinstitute/terra-github-workflows
ref: refs/heads/main
token: ${{ secrets.BROADBOT_TOKEN }}
inputs: '{
"run-name": "${{ env.BEE_CREATE_RUN_NAME }}",
"bee-name": "${{ env.BEE_NAME }}",
"bee-template-name": "rawls-e2e-azure-tests",
"version-template": "dev",
"custom-version-json": "${{ steps.render-leo-version.outputs.custom-version-json }}"
}'
## !! Commenting out until when/if the azure tests are necessary again...
# azure-automation-tests:
# runs-on: ubuntu-latest
# needs: [ leo-build-tag-publish-job, report-to-sherlock, init-github-context, create-bee-workflow ]
# permissions:
# contents: 'read'
# id-token: 'write'
# steps:
# - name: dispatch to azure automation test workflow
# uses: broadinstitute/workflow-dispatch@v4.0.0
# with:
# run-name: "${{ env.AZURE_SWAT_TESTS_RUN_NAME }}"
# workflow: .github/workflows/azure_automation_test.yml
# repo: DataBiosphere/leonardo
# ref: refs/heads/develop
# token: ${{ env.TOKEN }}
# # this is not actually 85mins, the timeout is not working correctly and is summing from other jobs
# wait-for-completion-timeout: 85m
# inputs: '{
# "terra-env": "${{ needs.init-github-context.outputs.test-env }}",
# "automation-branch": "${{ needs.init-github-context.outputs.automation-branch }}",
# "app-version": "${{ needs.leo-build-tag-publish-job.outputs.tag }}",
# "bee-name": "${{ env.BEE_NAME }}",
# "is-triggered-from-pr-dispatch": "true",
# "run-name": "${{ env.AZURE_SWAT_TESTS_RUN_NAME }}"
# }'
# wait-for-completion: true
leo-swat-test-job:
strategy:
matrix:
terra-env: [ dev ] # what versions of apps do we use to emulate types of environments
testing-env: [ qa ] # what env resources to use, e.g. SA keys
runs-on: ubuntu-latest
needs: [create-bee-workflow, init-github-context]
permissions:
contents: 'read'
id-token: 'write'
steps:
- name: Configure test-reporting input parameter
# TEST_REPORTING values are used as follows:
# log_results: boolean to log test results to bigquery
# test_context: descriptive context that test is running in, e.g. PR, post-develop, staging. Will be passed to env of the bigquery table
# caller_run_id: descriptive run_id of caller
run: |
TEST_REPORTING='{
"log_results": { "val": ${{ needs.init-github-context.outputs.log-results }} },
"test_context": { "val": "${{ needs.init-github-context.outputs.test-context }}" },
"caller_run_id": { "val": "${{ github.run_id }}" }
}'
TEST_REPORTING=$(echo "$TEST_REPORTING" |
tr -d '\n' |
jq -c '.')
echo "TEST_REPORTING=$TEST_REPORTING" >> $GITHUB_ENV
- name: dispatch to terra-github-workflows
uses: broadinstitute/workflow-dispatch@v4.0.0
with:
run-name: "${{ env.LEO_SWAT_TESTS_RUN_NAME }}"
workflow: leonardo-swat-tests
repo: broadinstitute/terra-github-workflows
ref: refs/heads/main
wait-for-completion-timeout: 85m
token: ${{ secrets.BROADBOT_TOKEN }} # github token for access to kick off a job in the private repo
inputs: '{
"run-name": "${{ env.LEO_SWAT_TESTS_RUN_NAME }}",
"bee-name": "${{ env.BEE_NAME }}",
"ENV": "${{ matrix.testing-env }}",
"sbt-test-command": "${{ needs.init-github-context.outputs.leo-test-command }}",
"java-version": "17",
"ref": "${{ needs.init-github-context.outputs.automation-branch }}",
"test-reporting": ${{ toJson(env.TEST_REPORTING) }}
}'
#
# E2E Tests - Cleanup
#
destroy-bee-workflow:
runs-on: ubuntu-latest
needs:
- init-github-context
- leo-swat-test-job
# - azure-automation-tests
if: ${{ needs.init-github-context.outputs.delete-bee && always() }} # always run to confirm bee is destroyed unless explicitly requested not to
permissions:
contents: 'read'
id-token: 'write'
steps:
- name: dispatch to terra-github-workflows
uses: broadinstitute/workflow-dispatch@v4.0.0
with:
run-name: "${{ env.BEE_DESTROY_RUN_NAME }}"
workflow: bee-destroy
repo: broadinstitute/terra-github-workflows
ref: refs/heads/main
token: ${{ env.TOKEN }}
inputs: '{
"run-name": "${{ env.BEE_DESTROY_RUN_NAME }}",
"bee-name": "${{ env.BEE_NAME }}"
}'
wait-for-completion: false
# Uncomment this when tests are stable
# Be sure to add the hook here https://beehive.dsp-devops.broadinstitute.org/environments/staging/chart-releases/leonardo/deploy-hooks/github-actions/25?saved=true
# notify-slack:
# runs-on: ubuntu-latest
# needs:
# - init-github-context
# - create-bee-workflow
# - leo-swat-test-job
# - destroy-bee-workflow
# steps:
# - id: notify-dsde-qa-on-staging
# uses: slackapi/slack-github-action@v1.23.0
# name: Notify dsde-qa on staging runs
# if: needs.init-github-context.outputs.test-env == 'staging'
# with:
# # C53JYBV9A is for #dsde-qa
# channel-id: 'C53JYBV9A'
# slack-message: "Leonardo GCP E2E Staging Tests Ran \n\tStatus: ${{ job.status }} \n\tBranch: ${{ needs.init-github-context.outputs.automation-branch }} \n\tRun: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
# env:
# SLACK_BOT_TOKEN: ${{ secrets.SLACKBOT_TOKEN }}