DR-3408: SqlSortDirection Model no longer generated #4158
Workflow file for this run
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: e2e | |
env: | |
K8_CLUSTER: "integration-master" | |
# This must be defined for the bash redirection | |
GOOGLE_APPLICATION_CREDENTIALS: 'jade-dev-account.json' | |
# This must be defined for the bash redirection | |
GOOGLE_SA_CERT: 'jade-dev-account.pem' | |
on: | |
workflow_dispatch: {} | |
pull_request: | |
branches: | |
- develop | |
schedule: | |
- cron: '0 4 * * *' # run at 4 AM UTC, 12PM EST. | |
jobs: | |
e2e_test: | |
name: Cypress End-to-end Tests | |
timeout-minutes: 180 | |
strategy: | |
matrix: | |
node-version: [16.x] | |
if: "!contains( github.event.pull_request.labels.*.name, 'skip-ci')" | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out the repository | |
uses: actions/checkout@v3 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v3 | |
with: | |
node-version: ${{ matrix.node-version }} | |
- name: 'Whitelist Runner IP' | |
uses: broadinstitute/datarepo-actions/actions/main@0.67.0 | |
with: | |
actions_subcommand: 'gcp_whitelist' | |
role_id: ${{ secrets.ROLE_ID }} | |
secret_id: ${{ secrets.SECRET_ID }} | |
- name: 'Check for an available namespace to deploy API to and set state lock' | |
id: namespace | |
uses: broadinstitute/datarepo-actions/actions/main@0.67.0 | |
with: | |
actions_subcommand: 'k8_checknamespace' | |
# Note: Integration-4 is also set up for UI testing, except that the datasets | |
# have been removed. We'd need to run the "ingest.js" script to ingest the datasets | |
# in order to use int-4 again. | |
k8_namespaces: 'integration-4,integration-5' | |
- name: initialize npm | |
env: | |
DEV_PROJECT: broad-jade-dev | |
DISABLE_ESLINT_PLUGIN: true | |
run: | | |
GCR_TAG=$(git rev-parse --short HEAD) | |
echo "GCR_TAG=$(echo ${GCR_TAG})" >> $GITHUB_ENV | |
npm ci | |
- name: set npm env | |
run: | | |
eval $(cat env_vars) | |
echo "HOST=$(echo ${localhost})" >> $GITHUB_ENV | |
HOST=localhost | |
echo "HOST=$(echo ${HOST})" >> $GITHUB_ENV | |
- name: check npm start | |
env: | |
DISABLE_ESLINT_PLUGIN: true | |
run: | | |
npm start & timeout 600 bash -c "until nc -z localhost 3000; do sleep 5; done" | |
# Build the Docker image | |
- name: Build | |
run: | | |
rm -rf jade-dev-account.pem | |
docker build -f Dockerfile.direct -t gcr.io/broad-jade-dev/jade-data-repo-ui:${GCR_TAG} --build-arg CACHEBUST=$(date +%s) . | |
# Push the Docker image to Google Container Registry | |
- name: Publish | |
run: | | |
gcloud auth activate-service-account --key-file jade-dev-account.json | |
gcloud auth configure-docker --quiet | |
docker push gcr.io/broad-jade-dev/jade-data-repo-ui:${GCR_TAG} | |
# Echo what the image deployed was (useful for running skaffold deploy --image ... ) | |
- name: Echo tagged image | |
run: | | |
echo "Pushed docker image gcr.io/broad-jade-dev/jade-data-repo-ui:${GCR_TAG}" | |
- name: 'Deploy to cluster with Helm' | |
uses: broadinstitute/datarepo-actions/actions/main@0.67.0 | |
with: | |
actions_subcommand: 'helmdeploy' | |
helm_create_secret_manager_secret_version: '0.0.6' | |
helm_datarepo_api_chart_version: 0.0.571 | |
helm_datarepo_ui_chart_version: 0.0.289 | |
helm_gcloud_sqlproxy_chart_version: 0.19.9 | |
helm_oidc_proxy_chart_version: 0.0.42 | |
helm_imagetag_update: 'ui' | |
- name: "Wait for deployment to come back online" | |
uses: broadinstitute/datarepo-actions/actions/wait-for-deployment@0.67.0 | |
env: | |
DEPLOYMENT_TYPE: 'ui' | |
- name: set cypresss env | |
run: | | |
eval $(cat env_vars) | |
echo "CYPRESS_BASE_URL=$(echo ${IT_JADE_API_URL})" >> $GITHUB_ENV | |
CYPRESS_GOOGLE_TOKEN=$(gcloud auth print-access-token) | |
echo ::add-mask::${CYPRESS_GOOGLE_TOKEN} | |
echo "CYPRESS_GOOGLE_TOKEN=$(echo ${CYPRESS_GOOGLE_TOKEN})" >> $GITHUB_ENV | |
- name: Cypress run | |
env: | |
CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} | |
DISABLE_ESLINT_PLUGIN: true | |
run: | | |
npx cypress run --record | |
- name: 'Clean state lock from used Namespace on API deploy' | |
if: always() | |
uses: broadinstitute/datarepo-actions/actions/main@0.67.0 | |
with: | |
actions_subcommand: 'k8_checknamespace_clean' | |
- name: 'Clean whitelisted Runner IP' | |
if: always() | |
uses: broadinstitute/datarepo-actions/actions/main@0.67.0 | |
with: | |
actions_subcommand: 'gcp_whitelist_clean' |