Skip to content

Remove sfml and add sdl3 as submodule (#29) #220

Remove sfml and add sdl3 as submodule (#29)

Remove sfml and add sdl3 as submodule (#29) #220

# This starter workflow is for a CMake project running on a single platform. There is a different starter workflow if you need cross-platform coverage.
# See: https://github.com/actions/starter-workflows/blob/main/ci/cmake-multi-platform.yml
name: Check Tests
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
types: [opened, labeled, unlabeled, synchronize]
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
BUILD_TYPE: Release
jobs:
check_ci_label:
runs-on: ubuntu-latest
steps:
- name: Check for 'ci' label
run: |
# Check if it on a pull request
if [ -z "${{ github.event.pull_request.number }}" ]; then
echo "Not a pull request. Skipping."
exit 0
else
echo "A pull request."
fi
labels="$(gh api repos/$OWNER/$REPO_NAME/pulls/$PULL_REQUEST_NUMBER --jq '.labels.[].name')"
if [[ ${labels[@]} =~ "ci" ]]
then
echo "Label contains 'ci'"
exit 0
else
echo "Label does not contain 'ci'"
exit 1
fi
shell: bash
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
OWNER: ${{ github.repository_owner }}
REPO_NAME: ${{ github.event.repository.name }}
PULL_REQUEST_NUMBER: ${{ github.event.pull_request.number }}
build:
needs: check_ci_label
# The CMake configure and build commands are platform agnostic and should work equally well on Windows or Mac.
# You can convert this to a matrix build if you need cross-platform coverage.
# See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install -y libsfml-dev
- name: Configure CMake
# Configure CMake in a 'build' subdirectory. `CMAKE_BUILD_TYPE` is only required if you are using a single-configuration generator such as make.
# See https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html?highlight=cmake_build_type
run: cmake -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}}
- name: Build
# Build your program with the given configuration
run: cmake --build ${{github.workspace}}/build --config ${{env.BUILD_TYPE}}
- name: Test
working-directory: ${{github.workspace}}/build
# Execute tests defined by the CMake configuration.
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
run: ctest -C --verbose ${{env.BUILD_TYPE}}
build_docker:
needs: check_ci_label
# The CMake configure and build commands are platform agnostic and should work equally well on Windows or Mac.
# You can convert this to a matrix build if you need cross-platform coverage.
# See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Build Docker
working-directory: ${{github.workspace}}/docker
run: |
bash build.sh
- name: Run Docker
working-directory: ${{github.workspace}}/docker
run: |
bash test.sh