From 3994a75ba05131127179046cf4d3b9682e1e7ba3 Mon Sep 17 00:00:00 2001 From: Coiby Xu Date: Fri, 15 Apr 2022 18:15:17 +0800 Subject: [PATCH] tests: enable Github action With this patch, four kinds of tests are triggered when there is a pull request created in a Github kexec-tools repo, - format check using shfmt - static analysis using shellcheck - ShellSpec unit tests (test cases in spec/) - integration tests (tests cases in tests/) Signed-off-by: Coiby Xu --- .github/workflows/main.yml | 52 ++++++++++++++++++++++++++++++++++ tools/run-integration-tests.sh | 33 +++++++++++++++++++++ 2 files changed, 85 insertions(+) create mode 100644 .github/workflows/main.yml create mode 100755 tools/run-integration-tests.sh diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 00000000..2b266aaa --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,52 @@ +name: kdump-utils tests + +on: pull_request + +jobs: + format-check: + runs-on: ubuntu-latest + container: docker.io/fedora:latest + steps: + - uses: actions/checkout@v4 + - run: dnf install shfmt -y + - run: shfmt -d *.sh kdumpctl mk*dumprd + + static-analysis: + runs-on: ubuntu-latest + container: docker.io/fedora:latest + steps: + - uses: actions/checkout@v4 + - run: dnf install shellcheck -y + # Currently, for kdump-utils, there is need for shellcheck to require + # the sourced file to give correct warnings about the checked file + - run: shellcheck --exclude=1090,1091 *.sh spec/*.sh kdumpctl mk*dumprd + + unit-tests: + runs-on: ubuntu-latest + container: docker.io/fedora:latest + steps: + - uses: actions/checkout@v4 + - run: sudo dnf install -y make dracut grubby hostname + - run: curl -L -O https://github.com/shellspec/shellspec/archive/latest.tar.gz && tar -xzf latest.tar.gz + - run: cd shellspec-latest && sudo make install + - run: shellspec + + integration-tests: + runs-on: self-hosted + timeout-minutes: 45 + concurrency: + group: ${{ github.workflow }}-${{ github.ref }}-${{ matrix.fedora_version }}-${{ matrix.test }} + cancel-in-progress: true + strategy: + matrix: + fedora_version: [ + "40", + ] + fail-fast: false + steps: + - name: "Checkout Repository" + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: "${{ matrix.fedora_version }} kdump tests" + run: tools/run-integration-tests.sh ${{ matrix.fedora_version }} diff --git a/tools/run-integration-tests.sh b/tools/run-integration-tests.sh new file mode 100755 index 00000000..32a4103f --- /dev/null +++ b/tools/run-integration-tests.sh @@ -0,0 +1,33 @@ +#!/bin/bash + +set -ex + +[[ -d ${0%/*} ]] && cd "${0%/*}"/../ + +fedora_version=40 +if [[ -n $1 ]]; then + fedora_version=$1 +fi + +dist_abbr=.fc$fedora_version + +VERSION=$(rpmspec -q --queryformat "%{VERSION}" kdump-utils.spec) +SRC_ARCHIVE=kdump-utils-$VERSION.tar.gz +if ! git archive --format=tar.gz -o "$SRC_ARCHIVE" --prefix=kdump-utils-$VERSION/ HEAD; then + echo "Failed to create kdump-utils source archive" + exit 1 +fi + +if ! rpmbuild -ba -D "dist $dist_abbr" -D "_sourcedir $(pwd)" -D "_builddir $(pwd)" -D "_srcrpmdir $(pwd)" -D "_rpmdir $(pwd)" kdump-utils.spec; then + echo "Failed to build kdump-utils rpm" + exit 1 +fi + +arch=$(uname -m) +rpm_name=$(rpmspec -D "dist $dist_abbr" -q --queryformat '%{NAME}-%{VERSION}-%{RELEASE}.%{ARCH}' kdump-utils.spec) +rpm_path="$(pwd)/${arch}/${rpm_name}.rpm" +if [[ ! -f $rpm_path ]]; then + echo "Failed to find built kdump-utils rpm ($path doesn't eixst)" +fi + +cd tests && tmt run --environment CUSTOM_MIRROR=https://mirrors.tuna.tsinghua.edu.cn/fedora --environment KDUMP_UTILS_RPM="$rpm_path" -a provision -h virtual -i fedora:$fedora_version