Updating R tests to work with the new version of sparklyr (1.8.4) #3145
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
# This workflow will build the software and documentation to ensure there are no errors, and also | |
# execute the tests. | |
# | |
# The FHIR server build is separated into three tranches, to minimise overall build time: | |
# | |
# Tranche 1: ModificationTest, AggregateQueryTest, ExtractTest | |
# Tranche 2: ManifestConverterTest, integration tests | |
# Tranche 3: All other FHIR server tests, tests from utilities and terminology modules | |
# | |
# There are a set of performance benchmarks that run and upload their results to a S3 bucket. | |
# | |
# This workflow also deploys a pre-release version of the software to Docker Hub and Maven Central, | |
# if the branch is a release branch (`release/**`). | |
name: Test | |
on: | |
push: | |
branches-ignore: | |
- gh-pages | |
jobs: | |
encoders: | |
name: Encoders | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Run the verify goal with Maven | |
env: | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: ${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
run: >- | |
mvn --batch-mode verify | |
-pl encoders -am | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 20 | |
- name: Upload encoders test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: encoders-surefire-reports | |
path: encoders/target/surefire-reports | |
- name: Upload test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: encoders-coverage | |
path: "**/jacoco.xml" | |
- name: Upload dump files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: encoders-dump-files | |
path: |- | |
**/*.dump | |
**/*.dumpstream | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: Encoders test report | |
fail_on_test_failures: true | |
fhir-server-1: | |
name: FHIR server (tranche 1) | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Cache test data | |
id: cache-test-data | |
uses: actions/cache@v3 | |
with: | |
path: fhir-server/src/test/resources/test-data/parquet | |
key: ${{ runner.os }}-test-data-${{ hashFiles('fhir-server/src/test/resources/test-data/fhir/*.ndjson', 'encoders/src/main/**/*.java', 'encoders/src/main/**/*.scala', 'fhir-server/src/main/java/au/csiro/pathling/io/Database.java') }} | |
- name: Run the verify goal with Maven | |
env: | |
# Activate the "tranche 1" test profile. If there is a cache hit on the test data, we | |
# don't need to import it. | |
PATHLING_PROFILES: testTranche1${{ steps.cache-test-data.outputs.cache-hit && ',!importTestData' || '' }} | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: >- | |
-DskipEncodersTests | |
-DskipUtilitiesTests | |
-DskipTerminologyTests | |
-DskipFhirPathTests | |
${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-P${{ env.PATHLING_PROFILES }} | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 30 | |
- name: Upload fhir-server test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-1-surefire-reports | |
path: fhir-server/target/surefire-reports | |
- name: Upload test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-1-coverage | |
path: "**/jacoco.xml" | |
- name: Upload timing log | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-1-timing-log | |
path: fhir-server/target/timing.log | |
- name: Upload dump files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-1-dump-files | |
path: |- | |
**/*.dump | |
**/*.dumpstream | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: FHIR server test report 1 | |
fail_on_test_failures: true | |
fhir-server-2: | |
name: FHIR server (tranche 2) | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Cache test data | |
id: cache-test-data | |
uses: actions/cache@v3 | |
with: | |
path: fhir-server/src/test/resources/test-data/parquet | |
key: ${{ runner.os }}-test-data-${{ hashFiles('fhir-server/src/test/resources/test-data/fhir/*.ndjson', 'encoders/src/main/**/*.java', 'encoders/src/main/**/*.scala', 'fhir-server/src/main/java/au/csiro/pathling/io/Database.java') }} | |
- name: Run the verify goal with Maven | |
env: | |
# Activate the "tranche 2" test profile. If there is a cache hit on the test data, we | |
# don't need to import it. | |
PATHLING_PROFILES: testTranche2${{ steps.cache-test-data.outputs.cache-hit && ',!importTestData' || '' }} | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: >- | |
-DskipEncodersTests | |
-DskipUtilitiesTests | |
-DskipTerminologyTests | |
-DskipFhirPathTests | |
${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-P${{ env.PATHLING_PROFILES }} | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 30 | |
- name: Upload fhir-server test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-2-surefire-reports | |
path: fhir-server/target/surefire-reports | |
- name: Upload test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-2-coverage | |
path: "**/jacoco.xml" | |
- name: Upload timing log | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-2-timing-log | |
path: fhir-server/target/timing.log | |
- name: Upload dump files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-2-dump-files | |
path: |- | |
**/*.dump | |
**/*.dumpstream | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: FHIR server test report 2 | |
fail_on_test_failures: true | |
# This job builds the FHIR server, and runs all tests that do not fall into tranches 1 or 2. | |
fhir-server-3: | |
name: FHIR server (tranche 3) | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Cache test data | |
id: cache-test-data | |
uses: actions/cache@v3 | |
with: | |
path: fhir-server/src/test/resources/test-data/parquet | |
key: ${{ runner.os }}-test-data-${{ hashFiles('fhir-server/src/test/resources/test-data/fhir/*.ndjson', 'encoders/src/main/**/*.java', 'encoders/src/main/**/*.scala', 'fhir-server/src/main/java/au/csiro/pathling/io/Database.java') }} | |
- name: Run the verify goal with Maven | |
env: | |
# Activate the "tranche 3" test profile. If there is a cache hit on the test data, we | |
# don't need to import it. | |
PATHLING_PROFILES: testTranche3${{ steps.cache-test-data.outputs.cache-hit && ',!importTestData' || '' }} | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: >- | |
-DskipEncodersTests | |
${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-P${{ env.PATHLING_PROFILES }} | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 30 | |
- name: Upload utilities test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: utilities-surefire-reports | |
path: utilities/target/surefire-reports | |
- name: Upload terminology test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: terminology-surefire-reports | |
path: terminology/target/surefire-reports | |
- name: Upload FHIRPath test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhirpath-surefire-reports | |
path: fhirpath/target/surefire-reports | |
- name: Upload FHIR server test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-3-surefire-reports | |
path: fhir-server/target/surefire-reports | |
- name: Upload FHIR server test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-3-coverage | |
path: "**/jacoco.xml" | |
- name: Upload timing log | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-3-timing-log | |
path: fhir-server/target/timing.log | |
- name: Upload dump files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: fhir-server-3-dump-files | |
path: |- | |
**/*.dump | |
**/*.dumpstream | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: FHIR server test report 3 | |
fail_on_test_failures: true | |
# This job builds, tests and scans the FHIR server Docker image. | |
docker-image: | |
name: Docker image | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Run the verify goal with Maven | |
if: github.actor == 'dependabot[bot]' | |
env: | |
# If the actor is Dependabot we skip the system test, as it requires access to secrets. | |
PATHLING_OPTS: >- | |
-DskipSurefireTests | |
-DskipITs | |
-Dpathling.dockerArchitecture=amd64 | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-Pdocker,!importTestData | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 15 | |
- name: Run the verify goal with Maven | |
if: github.actor != 'dependabot[bot]' | |
env: | |
PATHLING_OPTS: >- | |
-DskipSurefireTests | |
-Dmaven.test.failure.ignore | |
-Dpathling.dockerArchitecture=amd64 | |
-Dpathling.systemTest.auth.clientSecret=${{ secrets.TEST_CLIENT_SECRET }} | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-Pdocker,!importTestData | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 15 | |
- name: Scan Docker image for vulnerabilities | |
uses: aquasecurity/trivy-action@master | |
env: | |
TRIVY_OFFLINE_SCAN: true | |
with: | |
image-ref: "aehrc/pathling:${{ github.sha }}" | |
exit-code: "1" | |
ignore-unfixed: true | |
security-checks: "vuln" | |
severity: CRITICAL | |
timeout: 20m | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: Docker image test report | |
fail_on_test_failures: true | |
benchmark: | |
name: Benchmark | |
runs-on: ubuntu-latest | |
permissions: | |
id-token: write | |
steps: | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
role-to-assume: arn:aws:iam::865780493209:role/PathlingBenchmarkUpload | |
aws-region: ap-southeast-2 | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Cache test data | |
id: cache-test-data | |
uses: actions/cache@v3 | |
with: | |
path: fhir-server/src/test/resources/test-data/parquet | |
key: ${{ runner.os }}-test-data-${{ hashFiles('fhir-server/src/test/resources/test-data/fhir/*.ndjson', 'encoders/src/main/**/*.java', 'encoders/src/main/**/*.scala', 'fhir-server/src/main/java/au/csiro/pathling/io/Database.java') }} | |
- name: Get current time | |
id: timestamp | |
run: echo "::set-output name=timestamp::$(date +'%Y%m%d%H%M%S')" | |
- name: Run the verify goal with Maven | |
env: | |
# If there is a cache hit on the test data, we don't need to import it. If it is a cache | |
# miss, we still need to explicitly activate the `importTestData` profile, otherwise | |
# it will be deactivated by `skipTests`. | |
PATHLING_PROFILES: runBenchmark,${{ steps.cache-test-data.outputs.cache-hit && '!importTestData' || 'importTestData' }} | |
run: >- | |
mvn --batch-mode verify | |
-pl fhir-server -am | |
-P${{ env.PATHLING_PROFILES }} | |
-DskipSurefireTests | |
timeout-minutes: 20 | |
- name: Upload benchmark artifact | |
uses: actions/upload-artifact@v3 | |
with: | |
name: benchmark-results | |
path: "**/jmh-*.json" | |
- name: Upload benchmark file to S3 | |
run: aws s3 sync fhir-server/target/benchmark s3://pathling-benchmark/${{ github.ref }}/${{ github.run_id }}/${{ steps.timestamp.outputs.timestamp }}/ | |
js-client: | |
name: JavaScript client | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- uses: actions/setup-node@v3 | |
with: | |
node-version: "16" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Run the verify goal with Maven | |
run: >- | |
mvn --batch-mode verify | |
-pl lib/js -am | |
timeout-minutes: 5 | |
import: | |
name: Import lambda | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- uses: actions/setup-node@v3 | |
with: | |
node-version: "16" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Run the verify goal with Maven | |
run: | | |
mvn --batch-mode verify \ | |
-pl lib/import -am | |
timeout-minutes: 5 | |
- name: Upload import lambda | |
uses: actions/upload-artifact@v3 | |
with: | |
name: import-lambda | |
path: lib/import/target/pathling-import-lambda.zip | |
python-api: | |
name: Python API | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v4 | |
id: pythoninstall | |
with: | |
python-version: 3.8 | |
- name: Cache Python packages | |
uses: actions/cache@v3 | |
id: pythoncache | |
with: | |
path: /home/runner/.cache/pip | |
key: ${{ runner.os }}-pip-${{ hashFiles('lib/python/requirements.txt') }} | |
restore-keys: ${{ runner.os }}-pip | |
- name: Run the verify goal with Maven | |
env: | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: >- | |
-DskipEncodersTests | |
-DskipUtilitiesTests | |
-DskipTerminologyTests | |
${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
PYSPARK_PYTHON: ${{ steps.pythoninstall.outputs.python-path }} | |
PYSPARK_DRIVER_PYTHON: ${{ steps.pythoninstall.outputs.python-path }} | |
run: >- | |
mvn --batch-mode verify | |
-pl lib/python -am | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 30 | |
- name: Upload library API test reports | |
uses: actions/upload-artifact@v3 | |
with: | |
name: library-api-surefire-reports | |
path: library-api/target/surefire-reports | |
- name: Upload library API test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: library-api-coverage | |
path: "**/jacoco.xml" | |
- name: Upload Python API test coverage report | |
uses: actions/upload-artifact@v3 | |
with: | |
name: python-api-coverage | |
path: lib/python/**/coverage.xml | |
- name: Publish test results | |
# If the actor is Dependabot, we need to avoid anything that requires access to secrets. | |
if: github.actor != 'dependabot[bot]' | |
uses: scacap/action-surefire-report@v1 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
check_name: Python API test report | |
fail_on_test_failures: true | |
R-api: | |
runs-on: ubuntu-latest | |
name: PathlyR API | |
env: | |
R_KEEP_PKG_SOURCE: yes | |
SPARK_VERSION: 3.3.1 | |
HADOOP_VERSION: 2 | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- uses: r-lib/actions/setup-pandoc@v2 | |
- uses: r-lib/actions/setup-r@v2 | |
with: | |
r-version: "4.1.3" | |
use-public-rspm: true | |
- name: Install texlive-latex-base | |
run: sudo apt-get install -y texlive-latex-base texlive-fonts-extra | |
- name: Run maven to install dependencies | |
run: >- | |
mvn --batch-mode install -pl library-runtime -am -DskipTests | |
timeout-minutes: 30 | |
- name: Run the init goal with Maven | |
run: >- | |
mvn --batch-mode initialize -P '!R-install-deps' | |
-pl lib/R | |
timeout-minutes: 30 | |
- uses: r-lib/actions/setup-r-dependencies@v2 | |
with: | |
working-directory: lib/R | |
extra-packages: | | |
any::devtools | |
- name: Cache Spark | |
id: cache-spark | |
uses: actions/cache@v2 | |
with: | |
path: /home/runner/spark/spark-3.3.1-bin-hadoop2 | |
key: sparklyr-spark-3.3.1-bin-hadoop2-3 | |
- name: Install Spark (via sparklyr) | |
if: steps.cache-spark.outputs.cache-hit != 'true' | |
run: | | |
sparklyr::spark_install(version = Sys.getenv("SPARK_VERSION"), hadoop_version = Sys.getenv("HADOOP_VERSION")) | |
shell: Rscript {0} | |
- name: Run the verify goal with Maven | |
env: | |
# If the actor is not Dependabot, we ignore test failures and rely upon the Surefire | |
# report action to report them. | |
PATHLING_OPTS: >- | |
-DskipTests | |
-DskipPathlyrTests=false | |
${{ github.actor == 'dependabot[bot]' && '' || '-Dmaven.test.failure.ignore' }} | |
run: >- | |
mvn --batch-mode verify -P '!R-install-deps' | |
-pl lib/R -am | |
${{ env.PATHLING_OPTS }} | |
timeout-minutes: 30 | |
site: | |
name: Site | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- uses: actions/setup-node@v3 | |
with: | |
node-version: "16" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: |- | |
${{ runner.os }}-maven- | |
- name: Run the verify goal with Maven | |
run: >- | |
mvn --batch-mode verify | |
-pl site -am | |
-Pdocs | |
-DskipTests | |
timeout-minutes: 15 | |
upload-coverage: | |
name: Upload coverage | |
runs-on: ubuntu-latest | |
needs: [encoders, fhir-server-1, fhir-server-2, fhir-server-3, python-api] | |
if: github.actor != 'dependabot[bot]' | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Download encoders coverage report | |
uses: actions/download-artifact@v3 | |
with: | |
name: encoders-coverage | |
path: encoders-coverage | |
- name: Download library API coverage report | |
uses: actions/download-artifact@v3 | |
with: | |
name: library-api-coverage | |
path: library-api-coverage | |
- name: Download Python API coverage report | |
uses: actions/download-artifact@v3 | |
with: | |
name: python-api-coverage | |
path: python-api-coverage | |
- name: Download FHIR server coverage report 1 | |
uses: actions/download-artifact@v3 | |
with: | |
name: fhir-server-1-coverage | |
path: fhir-server-1-coverage | |
- name: Download FHIR server coverage report 2 | |
uses: actions/download-artifact@v3 | |
with: | |
name: fhir-server-2-coverage | |
path: fhir-server-2-coverage | |
- name: Download FHIR server coverage report 3 | |
uses: actions/download-artifact@v3 | |
with: | |
name: fhir-server-3-coverage | |
path: fhir-server-3-coverage | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v2 | |
deploy-pre-release: | |
name: Pre-release deployment | |
needs: [encoders, fhir-server-1, fhir-server-2, fhir-server-3, docker-image] | |
runs-on: ubuntu-latest | |
# If the branch starts with "release/", we deploy pre-release packages. | |
if: startsWith(github.ref, 'refs/heads/release/') | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
# This is required so that git-commit-id-plugin can find the latest tag. | |
fetch-depth: 0 | |
- name: Set up JDK | |
uses: actions/setup-java@v2 | |
with: | |
java-version: 11 | |
distribution: "zulu" | |
- name: Cache local Maven repository | |
uses: actions/cache@v3 | |
with: | |
path: ~/.m2/repository | |
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | |
restore-keys: | | |
${{ runner.os }}-maven- | |
- name: Login to Docker Hub | |
uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Install GPG key | |
run: | | |
cat <(echo -e "${{ secrets.GPG_KEY }}") | gpg --batch --import | |
gpg --list-secret-keys --keyid-format LONG | |
- name: Configure Maven settings | |
uses: s4u/[email protected] | |
with: | |
servers: | | |
[{ | |
"id": "ossrh", | |
"username": "${{ secrets.OSSRH_USERNAME }}", | |
"password": "${{ secrets.OSSRH_PASSWORD }}" | |
}] | |
- name: Run the deploy goal with Maven | |
run: | | |
TAG=$(echo '${{ github.ref }}' | sed 's/refs\/heads\/release\///') | |
mvn --batch-mode deploy \ | |
-pl fhir-server,library-api,library-runtime -am \ | |
-PmavenPreRelease,dockerPreRelease,docs \ | |
-Dpathling.fhirServerDockerTag=$TAG \ | |
-DskipTests -DskipScalaDocs \ | |
-Dgpg.passphrase="${{ secrets.GPG_PASSPHRASE }}" | |
timeout-minutes: 30 |