Skip to content

Build

Build #175

Workflow file for this run

# SPDX-FileCopyrightText: © Vegard IT GmbH (https://vegardit.com) and contributors
# SPDX-FileContributor: Sebastian Thomschke, Vegard IT GmbH
# SPDX-License-Identifier: Apache-2.0
#
# https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions
name: Build
on:
push:
branches: # build all branches
- '**'
tags-ignore: # don't build tags
- '**'
paths-ignore:
- '**/*.md'
- '.editorconfig'
- '.git*'
- '.github/*.yml'
- '.semaphore/**/*'
pull_request:
paths-ignore:
- '**/*.md'
- '.editorconfig'
- '.git*'
- '.github/*.yml'
- '.semaphore/**/*'
workflow_dispatch:
# https://github.blog/changelog/2020-07-06-github-actions-manual-triggers-with-workflow_dispatch/
inputs:
debug-with-ssh:
description: "Start an SSH session for debugging purposes after tests ran:"
default: never
type: choice
options: [ always, on_failure, on_failure_or_cancelled, never ]
debug-with-ssh-only-for-actor:
description: "Limit access to the SSH session to the GitHub user that triggered the job."
default: true
type: boolean
debug-with-ssh-only-jobs-matching:
description: "Only start an SSH session for jobs matching this regex pattern:"
default: ".*"
type: string
defaults:
run:
shell: bash
jobs:
test:
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os:
- ubuntu-latest
- ubuntu-22.04
- ubuntu-20.04
- windows-latest
steps:
- name: Git Checkout
uses: actions/checkout@v4 #https://github.com/actions/checkout
- name: "Linux: Configure APT"
uses: ./
with:
repo-name: ${{ github.repository }}
repo-branch: ${{ github.ref_name }}
- name: Run shellcheck
run: bash tests/run-shellcheck.sh
- name: Install bashcov
if: ${{ runner.os == 'Linux' && !env.ACT }}
run: |
ruby --version
echo "gem $(gem --version)"
if [[ "${{ matrix.os}}" == "ubuntu-20.04" ]]; then
# workaround for bashcov error:
# The last version of bashcov (>= 0) to support your Ruby & RubyGems was 1.8.2.
# Try installing it with `gem install bashcov -v 1.8.2`"
sudo gem install bashcov -v 1.8.2
else
sudo gem install bashcov
fi
sudo gem install simplecov-console
- name: Run tests
timeout-minutes: 5
run: |
set -eu
if [[ "${{ runner.os }}" == "Linux" && "${{ env.ACT }}" != "true" ]]; then
bashcov --skip-uncovered tests/run-tests.sh
else
bash tests/run-tests.sh
fi
- name: "SSH session for debugging: check"
id: debug_ssh_sesssion_check
if: always()
run: |
set -eu
job_filter_pattern="${{ inputs.debug-with-ssh-only-jobs-matching }}"
echo "job_filter: $job_filter_pattern"
job_info=$(echo "$GITHUB_JOB ${{ toJSON(matrix) }}" | tr -d '\n')
echo "job_info: $job_info"
if [[ "$job_info" =~ .*$job_filter_pattern.* ]] && case "${{ job.status }}" in
success) [[ "${{ inputs.debug-with-ssh }}" == always ]] ;;
cancelled) [[ "${{ inputs.debug-with-ssh }}" == on_failure_or_cancelled ]] ;;
failure) [[ "${{ inputs.debug-with-ssh }}" =~ on_failure.* ]] ;;
esac; then
echo "start_session=true" >>$GITHUB_OUTPUT;
fi
- name: "SSH session for debugging: start"
uses: mxschmitt/action-tmate@v3 # https://github.com/mxschmitt/action-tmate
if: always() && steps.debug_ssh_sesssion_check.outputs.start_session
with:
limit-access-to-actor: ${{ inputs.debug-with-ssh-only-for-actor }}
test-containers:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
image:
- debian:unstable-slim
- debian:testing-slim
- debian:stable-slim
- debian:bookworm-slim
- debian:bullseye-slim
- debian:buster-slim
- "bitnami/minideb:latest"
- "bitnami/minideb:bookworm"
- "bitnami/minideb:bullseye"
- "bitnami/minideb:buster"
- "kalilinux/kali-last-release:latest"
- ubuntu:devel
- ubuntu:latest
- ubuntu:22.04
- ubuntu:20.04
- ubuntu:18.04
- ubuntu:16.04
steps:
- name: Git Checkout
uses: actions/checkout@v4 #https://github.com/actions/checkout
- name: Run tests in [${{ matrix.image }}]
timeout-minutes: 5
run: bash tests/run-tests-in-docker.sh ${{ matrix.image }}