From bd6d37ac2a3df555e0772000fca7c187f09d21bf Mon Sep 17 00:00:00 2001 From: Mahendra Paipuri <44365948+mahendrapaipuri@users.noreply.github.com> Date: Tue, 25 Jun 2024 19:03:17 +0200 Subject: [PATCH] Test deb packages in CI (#100) * Reorganize workflows to fail fast * General maintenance on workflows Signed-off-by: Mahendra Paipuri --- .github/workflows/ci.yml | 4 +-- .github/workflows/step_packaging.yml | 38 ++++++++++++++++++++++----- .github/workflows/step_tests-e2e.yml | 5 ---- .github/workflows/step_tests-unit.yml | 5 ---- 4 files changed, 33 insertions(+), 19 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index c3bb5973..96279f82 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -66,11 +66,11 @@ jobs: contents: write test-e2e: - needs: [test-lint] + needs: [test-lint, test-unit] uses: ./.github/workflows/step_tests-e2e.yml build: - needs: [test-lint, test-unit, test-e2e] + needs: [test-lint, test-unit] uses: ./.github/workflows/step_build.yml packaging: diff --git a/.github/workflows/step_packaging.yml b/.github/workflows/step_packaging.yml index a6f827d7..f4214fd6 100644 --- a/.github/workflows/step_packaging.yml +++ b/.github/workflows/step_packaging.yml @@ -25,14 +25,26 @@ jobs: with: name: build-go-artifacts + - name: Get version + id: vars + run: | + if [[ "${GITHUB_EVENT_NAME}" == "push" && "${GITHUB_REF_TYPE}" == "tag" ]]; then + REF_NAME=$(echo "${GITHUB_REF_NAME//\//-}") + CEEMS_VERSION=$(echo "${REF_NAME//v}") + echo "version=${CEEMS_VERSION}" >> $GITHUB_OUTPUT + else + echo "version=$(cat VERSION)" >> $GITHUB_OUTPUT + fi + echo "goos=linux" >> $GITHUB_OUTPUT + # Build RPM and DEB packages - name: Build deb and rpm packages run: | - # Replace any '/' with '-' for non tag workflows - export REF_NAME=$(echo "${GITHUB_REF_NAME//\//-}") - # Strip v from tag name, eg v0.1.0 -> 0.1.0 - export CEEMS_VERSION=$(echo "${REF_NAME//v}") - export GOOS=linux + # # Replace any '/' with '-' for non tag workflows + # export REF_NAME=$(echo "${GITHUB_REF_NAME//\//-}") + # # Strip v from tag name, eg v0.1.0 -> 0.1.0 + # export CEEMS_VERSION=$(echo "${REF_NAME//v}") + # export GOOS=linux # Ensure target directory exists mkdir -p .tarballs @@ -44,13 +56,25 @@ jobs: for arch in amd64 arm64; do for packager in rpm deb; do for app in ceems_exporter ceems_api_server ceems_lb; do - GOARCH=${arch} nfpm pkg --config build/package/${app}/nfpm.yml --packager ${packager} --target .tarballs/${app}-${CEEMS_VERSION}-${GOOS}-${arch}.${packager} + GOARCH=${arch} nfpm pkg --config build/package/${app}/nfpm.yml --packager ${packager} --target .tarballs/${app}-${{ steps.vars.outputs.version }}-${{ steps.vars.outputs.goos }}-${arch}.${packager} done done done + - name: Test deb packages + run: | + # Install all CEEMS components + for app in ceems_exporter ceems_api_server ceems_lb; do + GOARCH=amd64 sudo apt-get install ./.tarballs/${app}-${{ steps.vars.outputs.version }}-${{ steps.vars.outputs.goos }}-amd64.deb + done + + # Test systemd service of each CEEMS component + for app in ceems_exporter ceems_api_server ceems_lb; do + systemctl is-active --quiet "${app}.service" && echo "${app}" is running + done + - name: Upload release artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: release-artifacts path: .tarballs diff --git a/.github/workflows/step_tests-e2e.yml b/.github/workflows/step_tests-e2e.yml index 57b2e72b..f0894b80 100644 --- a/.github/workflows/step_tests-e2e.yml +++ b/.github/workflows/step_tests-e2e.yml @@ -17,11 +17,6 @@ jobs: with: go-version: 1.21.x - - name: Install promu - run: | - make promu - go mod download - - name: Run e2e tests for Go packages run: make test-e2e diff --git a/.github/workflows/step_tests-unit.yml b/.github/workflows/step_tests-unit.yml index ba1f83ad..26f05217 100644 --- a/.github/workflows/step_tests-unit.yml +++ b/.github/workflows/step_tests-unit.yml @@ -17,11 +17,6 @@ jobs: with: go-version: 1.21.x - - name: Install promu - run: | - make promu - go mod download - - name: Run checkmetrics and checkrules run: make checkmetrics checkrules