Change 4.13 QE nightly to 4.15 (#1976) #6509
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
name: Test Incoming Changes | |
on: | |
push: | |
branches: [ main ] | |
pull_request: | |
branches: [ main ] | |
workflow_dispatch: | |
env: | |
REGISTRY: quay.io | |
REGISTRY_LOCAL: localhost | |
TNF_IMAGE_NAME: testnetworkfunction/cnf-certification-test | |
TNF_IMAGE_TAG: unstable | |
OCT_IMAGE_NAME: testnetworkfunction/oct | |
OCT_IMAGE_TAG: latest | |
TNF_CONTAINER_CLIENT: docker | |
TNF_NON_INTRUSIVE_ONLY: false | |
TNF_ALLOW_PREFLIGHT_INSECURE: false | |
TNF_DISABLE_CONFIG_AUTODISCOVER: false | |
TNF_CONFIG_DIR: /tmp/tnf/config | |
TNF_OUTPUT_DIR: /tmp/tnf/output | |
TNF_SRC_URL: 'https://github.com/${{ github.repository }}' | |
TESTING_CMD_PARAMS: '-n host -i ${REGISTRY_LOCAL}/${TNF_IMAGE_NAME}:${TNF_IMAGE_TAG} -t ${TNF_CONFIG_DIR} -o ${TNF_OUTPUT_DIR}' | |
TNF_SMOKE_TESTS_LOG_LEVEL: debug | |
ON_DEMAND_DEBUG_PODS: false | |
TERM: xterm-color | |
CM_BIN: /usr/local/bin/checkmake | |
CM_URL_LINUX: https://github.com/mrtazz/checkmake/releases/download/0.2.2/checkmake-0.2.2.linux.amd64 # yamllint disable-line | |
SMOKE_TESTS_LABELS_FILTER: all | |
SKIP_PRELOAD_IMAGES: true | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.event.number || github.ref }} | |
cancel-in-progress: true | |
jobs: | |
lint: | |
name: Run Linters and Vet | |
runs-on: ubuntu-latest | |
env: | |
SHELL: /bin/bash | |
steps: | |
- name: Set up Go 1.22 | |
uses: actions/setup-go@v5 | |
with: | |
go-version: 1.22.2 | |
- name: Disable default go problem matcher | |
run: echo "::remove-matcher owner=go::" | |
- name: Check out code into the Go module directory | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Install yaml dependency | |
run: pip3 install pyyaml | |
env: | |
SHELL: /bin/bash | |
- name: Extract dependent Pull Requests | |
uses: depends-on/depends-on-action@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Install checkmake | |
run: | | |
curl --location --output $CM_BIN --silent $CM_URL_LINUX | |
chmod +x $CM_BIN | |
- name: Install Shfmt | |
uses: mfinelli/setup-shfmt@v3 | |
- name: Golangci-lint | |
uses: golangci/golangci-lint-action@v4 | |
with: | |
version: v1.56 | |
args: --timeout 10m0s | |
- name: Checkmake | |
run: checkmake --config=.checkmake Makefile | |
- name: Hadolint | |
uses: hadolint/[email protected] | |
with: | |
dockerfile: Dockerfile | |
recursive: true | |
- name: Shfmt | |
run: shfmt -d *.sh script | |
- name: Markdownlint | |
uses: nosborn/[email protected] | |
with: | |
files: . | |
- name: ShellCheck | |
uses: ludeeus/action-shellcheck@master | |
# - name: Typos | |
# uses: crate-ci/typos@master | |
- name: Yamllint | |
uses: ibiqlik/action-yamllint@v3 | |
with: | |
config_file: .yamllint.yml | |
- name: Go vet | |
run: make vet | |
unit-tests: | |
name: Run Unit Tests | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-22.04, macos-latest] | |
env: | |
SHELL: /bin/bash | |
steps: | |
- name: Set up Go 1.22 | |
uses: actions/setup-go@v5 | |
with: | |
go-version: 1.22.2 | |
- name: Disable default go problem matcher | |
run: echo "::remove-matcher owner=go::" | |
- name: Check out code into the Go module directory | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Install yaml dependency | |
run: pip3 install pyyaml | |
env: | |
SHELL: /bin/bash | |
- name: Extract dependent Pull Requests | |
uses: depends-on/depends-on-action@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Run Tests | |
run: make test | |
env: | |
SHELL: /bin/bash | |
- name: Quality Gate - Test coverage shall be above threshold | |
env: | |
TESTCOVERAGE_THRESHOLD: 15 | |
run: | | |
echo "Quality Gate: checking test coverage is above threshold ..." | |
echo "Threshold : $TESTCOVERAGE_THRESHOLD %" | |
totalCoverage=`UNIT_TEST='true' cat cover.out.tmp | grep -v "_moq.go" > cover.out; go tool cover -func=cover.out | grep total | grep -Eo '[0-9]+\.[0-9]+'` | |
echo "Current test coverage : $totalCoverage %" | |
if (( $(echo "$totalCoverage $TESTCOVERAGE_THRESHOLD" | awk '{print ($1 > $2)}') )); then | |
echo OK | |
else | |
echo "Current test coverage is below threshold. Please add more unit tests or adjust threshold to a lower value." | |
echo "Failed" | |
exit 1 | |
fi | |
smoke-tests-local: | |
name: Run Local Smoke Tests | |
runs-on: ubuntu-22.04 | |
env: | |
SHELL: /bin/bash | |
KUBECONFIG: '/home/runner/.kube/config' | |
PFLT_DOCKERCONFIG: '/home/runner/.docker/config' | |
steps: | |
- name: Write temporary docker file | |
run: | | |
mkdir -p /home/runner/.docker | |
touch ${PFLT_DOCKERCONFIG} | |
echo '{ "auths": {} }' >> ${PFLT_DOCKERCONFIG} | |
- name: Set up Go 1.22 | |
uses: actions/setup-go@v5 | |
with: | |
go-version: 1.22.2 | |
- name: Disable default go problem matcher | |
run: echo "::remove-matcher owner=go::" | |
- name: Check out code into the Go module directory | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Install yaml dependency | |
run: pip3 install pyyaml | |
env: | |
SHELL: /bin/bash | |
- name: Extract dependent Pull Requests | |
uses: depends-on/depends-on-action@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
# Update the CNF containers, helm charts and operators DB. | |
- name: Update the CNF DB | |
run: | | |
mkdir -p "${GITHUB_WORKSPACE}"/offline-db | |
docker run \ | |
--env OCT_DUMP_ONLY=true \ | |
--rm \ | |
--volume "${GITHUB_WORKSPACE}"/offline-db:/tmp/dump:Z \ | |
${REGISTRY}/${OCT_IMAGE_NAME}:${OCT_IMAGE_TAG} | |
docker system prune --volumes -f | |
- name: Build CNF test suite binary | |
run: make build-cnf-tests | |
- name: Remove go mod cache to save disk space. | |
run: | | |
df -h | |
go clean -modcache || true | |
df -h | |
# Create a Kind cluster for testing. | |
- name: Check out `cnf-certification-test-partner` | |
uses: actions/checkout@v4 | |
with: | |
repository: test-network-function/cnf-certification-test-partner | |
path: cnf-certification-test-partner | |
- name: Bootstrap cluster, docker, and python | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make bootstrap-cluster && make bootstrap-docker-ubuntu-local && make bootstrap-python-ubuntu-local && pip3 install pyyaml | |
# Restart docker using /mnt/docker-storage (sdb) instead of /var/lib/docker (sda). | |
# This step needs to be done right after the partner repo's bootstrap scripts, as they | |
# overwrite the docker's daemon.json. | |
- name: Make docker to use /mnt (sdb) for storage | |
run: | | |
df -h | |
lsblk | |
sudo mkdir /mnt/docker-storage | |
sudo jq '. +={"data-root" : "/mnt/docker-storage"}' < /etc/docker/daemon.json > /tmp/docker-daemon.json | |
sudo cp /tmp/docker-daemon.json /etc/docker/daemon.json | |
cat /etc/docker/daemon.json | |
sudo systemctl restart docker | |
sudo ls -la /mnt/docker-storage | |
- name: Run 'make rebuild-cluster' | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make rebuild-cluster | |
- name: Run 'make install' | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make install | |
# Perform smoke tests. | |
- name: 'Test: Run test suites' | |
run: TNF_LOG_LEVEL=${TNF_SMOKE_TESTS_LOG_LEVEL} ./run-cnf-suites.sh -l "${SMOKE_TESTS_LABELS_FILTER}" | |
- name: Upload smoke test results as an artifact | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: smoke-tests | |
path: | | |
cnf-certification-test/*.tar.gz | |
- name: Remove tarball(s) to save disk space. | |
run: rm -f cnf-certification-test/*.tar.gz | |
- name: Build the TNF tool | |
run: make build-tnf-tool | |
- name: Check the smoke test results against the expected results template | |
run: make check-results | |
- name: 'Test: Run preflight specific test suite' | |
run: TNF_LOG_LEVEL=${TNF_SMOKE_TESTS_LOG_LEVEL} ./run-cnf-suites.sh -l "preflight" | |
- name: Upload preflight smoke test results as an artifact | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: preflight-smoke-tests | |
path: | | |
cnf-certification-test/*.tar.gz | |
- name: Remove tarball(s) to save disk space | |
run: rm -f cnf-certification-test/*.tar.gz | |
smoke-tests-container: | |
name: Run Container Smoke Tests | |
runs-on: ubuntu-22.04 | |
env: | |
SHELL: /bin/bash | |
KUBECONFIG: '/home/runner/.kube/config' | |
PFLT_DOCKERCONFIG: '/home/runner/.docker/config' | |
steps: | |
- name: Write temporary docker file | |
run: | | |
mkdir -p /home/runner/.docker | |
touch ${PFLT_DOCKERCONFIG} | |
echo '{ "auths": {} }' >> ${PFLT_DOCKERCONFIG} | |
# Create a Kind cluster for testing. | |
- name: Check out `cnf-certification-test-partner` | |
uses: actions/checkout@v4 | |
with: | |
repository: test-network-function/cnf-certification-test-partner | |
path: cnf-certification-test-partner | |
- name: Bootstrap cluster, docker, and python | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make bootstrap-cluster && make bootstrap-docker-ubuntu-local && make bootstrap-python-ubuntu-local && pip3 install pyyaml | |
# Restart docker using /mnt/docker-storage (sdb) instead of /var/lib/docker (sda). | |
# This step needs to be done right after the partner repo's bootstrap scripts, as they | |
# overwrite the docker's daemon.json. | |
- name: Make docker to use /mnt (sdb) for storage | |
run: | | |
df -h | |
lsblk | |
sudo mkdir /mnt/docker-storage | |
sudo jq '. +={"data-root" : "/mnt/docker-storage"}' < /etc/docker/daemon.json > /tmp/docker-daemon.json | |
sudo cp /tmp/docker-daemon.json /etc/docker/daemon.json | |
cat /etc/docker/daemon.json | |
sudo systemctl restart docker | |
sudo ls -la /mnt/docker-storage | |
- name: Run 'make rebuild-cluster' | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make rebuild-cluster | |
- name: Run 'make install' | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: cd ${GITHUB_WORKSPACE}/cnf-certification-test-partner && make install | |
# needed by depends-on-action | |
- name: Set up Go 1.22 | |
uses: actions/setup-go@v5 | |
with: | |
go-version: 1.22.2 | |
# Perform smoke tests using a TNF container. | |
- name: Check out code into the Go module directory | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Extract dependent Pull Requests | |
uses: depends-on/depends-on-action@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build the `cnf-certification-test` image | |
uses: nick-fields/retry@v3 | |
with: | |
timeout_minutes: 90 | |
max_attempts: 3 | |
command: make build-image-local | |
env: | |
IMAGE_TAG: ${TNF_IMAGE_TAG} | |
# Prepare collector to be used when running smoke tests | |
- name: Check out `Collector` | |
uses: actions/checkout@v4 | |
with: | |
repository: test-network-function/collector | |
path: collector | |
# Clean up unused container image layers. We need to filter out a possible error return code | |
# from docker with "|| true" as some images might still be used by running kind containers and | |
# won't be removed. | |
- name: Remove unnamed/dangling container images to save space. Show disk space before and after removing them. | |
run: | | |
df -h | |
docker rmi $(docker images -f "dangling=true" -q) || true | |
df -h | |
- name: Create required TNF config files and directories | |
run: | | |
mkdir -p $TNF_CONFIG_DIR $TNF_OUTPUT_DIR | |
cp cnf-certification-test/*.yml $TNF_CONFIG_DIR | |
shell: bash | |
- name: Get Collector's CI credentials | |
run: | | |
echo "collector_ciuser=ciuser_${{ github.run_id }}" >> $GITHUB_OUTPUT | |
echo "collector_cipassword=cipassword" >> $GITHUB_OUTPUT | |
id: set_collector_ci_creds | |
- name: Update Collector's CI credentials and Print username | |
run: | | |
echo Collector CI username: ${{ steps.set_collector_ci_creds.outputs.collector_ciuser }} | |
echo "COLLECTOR_CIUSER=${{ steps.set_collector_ci_creds.outputs.collector_ciuser }}" >> $GITHUB_ENV | |
echo "COLLECTOR_CIPASSWORD=${{ steps.set_collector_ci_creds.outputs.collector_cipassword }}" >> $GITHUB_ENV | |
- name: Ensure COLLECTOR_CIUSER and COLLECTOR_CIPASSWORD are set | |
run: '[[ -n "$COLLECTOR_CIUSER" ]] && [[ -n "$COLLECTOR_CIPASSWORD" ]]' | |
- name: Modify TNF config with CI collector credentials | |
run: | | |
sed -i\ | |
-e '/executedBy/s/""/"CI"/g' \ | |
-e '/partnerName/s/""/"${{ env.COLLECTOR_CIUSER }}"/g' \ | |
-e '/collectorAppPassword/s/""/"${{ env.COLLECTOR_CIPASSWORD }}"/g' \ | |
$TNF_CONFIG_DIR/tnf_config.yml | |
- name: 'Test: Run without any TS, just get diagnostic information' | |
run: TNF_LOG_LEVEL=${TNF_SMOKE_TESTS_LOG_LEVEL} ./run-tnf-container.sh ${{ env.TESTING_CMD_PARAMS }} | |
- name: 'Test: Run Smoke Tests in a TNF container' | |
run: TNF_LOG_LEVEL=${TNF_SMOKE_TESTS_LOG_LEVEL} TNF_ENABLE_DATA_COLLECTION=true ./run-tnf-container.sh ${{ env.TESTING_CMD_PARAMS }} -l "${SMOKE_TESTS_LABELS_FILTER}" | |
- name: Run sanity check on collector | |
uses: ./collector/.github/actions/run-sanity-check | |
with: | |
working_directory: collector | |
collector_username: ${COLLECTOR_CIUSER} | |
collector_password: ${COLLECTOR_CIPASSWORD} | |
- name: Upload container test results as an artifact | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: smoke-tests-container | |
path: | | |
${{ env.TNF_OUTPUT_DIR }}/*.tar.gz | |
- name: Remove tarball(s) to save disk space. | |
run: rm -f ${{ env.TNF_OUTPUT_DIR }}/*.tar.gz | |
- name: Build the TNF tool | |
run: make build-tnf-tool | |
- name: Check the smoke test results against the expected results template | |
run: ./tnf check results --log-file="${TNF_OUTPUT_DIR}"/cnf-certsuite.log | |
- name: 'Test: Run Preflight Specific Smoke Tests in a TNF container' | |
run: TNF_LOG_LEVEL=${TNF_SMOKE_TESTS_LOG_LEVEL} ./run-tnf-container.sh ${{ env.TESTING_CMD_PARAMS }} -l "preflight" | |
# Only run this job if the previous jobs are successful that build the ARM and x86 images. | |
create-manifest-multiarch: | |
name: Create manifest list for multi-arch image | |
needs: [unit-tests, smoke-tests-container] | |
runs-on: ubuntu-22.04 | |
if: github.event_name != 'pull_request' && needs.smoke-tests-container.result == 'success' && needs.unit-tests.result == 'success' | |
steps: | |
- name: Check out code | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Login to Quay.io | |
uses: docker/login-action@v3 | |
if: ${{ github.ref == 'refs/heads/main' && github.repository_owner == 'test-network-function' }} | |
with: | |
registry: ${{ env.REGISTRY }} | |
username: ${{ secrets.QUAY_ROBOT_USERNAME }} | |
password: ${{ secrets.QUAY_ROBOT_TOKEN }} | |
- name: Build and push the unstable images for multi-arch | |
uses: docker/build-push-action@v5 | |
if: ${{ github.ref == 'refs/heads/main' && github.repository_owner == 'test-network-function' }} | |
with: | |
context: . | |
file: Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: | | |
${{ env.REGISTRY }}/${{ env.TNF_IMAGE_NAME }}:${{ env.TNF_IMAGE_TAG }} | |
- name: (if on main and upstream) Send chat msg to dev team if failed to create container image. | |
if: ${{ failure() && github.ref == 'refs/heads/main' && github.repository_owner == 'test-network-function' }} | |
uses: ./.github/actions/slack-webhook-sender | |
with: | |
message: 'Failed to create the *unstable* container manifest' | |
slack_webhook: '${{ secrets.SLACK_ALERT_WEBHOOK_URL }}' | |
check-all-dependencies-are-merged: | |
name: Check all the PR dependencies are merged | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Check all dependent Pull Requests are merged | |
uses: depends-on/depends-on-action@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
check-unmerged-pr: true |