feat(#8877): Look up users from their facility_id
or contact_id
#17411
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: Build and test | |
on: [push, pull_request] | |
env: | |
COUCH_URL: http://admin:pass@localhost:5984/medic-test | |
BUILDS_SERVER: ${{ secrets.AUTH_MARKET_URL && '_couch/builds_testing' || '_couch/builds_external' }} | |
STAGING_SERVER: ${{ secrets.AUTH_MARKET_URL && '_couch/builds_4' || '_couch/builds_external' }} | |
MARKET_URL_READ: 'https://staging.dev.medicmobile.org' | |
MARKET_URL: ${{ secrets.AUTH_MARKET_URL || 'https://staging.dev.medicmobile.org' }} | |
INTERNAL_CONTRIBUTOR: ${{ secrets.AUTH_MARKET_URL && 'true' }} | |
DOCKERHUB_USERNAME: 'dockermedic' | |
ECR_REPO: '720541322708.dkr.ecr.eu-west-2.amazonaws.com/medic' | |
ECR_PUBLIC_REPO: 'public.ecr.aws/medic' | |
COUCHDB_LOG_LEVEL: 'debug' | |
TAG: ${{ (github.ref_type == 'tag' && github.ref_name) || '' }} | |
BRANCH: ${{ github.head_ref || github.ref_name }} | |
BUILD_NUMBER: ${{ github.run_id }} | |
NODE_VERSION: '20.11' | |
jobs: | |
build: | |
name: Compile the app | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Install bats | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y bats | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ env.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.ECR_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.ECR_SECRET_ACCESS_KEY }} | |
aws-region: eu-west-2 | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
- name: Login to Amazon ECR | |
id: login-ecr | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
mask-password: 'true' | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ env.NODE_VERSION }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
- name: Couch Start | |
run: ./scripts/ci/couch-start | |
- name: Create logs directory | |
run: mkdir tests/logs | |
- run: npm ci | |
- name: Compile | |
run: npm run ci-compile | |
- name: Setup QEMU | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: docker/setup-qemu-action@v3 | |
- name: Setup Buildx | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: docker/setup-buildx-action@v3 | |
- name: Publish for testing | |
run: npm run publish-for-testing | |
- name: Upload docker images as artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: cht-images | |
path: images/ | |
if: ${{ !env.INTERNAL_CONTRIBUTOR }} | |
- name: Search-Replace PR Body | |
if: ${{ env.INTERNAL_CONTRIBUTOR && github.event_name == 'pull_request' }} | |
uses: ./.github/actions/update-staging-url-placeholders | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
config-tests: | |
needs: build | |
name: ${{ matrix.cmd }} | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false | |
matrix: | |
cmd: ['test-config-default'] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ env.NODE_VERSION }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
- run: npm ci | |
- name: Run Tests | |
run: npm run ${{ matrix.cmd }} | |
test-cht-form: | |
needs: build | |
runs-on: ubuntu-22.04 | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ env.NODE_VERSION }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
- run: sudo apt-get install -y xsltproc | |
- run: npm ci | |
- name: Build cht-form Web Component | |
run: npm run build-cht-form | |
- name: Run Tests | |
run: npm run wdio-cht-form | |
tests: | |
needs: build | |
name: ${{ matrix.cmd }}-${{ matrix.suite || '' }}${{ matrix.chrome-version == '90' && '-minimum-browser' || '' }} | |
runs-on: ubuntu-22.04 | |
env: | |
CHROME_VERSION: ${{ matrix.chrome-version }} | |
strategy: | |
fail-fast: false | |
matrix: | |
cmd: ['ci-integration-all', 'ci-integration-sentinel', 'ci-webdriver-default-mobile'] | |
chrome-version: ['90', 'latest'] | |
suite: [all] | |
include: | |
- cmd: ci-webdriver-default | |
suite: core | |
- cmd: ci-webdriver-default | |
suite: data | |
- cmd: ci-webdriver-default | |
suite: enketo | |
- cmd: ci-webdriver-default | |
suite: lowLevel | |
- cmd: ci-webdriver-default | |
suite: workflows | |
exclude: # temporary until all suites run on Chrome 90 | |
- cmd: ci-integration-all | |
chrome-version: 90 | |
- cmd: ci-integration-sentinel | |
chrome-version: 90 | |
- cmd: ci-webdriver-default-mobile | |
chrome-version: 90 | |
- cmd: ci-webdriver-default | |
chrome-version: 90 | |
steps: | |
- name: Login to Docker Hub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ env.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.ECR_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.ECR_SECRET_ACCESS_KEY }} | |
aws-region: eu-west-2 | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
- name: Login to Amazon ECR | |
id: login-ecr | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
mask-password: 'true' | |
- name: Use Node.js ${{ env.NODE_VERSION }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
- uses: actions/checkout@v4 | |
- name: Download docker images artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
name: cht-images | |
path: images/ | |
if: ${{ !env.INTERNAL_CONTRIBUTOR }} | |
- name: Load docker images | |
run: ls -1 *.tar | xargs --no-run-if-empty -L 1 docker load -i | |
working-directory: images/ | |
if: ${{ !env.INTERNAL_CONTRIBUTOR }} | |
- name: Set ENV | |
run: | | |
echo "HORTI_BUILDS_SERVER=$MARKET_URL_READ/$BUILDS_SERVER" >> $GITHUB_ENV | |
- name: Create logs directory | |
run: mkdir tests/logs | |
- name: Install pyxform | |
run: python -m pip install git+https://github.com/medic/[email protected]#egg=pyxform-medic | |
- name: Install cht-conf | |
run: npm install -g cht-conf | |
- run: npm ci | |
- name: Fetch allure history | |
uses: actions/checkout@v4 | |
with: | |
repository: 'medic/build-history-data' | |
path: 'build-history-data' | |
persist-credentials: false | |
- name: Copy allure history | |
run: | | |
mkdir -p allure-results/history | |
cp -r build-history-data/cht-core/allure/${{ matrix.cmd }}-${{ matrix.suite }}/allure-report/history allure-results | true | |
- name: Install Chrome 90 | |
if: ${{matrix.chrome-version=='90'}} | |
run: | | |
wget -O "google-chrome-stable_current_amd64.deb" https://www.slimjet.com/chrome/download-chrome.php?file=files/90.0.4430.72/google-chrome-stable_current_amd64.deb | |
sudo dpkg -i "google-chrome-stable_current_amd64.deb" | |
npm install chromedriver@^90.0.1 | |
- name: Run tests ${{ matrix.cmd }}-${{ matrix.suite }} on Chrome ${{ matrix.chrome-version }} | |
run: npm run ${{ matrix.cmd }} -- --suite=${{ matrix.suite }} | |
- name: Fetch allure history | |
if: always() | |
uses: actions/checkout@v4 | |
with: | |
repository: 'medic/build-history-data' | |
path: 'build-history-data-new' | |
persist-credentials: false | |
- name: Copy new allure history | |
if: always() | |
run: | | |
mkdir -p build-history-data-new/cht-core/allure/${{ matrix.cmd }}-${{ matrix.suite }}/history | |
cp -r allure-report/history build-history-data-new/cht-core/allure/${{ matrix.cmd }}-${{ matrix.suite }}/allure-report | true | |
- name: Upload allure report history | |
if: always() && github.ref == 'refs/heads/master' # whether pass or fail, but only on master | |
continue-on-error: true # don't fail the build if git push fails | |
uses: actions-js/push@master | |
with: | |
github_token: ${{ secrets.BUILD_HISTORY_DATA_PUSH_TOKEN }} | |
directory: 'build-history-data-new' | |
repository: 'medic/build-history-data' | |
force: true | |
- name: Fetch report repo | |
if: always() | |
uses: actions/checkout@v4 | |
with: | |
repository: 'medic/build-history' | |
path: 'build-history' | |
persist-credentials: false | |
- name: Copy new report | |
if: always() | |
run: | | |
mkdir -p build-history/cht-core/allure/${{ matrix.cmd }}-${{ matrix.suite }} | |
cp -r allure-report build-history/cht-core/allure/${{ matrix.cmd }}-${{ matrix.suite }} | true | |
- name: Upload allure report | |
if: always() && github.ref == 'refs/heads/master' # whether pass or fail, but only on master | |
continue-on-error: true # don't fail the build if git push fails | |
uses: actions-js/push@master | |
with: | |
github_token: ${{ secrets.BUILD_HISTORY_DATA_PUSH_TOKEN }} | |
directory: 'build-history' | |
repository: 'medic/build-history' | |
force: true | |
- name: Archive Results | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ matrix.cmd }}-${{ matrix.suite || ''}} | |
path: | | |
allure-results | |
allure-report | |
tests/logs | |
tests/results/ | |
if: ${{ failure() }} | |
publish: | |
needs: [tests, config-tests, test-cht-form] | |
name: Publish branch build | |
runs-on: ubuntu-22.04 | |
if: ${{ github.event_name != 'pull_request' }} | |
steps: | |
- name: Install regctl | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: regclient/actions/regctl-installer@main | |
- name: Configure AWS credentials | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.ECR_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.ECR_SECRET_ACCESS_KEY }} | |
aws-region: eu-west-2 | |
- name: Login to Amazon ECR | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
mask-password: 'true' | |
- name: Configure AWS credentials Public | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.ECR_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.ECR_SECRET_ACCESS_KEY }} | |
aws-region: us-east-1 | |
- name: Login to Public Amazon ECR | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
id: login-ecr-public | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
registry-type: public | |
mask-password: 'true' | |
- uses: actions/checkout@v4 | |
- name: Publish | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
run: | | |
cd scripts/ci | |
npm ci | |
node ./publish.js | |
node ./tag-docker-images.js | |
upgrade: | |
needs: [publish] | |
name: Upgrade from latest release | |
runs-on: ubuntu-22.04 | |
if: ${{ github.event_name != 'pull_request' }} | |
steps: | |
- name: Configure AWS credentials Public | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.ECR_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.ECR_SECRET_ACCESS_KEY }} | |
aws-region: us-east-1 | |
- name: Login to Public Amazon ECR | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
id: login-ecr-public | |
uses: aws-actions/amazon-ecr-login@v2 | |
with: | |
registry-type: public | |
mask-password: 'true' | |
- uses: actions/checkout@v4 | |
- name: Set ENV | |
run: | | |
echo "BUILDS_SERVER=$STAGING_SERVER" >> $GITHUB_ENV | |
- run: npm ci | |
- name: Create logs directory | |
run: mkdir tests/logs | |
- name: Upgrade | |
if: ${{ env.INTERNAL_CONTRIBUTOR }} | |
run: npm run upgrade-wdio | |
- name: Archive Results | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Upgrade | |
path: | | |
allure-results | |
allure-report | |
tests/logs | |
tests/results/ | |
if: ${{ failure() }} |