Refactor tests to use an event style and fix some found bugs #300
Workflow file for this run
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
# Continuous Integration tests | |
name: CI | |
# Controls when the action will run. | |
on: | |
# Triggers the workflow on push or pull request events but only for the main branch | |
push: | |
branches: [main] | |
pull_request: | |
branches: [main] | |
# Ensure that only one instance of the workflow is run at a time for each branch/tag. | |
# Jobs currently running on the branch/tag will be cancelled when new commits are pushed. | |
# See https://docs.github.com/en/actions/learn-github-actions/workflow-syntax-for-github-actions#concurrency. | |
concurrency: | |
# `github.workflow` is the workflow name, `github.ref` is the current branch/tag identifier | |
group: ${{ format('{0}:{1}', github.workflow, github.ref) }} | |
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | |
# A workflow run is made up of one or more jobs that can run sequentially or in parallel | |
jobs: | |
build-linux: | |
name: Linux GCC | |
strategy: | |
matrix: | |
container: ['gcc:5', 'gcc:7', 'gcc:9', 'gcc:10', 'gcc:11', 'gcc:12', 'gcc:13'] | |
# The type of runner that the job will run on | |
runs-on: ubuntu-latest | |
continue-on-error: true | |
# Use the container for this specific version of gcc | |
container: ${{ matrix.container }} | |
# Steps represent a sequence of tasks that will be executed as part of the job | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it | |
- name: Checkout Code | |
uses: actions/checkout@v2 | |
# Download and install cmake | |
- name: Install CMake v3.19.1 | |
uses: lukka/[email protected] | |
- name: Configure CMake | |
run: | | |
cmake -E make_directory build | |
cmake -S . -B build -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Release -DCI_BUILD=ON | |
- name: Build | |
timeout-minutes: 30 | |
# Execute the build. You can specify a specific target with "--target <NAME>" | |
run: cmake --build build --config Release --parallel 2 | |
- name: Test | |
timeout-minutes: 5 | |
# Execute tests defined by the CMake configuration. | |
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail | |
run: | | |
build/tests/test_nuclear | |
for f in build/tests/individual/*; do echo "Testing $f"; ./$f; done | |
build-osx: | |
name: MacOS Clang | |
# The type of runner that the job will run on | |
runs-on: macos-latest | |
# Steps represent a sequence of tasks that will be executed as part of the job | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it | |
- name: Checkout Code | |
uses: actions/checkout@v2 | |
- name: Configure CMake | |
run: | | |
cmake -E make_directory build | |
cmake -S . -B build -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Release | |
- name: Build | |
timeout-minutes: 30 | |
# Execute the build. You can specify a specific target with "--target <NAME>" | |
run: cmake --build build --config Release --parallel 2 | |
- name: Test | |
timeout-minutes: 5 | |
# Execute tests defined by the CMake configuration. | |
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail | |
run: | | |
build/tests/test_nuclear | |
for f in build/tests/individual/*; do echo "Testing $f"; ./$f; done | |
build-windows: | |
name: Windows MSVC | |
# The type of runner that the job will run on | |
runs-on: windows-latest | |
# Steps represent a sequence of tasks that will be executed as part of the job | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it | |
- name: Checkout Code | |
uses: actions/checkout@v2 | |
- name: Configure CMake | |
run: | | |
cmake -E make_directory build | |
cmake -S . -B build -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Release | |
- name: Build | |
timeout-minutes: 30 | |
# Execute the build. You can specify a specific target with "--target <NAME>" | |
run: cmake --build build --config Release --parallel 2 | |
- name: Test | |
timeout-minutes: 5 | |
# Execute tests defined by the CMake configuration. | |
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail | |
run: | | |
build/tests/Release/test_nuclear.exe | |
for f in build/tests/individual/Release/*; do echo "Testing $f"; ./$f; done | |
shell: bash | |
check-clang-tidy: | |
name: Clang-Tidy | |
# The type of runner that the job will run on | |
runs-on: ubuntu-latest | |
# Steps represent a sequence of tasks that will be executed as part of the job | |
steps: | |
- name: Install clang-tidy | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y clang-tidy | |
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it | |
- name: Checkout Code | |
uses: actions/checkout@v2 | |
# Download and install cmake | |
- name: Install CMake v3.19.1 | |
uses: lukka/[email protected] | |
- name: Configure CMake | |
run: | | |
cmake -E make_directory build | |
cmake -S . -B build -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Release -DCI_BUILD=ON -DENABLE_CLANG_TIDY=ON | |
- name: Build | |
timeout-minutes: 30 | |
# Execute the build. You can specify a specific target with "--target <NAME>" | |
run: cmake --build build --config Release --parallel 2 |