From 94a04a39b5f1b8449a41b8e8edc6bce1e4773b6e Mon Sep 17 00:00:00 2001 From: Scott Dickerson Date: Mon, 18 Mar 2024 11:58:17 -0400 Subject: [PATCH] :seedling: Refactor CI github actions, Dockerfile (#1780) Refactoring: - Split CI, one for repo tests and one for global tests - Only enable global CI on main (with a note) - Global CI configured like the multiarch build to cancel in progress runs if a new run starts - Repo CI bump the version of action `codecov/codecov-action` based on runtime warnings - Add `--ignoreScripts` to the `npm clean-install` in the Dockerfile to avoid running unnecessary postinstall scripts with the build running directly after the install. Signed-off-by: Scott J Dickerson --- .github/workflows/ci-actions.yml | 78 -------------------------------- .github/workflows/ci-global.yml | 54 ++++++++++++++++++++++ .github/workflows/ci-repo.yml | 55 ++++++++++++++++++++++ Dockerfile | 2 +- 4 files changed, 110 insertions(+), 79 deletions(-) delete mode 100644 .github/workflows/ci-actions.yml create mode 100644 .github/workflows/ci-global.yml create mode 100644 .github/workflows/ci-repo.yml diff --git a/.github/workflows/ci-actions.yml b/.github/workflows/ci-actions.yml deleted file mode 100644 index eeed592731..0000000000 --- a/.github/workflows/ci-actions.yml +++ /dev/null @@ -1,78 +0,0 @@ -name: CI - -on: - push: - branches: - - main - - "release-*" - pull_request: - branches: - - main - - "release-*" - -jobs: - unit-test: - runs-on: ubuntu-latest - strategy: - matrix: - # Note: This should match the node version(s) used in the base Dockerfile - node-version: [18.x] - - steps: - - uses: actions/checkout@v4 - - - name: Use Node.js ${{ matrix.node-version }} - uses: actions/setup-node@v4 - with: - node-version: ${{ matrix.node-version }} - - - name: Verify package-lock.json - run: ./scripts/verify_lock.mjs - - - name: Install - run: npm clean-install --ignore-scripts - - - name: Lint sources - run: npm run lint - - - name: Build - run: npm run build - - - name: Test - run: npm run test -- --coverage --watchAll=false - - - name: Upload to codecov (client) - uses: codecov/codecov-action@v3 - with: - flags: client - directory: ./*/coverage - - - name: Upload to codecov (server) - uses: codecov/codecov-action@v3 - with: - flags: server - directory: ./*/coverage - - build-and-upload-for-global-ci: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - - name: save tackle2-ui image - run: | - docker build . -t quay.io/konveyor/tackle2-ui:latest - docker save -o /tmp/tackle2-ui.tar quay.io/konveyor/tackle2-ui:latest - - - name: Upload tackle2-ui image as artifact - uses: actions/upload-artifact@v3 - with: - name: tackle2-ui - path: /tmp/tackle2-ui.tar - retention-days: 1 - - test-integration: - needs: build-and-upload-for-global-ci - uses: konveyor/ci/.github/workflows/global-ci.yml@main - with: - component_name: tackle2-ui - run_api_tests: false diff --git a/.github/workflows/ci-global.yml b/.github/workflows/ci-global.yml new file mode 100644 index 0000000000..508f1a5f89 --- /dev/null +++ b/.github/workflows/ci-global.yml @@ -0,0 +1,54 @@ +name: CI (global konveyor CI) + +on: + push: + branches: + - "main" + pull_request: + branches: + - "main" + +### +# The global CI settings need to be adjusted for the `release-*`` branches such that: +# 1. The operator uses the correct `:release-*` images +# 2. The `*-tests_ref` use the correct branches +# +# on: +# push: +# branches: +# - 'main' +# - 'release-*' +# pull_request: +# branches: +# - 'main' +# - 'release-*' +## + +concurrency: + group: ci-global-${{ github.ref }} + cancel-in-progress: true + +jobs: + build-and-upload-for-global-ci: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: save tackle2-ui image + run: | + docker build . -t quay.io/konveyor/tackle2-ui:latest + docker save -o /tmp/tackle2-ui.tar quay.io/konveyor/tackle2-ui:latest + + - name: Upload tackle2-ui image as artifact + uses: actions/upload-artifact@v3 + with: + name: tackle2-ui + path: /tmp/tackle2-ui.tar + retention-days: 1 + + run-global-ci: + needs: build-and-upload-for-global-ci + uses: konveyor/ci/.github/workflows/global-ci.yml@main + with: + component_name: tackle2-ui + run_api_tests: false diff --git a/.github/workflows/ci-repo.yml b/.github/workflows/ci-repo.yml new file mode 100644 index 0000000000..e06d93da75 --- /dev/null +++ b/.github/workflows/ci-repo.yml @@ -0,0 +1,55 @@ +name: CI (repo level) + +on: + push: + branches: + - "main" + - "release-*" + pull_request: + branches: + - "main" + - "release-*" + +env: + # Note: This should match the node version(s) used in the base Dockerfile + node-version: "18" + +jobs: + unit-test: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - name: Use Node.js (version "${{ env.node-version }}") + uses: actions/setup-node@v4 + with: + node-version: ${{ env.node-version }} + cache: "npm" + + - name: Verify package-lock.json + run: ./scripts/verify_lock.mjs + + - name: Install + run: npm clean-install --ignore-scripts + + - name: Lint sources + run: npm run lint + + - name: Build + run: npm run build + + - name: Test + run: npm run test -- --coverage --watchAll=false + + - name: Upload to codecov (client) + uses: codecov/codecov-action@v4 + with: + flags: client + directory: ./*/coverage + + - name: Upload to codecov (server) + uses: codecov/codecov-action@v4 + with: + flags: server + directory: ./*/coverage diff --git a/Dockerfile b/Dockerfile index 9cc6be7c9a..17edb1680c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,7 +3,7 @@ FROM registry.access.redhat.com/ubi9/nodejs-18:latest as builder USER 1001 COPY --chown=1001 . . -RUN npm clean-install && npm run build && npm run dist +RUN npm clean-install --ignore-scripts && npm run build && npm run dist # Runner image FROM registry.access.redhat.com/ubi9/nodejs-18-minimal:latest