From c9266b045c75fd5443c68dbc9f32c7218e24df9f Mon Sep 17 00:00:00 2001 From: Benjamin Benoist Date: Tue, 18 Jul 2023 09:55:51 +0200 Subject: [PATCH] Github Actions: split testing and releasing (close #806) --- .github/workflows/{ci.yml => release.yml} | 72 +--------------------- .github/workflows/test.yml | 73 +++++++++++++++++++++++ 2 files changed, 74 insertions(+), 71 deletions(-) rename .github/workflows/{ci.yml => release.yml} (76%) create mode 100644 .github/workflows/test.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/release.yml similarity index 76% rename from .github/workflows/ci.yml rename to .github/workflows/release.yml index 8cc48669a..c888b4d29 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/release.yml @@ -1,82 +1,14 @@ -name: CI +name: release on: push: tags: - '*' branches: - - master - - develop - 'snapshot/**' - pull_request: jobs: - test: - runs-on: ubuntu-latest - - services: - postgres: - image: postgres - ports: - - 5432:5432 - env: - POSTGRES_USER: enricher - POSTGRES_PASSWORD: supersecret1 - POSTGRES_DB: sql_enrichment_test - POSTGRES_PORT: 5432 - options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 - - steps: - - uses: actions/checkout@v2 - - uses: coursier/cache-action@v6 - - name: Set up JDK 11 - uses: actions/setup-java@v1 - with: - java-version: 11 - - name: Start HTTP server to test API enrichment in Common Enrich - run: python integration-tests/common/api-enrichment-test.py 8001 & - - name: Start HTTP server to test API enrichment in Common Fs2 - run: python integration-tests/common-fs2/api-enrichment-test.py 8000 & - - name: Prepare data in Postgres to test SQL enrichment in Common Enrich - run: psql -h localhost -p 5432 -U enricher -d sql_enrichment_test < integration-tests/common/sql-enrichment-test.sql - env: - PGPASSWORD: supersecret1 - - name: Prepare data in Postgres to test SQL enrichment in Common Fs2 - run: psql -h localhost -p 5432 -U enricher -d sql_enrichment_test < integration-tests/common-fs2/sql-enrichment-test.sql - env: - PGPASSWORD: supersecret1 - - name: Run tests - run: SBT_OPTS="-Xms1G -Xmx8G -Xss4M -XX:MaxMetaspaceSize=1024M" sbt coverage +test - env: - OER_KEY: ${{ secrets.OER_KEY }} - - name: Check Scala formatting - run: sbt scalafmtCheckAll - - name: Check assets can be published - run: sbt publishLocal - - name: Run integration tests for enrich-kinesis - run: sbt "project kinesisDistroless" IntegrationTest/test - env: - AWS_ACCESS_KEY_ID: foo - AWS_SECRET_ACCESS_KEY: bar - - name: Run integration tests for enrich-kafka - run: | - sbt "project kafka" "docker:publishLocal" - docker-compose -f integration-tests/enrich-kafka/docker-compose.yml up -d - sbt "project kafka" IntegrationTest/test - docker-compose -f integration-tests/enrich-kafka/docker-compose.yml down - - name: Run integration tests for enrich-nsq - run: sbt "project nsqDistroless" IntegrationTest/test - - name: Generate coverage report - run: sbt coverageReport - - name: Aggregate coverage data - run: sbt coverageAggregate - - name: Submit coveralls data - run: sbt coveralls - env: - COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }} - github_release: - needs: test if: startsWith(github.ref, 'refs/tags/') runs-on: ubuntu-latest steps: @@ -119,7 +51,6 @@ jobs: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} publish_docker: - needs: test if: startsWith(github.ref, 'refs/tags/') || startsWith(github.ref, 'refs/heads/snapshot') runs-on: ubuntu-latest strategy: @@ -247,7 +178,6 @@ jobs: SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} publish_sce: - needs: test if: startsWith(github.ref, 'refs/tags/') runs-on: ubuntu-latest steps: diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 000000000..43e503e63 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,73 @@ +name: test + +on: + push: + branches: + - '**' + tags-ignore: + - '**' + +jobs: + test: + runs-on: ubuntu-latest + + services: + postgres: + image: postgres + ports: + - 5432:5432 + env: + POSTGRES_USER: enricher + POSTGRES_PASSWORD: supersecret1 + POSTGRES_DB: sql_enrichment_test + POSTGRES_PORT: 5432 + options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 + + steps: + - uses: actions/checkout@v2 + - uses: coursier/cache-action@v6 + - name: Set up JDK 11 + uses: actions/setup-java@v1 + with: + java-version: 11 + - name: Start HTTP server to test API enrichment in Common Enrich + run: python integration-tests/common/api-enrichment-test.py 8001 & + - name: Start HTTP server to test API enrichment in Common Fs2 + run: python integration-tests/common-fs2/api-enrichment-test.py 8000 & + - name: Prepare data in Postgres to test SQL enrichment in Common Enrich + run: psql -h localhost -p 5432 -U enricher -d sql_enrichment_test < integration-tests/common/sql-enrichment-test.sql + env: + PGPASSWORD: supersecret1 + - name: Prepare data in Postgres to test SQL enrichment in Common Fs2 + run: psql -h localhost -p 5432 -U enricher -d sql_enrichment_test < integration-tests/common-fs2/sql-enrichment-test.sql + env: + PGPASSWORD: supersecret1 + - name: Run tests + run: SBT_OPTS="-Xms1G -Xmx8G -Xss4M -XX:MaxMetaspaceSize=1024M" sbt coverage +test + env: + OER_KEY: ${{ secrets.OER_KEY }} + - name: Check Scala formatting + run: sbt scalafmtCheckAll + - name: Check assets can be published + run: sbt publishLocal + - name: Run integration tests for enrich-kinesis + run: sbt "project kinesisDistroless" IntegrationTest/test + env: + AWS_ACCESS_KEY_ID: foo + AWS_SECRET_ACCESS_KEY: bar + - name: Run integration tests for enrich-kafka + run: | + sbt "project kafka" "docker:publishLocal" + docker-compose -f integration-tests/enrich-kafka/docker-compose.yml up -d + sbt "project kafka" IntegrationTest/test + docker-compose -f integration-tests/enrich-kafka/docker-compose.yml down + - name: Run integration tests for enrich-nsq + run: sbt "project nsqDistroless" IntegrationTest/test + - name: Generate coverage report + run: sbt coverageReport + - name: Aggregate coverage data + run: sbt coverageAggregate + - name: Submit coveralls data + run: sbt coveralls + env: + COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }} \ No newline at end of file