Skip to content
This repository has been archived by the owner on Mar 19, 2024. It is now read-only.

.github/workflows/build.yml #1241

.github/workflows/build.yml

.github/workflows/build.yml #1241

Workflow file for this run

name: build images
on:
push:
branches-ignore:
- 'dependabot/**'
- 'manual-dependencies/**'
paths-ignore:
- '.env.example'
- '.github/dependabot.yml'
- '.github/workflows/dependencies.yml'
- '.gitignore'
- 'LICENSE'
- 'README.md'
pull_request:
branches:
- main
paths-ignore:
- '.env.example'
- '.github/dependabot.yml'
- '.github/workflows/dependencies.yml'
- '.gitignore'
- 'LICENSE'
- 'README.md'
schedule:
- cron: '28 3 * * *'
# Cancel existing executions when new commits are pushed onto the same branch
# (Source: https://ashishb.net/tech/common-pitfalls-of-github-actions/)
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
defaults:
run:
shell: bash
# Use "env" to set workflow-level variables.
# NOTE: This can't be used by "jobs[*].container"; see "jobs.set_defaults" to use outputs as a workaround.
env:
BASEIMAGE_11: docker.io/library/tomcat:9-jre11-temurin-jammy
BASEIMAGE_17: docker.io/library/tomcat:9-jre17-temurin-jammy
jobs:
set_defaults:
name: Set defaults
runs-on: ubuntu-22.04
timeout-minutes: 3
steps:
# It is not currently possible to use a global env for jobs.baseimage_query.container.
# Because we may want to support alternate versions of Tomcat and Java in the future,
# we will set it a single time in this job and pass the value as an output.
- name: Set default base images
id: default_base_images
run: |
set -x
echo "base_image_11=$BASEIMAGE_11" >> $GITHUB_OUTPUT
echo "base_image_17=$BASEIMAGE_17" >> $GITHUB_OUTPUT
outputs:
base_image_11: ${{ steps.default_base_images.outputs.base_image_11 }}
base_image_17: ${{ steps.default_base_images.outputs.base_image_17 }}
baseimage_11_query:
name: Versions in Java 11 base image
needs: set_defaults
runs-on: ubuntu-22.04
timeout-minutes: 3
container: ${{ needs.set_defaults.outputs.base_image_11 }} # NOTE: This cannot be ${{ env.EXAMPLE }} or ${{ matrix.example }}
steps:
- name: Query versions of Java and Tomcat in the Java 11 base image
id: tomcat_query
run: |
set -x
echo "java_version=$( sed --regexp-extended --expression='s/^(jdk|jre)-?//' <<< "$JAVA_VERSION" )" >> $GITHUB_OUTPUT
echo "tomcat_major=$TOMCAT_MAJOR" >> $GITHUB_OUTPUT
echo "tomcat_version=$TOMCAT_VERSION" >> $GITHUB_OUTPUT
outputs:
java_version: ${{ steps.tomcat_query.outputs.java_version }}
tomcat_major: ${{ steps.tomcat_query.outputs.tomcat_major }}
tomcat_version: ${{ steps.tomcat_query.outputs.tomcat_version }}
baseimage_17_query:
name: Versions in Java 17 base image
needs: set_defaults
runs-on: ubuntu-22.04
timeout-minutes: 3
container: ${{ needs.set_defaults.outputs.base_image_17 }} # NOTE: This cannot be ${{ env.EXAMPLE }} or ${{ matrix.example }}
steps:
- name: Query versions of Java and Tomcat in the Java 17 base image
id: tomcat_query
run: |
set -x
echo "java_version=$( sed --regexp-extended --expression='s/^(jdk|jre)-?//' <<< "$JAVA_VERSION" )" >> $GITHUB_OUTPUT
echo "tomcat_major=$TOMCAT_MAJOR" >> $GITHUB_OUTPUT
echo "tomcat_version=$TOMCAT_VERSION" >> $GITHUB_OUTPUT
outputs:
java_version: ${{ steps.tomcat_query.outputs.java_version }}
tomcat_major: ${{ steps.tomcat_query.outputs.tomcat_major }}
tomcat_version: ${{ steps.tomcat_query.outputs.tomcat_version }}
generate_matrix:
name: Generate matrix of DHIS2 stable versions
runs-on: ubuntu-22.04
timeout-minutes: 3
steps:
- name: Checkout repo to current directory
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
- name: Setup Python
uses: actions/setup-python@65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236
with:
python-version: '3.11'
- name: Install Python packages
run: |
set -x
pip3 install --requirement .github/workflows/support/matrix/requirements.txt
- name: Generate matrix for dev and stable versions
id: matrix_cmd
run: |
set -x
echo "dhis2_matrix=$( python3 .github/workflows/support/matrix/matrix.py )" >> $GITHUB_OUTPUT
outputs:
dhis2_matrix: ${{ steps.matrix_cmd.outputs.dhis2_matrix }}
build:
name: Build image
needs:
- baseimage_11_query
- baseimage_17_query
- generate_matrix
runs-on: ubuntu-22.04
timeout-minutes: 60
services:
registry:
image: docker.io/library/registry:2
ports:
- 5000:5000
strategy:
matrix: ${{fromJSON(needs.generate_matrix.outputs.dhis2_matrix)}}
fail-fast: false
steps:
- name: Maximize build space
run: |
set -x
echo "Available storage:"
df -h
echo "Removing unwanted software... "
sudo rm -rf /usr/share/dotnet
sudo rm -rf /usr/local/lib/android
sudo rm -rf /opt/ghc
echo "Available storage:"
df -h
- name: Checkout this repository to source/ subdirectory
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
with:
path: source
- name: Download dhis.war to source/ subdirectory
id: get_war
run: |
set -x
# Trims full version like "2.36.1" or "2.36-dev" to "2.36" from job matrix
if grep --quiet --extended-regexp '^[0-9]{2}(\.|-)' <<< "${{ matrix.dhis2_version }}" ; then
DHIS2_MAJOR="$( cut -c1-2 <<< "${{ matrix.dhis2_version }}" )"
else
DHIS2_MAJOR="$( cut -c1-4 <<< "${{ matrix.dhis2_version }}" )"
fi
if [[ "$DHIS2_MAJOR" == "dev" ]] \
&& [[ "${{ matrix.dhis2_version }}" == "dev" ]]; then
DHIS2_WAR_URL="https://releases.dhis2.org/$DHIS2_MAJOR/dhis.war"
elif [[ "${{ matrix.dhis2_version }}" =~ ^2\.[0-9]{2}-dev$ ]]; then
DHIS2_WAR_URL="https://releases.dhis2.org/$DHIS2_MAJOR/dev/dhis2-dev-${DHIS2_MAJOR}.war"
elif [[ "${{ matrix.dhis2_version }}" == "2.36.0" ]] || [[ "${{ matrix.dhis2_version }}" == "2.36.11" ]]; then
DHIS2_WAR_URL="https://s3.amazonaws.com/dhis2-builds/${{ matrix.dhis2_version }}/latest/dhis.war"
else
DHIS2_WAR_URL="$( curl -s https://releases.dhis2.org/v1/versions/stable.json | jq -r '.versions[] | .patchVersions[] | select(.name=="${{ matrix.dhis2_version }}") | .url' )"
fi
wget \
--no-verbose \
--output-document=source/dhis.war \
"$DHIS2_WAR_URL"
# Expand to get the contents of build.properties
unzip -qq source/dhis.war -d source/dhis
DHIS2_BUILD_PROPERTIES="$( find source/dhis/WEB-INF/lib/ -name 'dhis-service-core-[0-9]*.jar' -exec unzip -p '{}' build.properties \; )"
echo "build_version=$( awk -F'=' '/^build\.version/ {gsub(/ /, "", $NF); print $NF}' <<< "$DHIS2_BUILD_PROPERTIES" )" >> $GITHUB_OUTPUT
echo "build_revision=$( awk -F'=' '/^build\.revision/ {gsub(/ /, "", $NF); print $NF}' <<< "$DHIS2_BUILD_PROPERTIES" )" >> $GITHUB_OUTPUT
echo "build_time=$( awk -F'=' '/^build\.time/ {sub(/ /, "", $NF); print $NF}' <<< "$DHIS2_BUILD_PROPERTIES" )" >> $GITHUB_OUTPUT
echo "build_date=$( awk -F'=' '/^build\.time/ {sub(/ /, "", $NF); print $NF}' <<< "$DHIS2_BUILD_PROPERTIES" | grep --only-matching --extended-regexp '20[0-9]{2}-[0-9]{2}-[0-9]{2}' )" >> $GITHUB_OUTPUT
- name: Version helper
id: versions_helper
run: |
set -x
# Trims full version like "2.36.1" or "2.36.7-SNAPSHOT" to "2.36" from war file build properties
if grep --quiet --extended-regexp '^[0-9]{2}(\.|-)' <<< "${{ steps.get_war.outputs.build_version }}" ; then
DHIS2_MAJOR="$( cut -c1-2 <<< "${{ steps.get_war.outputs.build_version }}" )"
else
DHIS2_MAJOR="$( cut -c1-4 <<< "${{ steps.get_war.outputs.build_version }}" )"
fi
echo "dhis2_major=$DHIS2_MAJOR" >> $GITHUB_OUTPUT
# 2.40 is co-branded as version 40. Generate alternate image tag values for all 2.40 releases
# Other versions will return the same values; duplicate tags will be normalized in steps.image_meta
if [[ '${{ matrix.dhis2_version }}' == '2.40-dev' ]] ; then
DHIS2_MAJOR_ALT='40'
DHIS2_VERSION_ALT='40-dev'
elif [[ "$DHIS2_MAJOR" == '2.40' ]] ; then
DHIS2_MAJOR_ALT='40'
DHIS2_VERSION_ALT="$( curl -s https://releases.dhis2.org/v1/versions/stable.json | jq -r '.versions[] | .patchVersions[] | select(.name=="${{ matrix.dhis2_version }}") | .url' | sed -e 's,^.*/dhis2-stable-,,' -e 's/\.war$//' )"
else
DHIS2_MAJOR_ALT="$DHIS2_MAJOR"
DHIS2_VERSION_ALT='${{ matrix.dhis2_version }}'
fi
echo "dhis2_major_alt=$DHIS2_MAJOR_ALT" >> $GITHUB_OUTPUT
echo "dhis2_version_alt=$DHIS2_VERSION_ALT" >> $GITHUB_OUTPUT
# If a version has builds for multiple versions of Java, mark one as the primary. As of this writing, matrix.py
# provides builds for Java 11 and 17 on DHIS2 2.39 and 2.40, but certain tags should only be added for 11.
DHIS2_PRIMARY_JAVA='true'
if [[ "$DHIS2_MAJOR" =~ 2\.(39|40) ]] && [[ '${{ matrix.java_major }}' == '17' ]]; then
DHIS2_PRIMARY_JAVA='false'
fi
echo "dhis2_primary_java=$DHIS2_PRIMARY_JAVA" >> $GITHUB_OUTPUT
# Trims full version with a _hotfix_ value like "2.36.10.1" or "2.36.10.1-SNAPSHOT", to a _maintenance_ value like "2.36.10"
# See https://dhis2-a3b1.kxcdn.com/uploads/default/original/3X/c/d/cd18b97ca7420000bd3c274c470cad01c63e24e5.jpeg
# or https://community.dhis2.org/t/hotfix-versioning-convention/47088 for details
if grep --quiet --only-matching --extended-regexp '^2\.[0-9]{2}\.[0-9]+\.[0-9]+.*' <<< "${{ matrix.dhis2_version }}" ; then
DHIS2_VERSION_MAINT="$( grep --only-matching --extended-regexp '^2\.[0-9]{2}\.[0-9]+' <<< "${{ matrix.dhis2_version }}" )"
else
DHIS2_VERSION_MAINT="${{ matrix.dhis2_version }}"
fi
echo "dhis2_version_maint=$DHIS2_VERSION_MAINT" >> $GITHUB_OUTPUT
# Due to limited GHA cache space, only retain Docker cache for one version
if ${{ matrix.latest_overall }}; then
echo "cache_to=type=gha,mode=max" >> $GITHUB_OUTPUT
fi
# Git checkout reference for e2e-tests repository
if [[ "${{ matrix.dhis2_version }}" == "dev" ]]; then
E2E_REMOTE_REF='master'
elif [[ "${{ matrix.dhis2_version }}" =~ ^2\.[0-9]{2}-dev$ ]]; then
# For a version like "2.37-dev", use "v37". If that doesn't exist, choose the latest as it is likely too new
if git ls-remote --heads --refs --sort='version:refname' https://github.com/dhis2/e2e-tests.git | awk '/[[:blank:]]+refs\/heads\/v[0-9]{2}$/ {gsub("refs/heads/",""); print $NF}' | grep "^v${DHIS2_MAJOR#2.}$"
then
E2E_REMOTE_REF="v${DHIS2_MAJOR#2.}"
else
E2E_REMOTE_REF="$( git ls-remote --heads --refs --sort='version:refname' https://github.com/dhis2/e2e-tests.git | awk '/[[:blank:]]+refs\/heads\/v[0-9]{2}$/ {gsub("refs/heads/",""); print $NF}' | sort --version-sort | tail -1 )"
fi
else
# The tag for a version may not exist in github.com/dhis2/e2e-tests, such as tag "2.37.0-rc"
# for version "2.37.1" as of this writing. This logic will determine the appropriate version
# if there is not an exact match.
if git ls-remote --tags --refs --sort='version:refname' https://github.com/dhis2/e2e-tests.git | awk '/[[:blank:]]+refs\/tags\/[0-9.]+-rc$/ {gsub("refs/tags/",""); print $NF}' | grep -q "^${{ matrix.dhis2_version }}-rc$"
then
E2E_REMOTE_REF="${{ matrix.dhis2_version }}-rc"
else
E2E_REMOTE_REF="$( git ls-remote --tags --refs --sort='version:refname' https://github.com/dhis2/e2e-tests.git | awk '/[[:blank:]]+refs\/tags\/[0-9.]+-rc$/ {gsub("refs/tags/",""); print $NF}'| grep "^${DHIS2_MAJOR}" | sort --version-sort | tail -1 )"
fi
fi
echo "e2e_remote_ref=$E2E_REMOTE_REF" >> $GITHUB_OUTPUT
# Git checkout depth for e2e-tests repository
if [[ "${{ matrix.dhis2_version }}" =~ ^2\.36\.[012]$ ]] ; then
echo "e2e_remote_depth=0" >> $GITHUB_OUTPUT
else
echo "e2e_remote_depth=1" >> $GITHUB_OUTPUT
fi
- name: Container image metadata
id: image_meta
uses: docker/metadata-action@96383f45573cb7f253c731d3b3ab81c87ef81934
with:
images: ghcr.io/${{ github.repository_owner }}/dhis2
labels: |
org.opencontainers.image.base.name=${{ env[format('BASEIMAGE_{0}', matrix.java_major)] }}
org.opencontainers.image.title=dhis2
org.opencontainers.image.url=${{ github.server_url }}/${{ github.repository }}/pkgs/container/dhis2
org.opencontainers.image.version=${{ matrix.dhis2_version }}
dhis2.build.major=${{ steps.versions_helper.outputs.dhis2_major }}
dhis2.build.version=${{ steps.get_war.outputs.build_version }}
dhis2.build.revision=${{ steps.get_war.outputs.build_revision }}
dhis2.build.time=${{ steps.get_war.outputs.build_time }}
dhis2.build.date=${{ steps.get_war.outputs.build_date }}
java.major=${{ matrix.java_major }}
java.version=${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['java_version'] }}
tomcat.major=${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_major'] }}
tomcat.version=${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_version'] }}
flavor: latest=false
tags: |
type=raw,value=latest,enable=${{ matrix.latest_overall }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_major }},enable=${{ matrix.latest_major }}
type=raw,value=${{ matrix.dhis2_version }},enable=${{ steps.versions_helper.outputs.dhis2_primary_java }}
type=raw,value=${{ matrix.dhis2_version }}-jre${{ matrix.java_major }}
type=raw,value=${{ matrix.dhis2_version }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_major'] }},enable=${{ steps.versions_helper.outputs.dhis2_primary_java }}
type=raw,value=${{ matrix.dhis2_version }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_major'] }}-jre${{ matrix.java_major }}
type=raw,value=${{ matrix.dhis2_version }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_version'] }}-jre${{ matrix.java_major }}-temurin-jammy
type=raw,value=${{ steps.versions_helper.outputs.dhis2_major_alt }},enable=${{ matrix.latest_major }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_version_alt }},enable=${{ steps.versions_helper.outputs.dhis2_primary_java }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_version_alt }}-jre${{ matrix.java_major }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_version_alt }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_major'] }},enable=${{ steps.versions_helper.outputs.dhis2_primary_java }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_version_alt }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_major'] }}-jre${{ matrix.java_major }}
type=raw,value=${{ steps.versions_helper.outputs.dhis2_version_alt }}-tomcat${{ needs[format('baseimage_{0}_query', matrix.java_major)]['outputs']['tomcat_version'] }}-jre${{ matrix.java_major }}-temurin-jammy
- name: Set up QEMU for amd64 and arm64
uses: docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3
with:
platforms: linux/amd64,linux/arm64
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@f95db51fddba0c2d1ec667646a06c2ce06100226
with:
driver-opts: network=host # Required for buildx container to push to local registry
- name: Multi-platform build and push to local registry
id: image_build
uses: docker/build-push-action@0565240e2d4ab88bba5387d719585280857ece09
with:
context: source # The default is to refer to the github.com sha URL, but we need the context as a directory for the downloaded dhis.war
file: source/Dockerfile # NOTE: A dhis.war file must be in the same directory as this file
platforms: linux/amd64,linux/arm64
build-args: |
BASE_IMAGE=${{ env[format('BASEIMAGE_{0}', matrix.java_major)] }}
labels: ${{ steps.image_meta.outputs.labels }}
tags: localhost:5000/dhis2:${{ matrix.dhis2_version }}-${{ github.sha }} # The host:port in the tag determines the registry it's pushed to
pull: true
push: true
cache-from: type=gha
cache-to: ${{ steps.versions_helper.outputs.cache_to }} # https://github.community/t/do-expressions-support-ternary-operators-to-change-their-returned-value/18114/2
- name: Inspect image in local registry
run: docker buildx imagetools inspect ${{ fromJSON(steps.image_build.outputs.metadata)['image.name'] }}
##########################################################################
- name: Use image from local registry in Compose
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }} # don't block the remaining actions if it fails on dev versions
run: |
set -x
sed \
--regexp-extended \
--expression="/^\s+image:/ s,ghcr\.io/baosystems/dhis2[^\"]+,${{ fromJSON(steps.image_build.outputs.metadata)['image.name'] }},g" \
--in-place \
source/docker-compose.yml
- name: Pull Compose stack images
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
run: |
set -x
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
pull --quiet
- name: Create Compose stack and start database service
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
run: |
set -x
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
up --detach database
- name: Initialize the database
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
run: |
set -x
sleep 6
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
exec database \
psql --echo-all --echo-hidden -v 'ON_ERROR_STOP=1' --username='postgres' --dbname='postgres' --command='CREATE ROLE "dhis";'
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
exec database \
psql --echo-all --echo-hidden -v 'ON_ERROR_STOP=1' --username='postgres' --dbname='postgres' --command='CREATE DATABASE "dhis2";'
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
exec database \
psql --echo-all --echo-hidden -v 'ON_ERROR_STOP=1' --username='postgres' --dbname='dhis2' --command='CREATE EXTENSION postgis;'
- name: Import sample data
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
run: |
set -x
if [[ "${{ matrix.dhis2_version }}" =~ ^2\.[0-9]{2}-dev$ ]]; then
DHIS2_DB_URL="https://databases.dhis2.org/sierra-leone/${{ steps.versions_helper.outputs.dhis2_major }}/dhis2-db-sierra-leone.sql.gz"
else
DHIS2_DB_URL="https://databases.dhis2.org/sierra-leone/${{ steps.versions_helper.outputs.dhis2_version_maint }}/dhis2-db-sierra-leone.sql.gz"
fi
wget \
--no-verbose \
--output-document=/tmp/db.sql.gz \
"$DHIS2_DB_URL"
gunzip -c /tmp/db.sql.gz \
| docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
exec -T database \
psql -q -v 'ON_ERROR_STOP=1' --username='postgres' --dbname='dhis2'
- name: Start DHIS2
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
timeout-minutes: 15
run: |
set -x
docker compose \
--project-name 'docker-dhis2' \
--project-directory 'source' \
--file 'source/docker-compose.yml' \
--file 'source/.github/workflows/support/docker-compose.override.yml' \
up --detach
# Wait for login screen
set +x
until \
curl -silent --output /dev/null --fail --max-time 1 http://localhost:8080/dhis-web-commons/security/login.action
do
sleep .5
done
- name: Generate analytics
continue-on-error: ${{ endsWith(matrix.dhis2_version, 'dev') }}
timeout-minutes: 30
run: |
set -x
export STATUS_URI="$(
curl --user 'system:System123' --max-time 10 --retry 5 --retry-delay 0 --retry-max-time 60 --connect-timeout 5 --silent \
--request POST \
--location \
'http://localhost:8080/api/resourceTables/analytics' \
| jq --raw-output '.response.relativeNotifierEndpoint'
)"
set +x
# Disable exiting on failure while parsing output
set +e
set +o pipefail
# Print status messages as they change
until [[ "$( curl --user 'system:System123' --max-time 10 --retry 5 --retry-delay 0 --retry-max-time 60 --connect-timeout 5 --silent "http://localhost:8080${STATUS_URI}" | jq --raw-output "sort_by(.time, .completed)|.[-1].completed" )" == "true" ]]; do
STATUS_CURRENT="$( curl --user 'system:System123' --max-time 10 --retry 5 --retry-delay 0 --retry-max-time 60 --connect-timeout 5 --silent "http://localhost:8080${STATUS_URI}" | jq "sort_by(.time, .completed)|.[-1]" )"
LINE_CURRENT="[$( jq --raw-output ".level" <<<"$STATUS_CURRENT" )] $( jq --raw-output ".time" <<<"$STATUS_CURRENT" ) $( jq --raw-output ".message" <<<"$STATUS_CURRENT" ) (Completed: $( jq --raw-output ".completed" <<<"$STATUS_CURRENT" ))"
if [[ "${LINE_PREV:-}" != "$LINE_CURRENT" ]]; then
echo "$LINE_CURRENT"
fi
LINE_PREV="$LINE_CURRENT"
sleep 3
done
# Print final status message
STATUS_LATEST="$( curl --user 'system:System123' --max-time 10 --retry 5 --retry-delay 0 --retry-max-time 60 --connect-timeout 5 --silent "http://localhost:8080${STATUS_URI}" | jq "sort_by(.time, .completed)|.[-1]" )"
LINE_LATEST="[$( jq --raw-output ".level" <<<"$STATUS_LATEST" )] $( jq --raw-output ".time" <<<"$STATUS_LATEST" ) $( jq --raw-output ".message" <<<"$STATUS_LATEST" ) (Completed: $( jq --raw-output ".completed" <<<"$STATUS_LATEST" ))"
if [[ "${LINE_PREV:-}" != "$LINE_LATEST" ]]; then
echo "$LINE_LATEST"
fi
##########################################################################
# - name: Install NodeJS
# uses: actions/setup-node@56337c425554a6be30cdef71bf441f15be286854
# with:
# node-version: '14' # NOTE: A dependency in dhis2/e2e-tests will not run in v16 or higher
# check-latest: true
# - name: Install Java # For Selenium
# uses: actions/setup-java@860f60056505705214d223b91ed7a30f173f6142
# with:
# distribution: 'adopt'
# java-version: '11'
# - name: Install latest google-chrome-stable
# run: |
# set -x
# echo "deb [arch=$(dpkg --print-architecture)] http://dl.google.com/linux/chrome/deb/ stable main" | sudo tee /etc/apt/sources.list.d/google-chrome.list >/dev/null
# curl --silent https://dl-ssl.google.com/linux/linux_signing_key.pub | gpg --dearmor | sudo tee /etc/apt/trusted.gpg.d/google.gpg >/dev/null
# sudo apt-get update
# if ! dpkg-query -W google-chrome-stable ; then
# sudo apt-get install -y --no-install-recommends google-chrome-stable
# else
# sudo apt-get install -y --only-upgrade google-chrome-stable
# fi
# - name: Checkout dhis2/e2e-tests to current directory
# uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
# with:
# repository: dhis2/e2e-tests
# ref: ${{ steps.versions_helper.outputs.e2e_remote_ref }} # "master" for dev, "${{ matrix.dhis2_version }}-rc" for releases; see "versions_helper" for logic
# fetch-depth: ${{ steps.versions_helper.outputs.e2e_remote_depth }} # default is "1", "0" for certain versions; see "versions_helper" for logic
# - name: Install dependencies for dhis2/e2e-tests
# run: |
# set -x
# npm install --legacy-peer-deps
# - name: Fix tests for 2.36.0 through 2.36.2
# if: |
# matrix.dhis2_version == '2.36.0' ||
# matrix.dhis2_version == '2.36.1' ||
# matrix.dhis2_version == '2.36.2'
# run: |
# set -x
# git show 2e090dd85936d8e95b5e5ed43ed1ceea7094888a | sed --regexp-extended --expression='s,([ab]/)(step_definitions/),\1tests/\2,g' | git apply --reverse
# - name: Add headless Chrome options to wdio
# run: |
# set -x
# if [[ -f ./tests/config/wdio.local.conf.js ]]; then
# WDIO_CONFIG_PATH="./tests/config/wdio.local.conf.js"
# else
# WDIO_CONFIG_PATH="./wdio.conf.js"
# fi
# sed \
# --regexp-extended \
# --expression="/\s*--disable-web-security/ { s/^(\s*)/\1'--headless','--disable-gpu','--window-size=2048,1536','--ignore-certificate-errors','--disable-extensions','--no-sandbox','--disable-dev-shm-usage',\n\1/ }" \
# --in-place \
# "$WDIO_CONFIG_PATH"
# - name: Cucumber tests # does NOT require analytics to have been generated
# if: | # Tests fail on earlier versions for similar reasons as newer Mocha tests
# matrix.dhis2_version != '2.35.0' &&
# matrix.dhis2_version != '2.35.1' &&
# matrix.dhis2_version != '2.35.2' &&
# matrix.dhis2_version != '2.35.3' &&
# matrix.dhis2_version != '2.35.4' &&
# matrix.dhis2_version != '2.35.5' &&
# matrix.dhis2_version != '2.36.0'
# uses: nick-fields/retry@e88a9994b039653512d697de1bce46b00bfe11b5
# with:
# timeout_minutes: 5
# max_attempts: 3
# warning_on_retry: false
# continue_on_error: ${{ endsWith(matrix.dhis2_version, 'dev') }} # don't block the remaining actions if it fails on dev versions
# command: |
# set -x
# npx wdio ./tests/config/wdio.cucumber.conf.js
# env:
# BASE_URL: http://localhost:8080/
# DEBUG: '1' # Do not run in parallel; there can be more failures in GHA without this due to limited resources
##########################################################################
- name: Login to GitHub Container Registry
if: ${{ (github.ref == 'refs/heads/main') && (github.event_name != 'pull_request') && !env.ACT }}
uses: docker/login-action@343f7c4344506bcbf9b4de18042ae17996df046d
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Copy image from local registry and push to public registry
if: ${{ (github.ref == 'refs/heads/main') && (github.event_name != 'pull_request') && !env.ACT }}
uses: akhilerm/tag-push-action@85bf542f43f5f2060ef76262a67ee3607cb6db37
with:
src: ${{ fromJSON(steps.image_build.outputs.metadata)['image.name'] }}
dst: ${{ steps.image_meta.outputs.tags }}
##########################################################################
# - name: Upload npm logs
# if: always()
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# with:
# name: ${{ matrix.dhis2_version }}_npm
# path: /home/runner/.npm/_logs/
# retention-days: 8
# if-no-files-found: ignore
# - name: Upload wdio logs
# if: always()
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# with:
# name: ${{ matrix.dhis2_version }}_wdio
# path: output/
# retention-days: 8
# if-no-files-found: ignore
# # Archive files before uploading as an artifact because of the following warning without doing so:
# # "There are over 10,000 files in this artifact, consider creating an archive before upload to improve the upload performance."
# - name: Archive allure results
# if: always()
# run: |
# if [[ -d reports/allure-results ]] ; then
# cd reports/
# zip -q -r allure-results.zip allure-results
# fi
# - name: Upload allure results
# if: always()
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# with:
# name: ${{ matrix.dhis2_version }}_allure
# path: reports/allure-results.zip
# retention-days: 8
# if-no-files-found: ignore
check:
name: Check if required jobs passed # this job name is to be used as the single required status check in branch protection
if: success()
needs: build
runs-on: ubuntu-22.04
timeout-minutes: 3
steps:
# See https://github.com/re-actors/alls-green/blob/3a2de129/README.md for why this is here
- name: Decide whether the needed jobs succeeded or failed
uses: re-actors/alls-green@05ac9388f0aebcb5727afa17fcccfecd6f8ec5fe
with:
jobs: ${{ toJSON(needs) }}