-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Brendon
committed
Nov 16, 2024
1 parent
eb98fa5
commit a571d06
Showing
2 changed files
with
42 additions
and
55 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,39 +1,68 @@ | ||
# 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: CMake on a single platform | ||
|
||
on: | ||
push: | ||
branches: [ "main" ] | ||
branches: [ "CICD" ] | ||
pull_request: | ||
branches: [ "main" ] | ||
|
||
env: | ||
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.) | ||
BUILD_TYPE: Release | ||
BASE_PATH: ${{github.workspace}} | ||
|
||
jobs: | ||
build: | ||
# 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@v4 | ||
|
||
- name: Install Dependencies | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get install -y libmongoc-1.0-0 curl cmake build-essential | ||
- name: Setup External Libraries | ||
run: | | ||
mkdir -p external_libraries | ||
cd external_libraries | ||
# Clone Crow | ||
git clone --recurse-submodules https://github.com/CrowCpp/Crow.git Crow | ||
# Download and extract Boost | ||
curl -L "https://archives.boost.io/release/1.86.0/source/boost_1_86_0.tar.gz" -o boost.tar.gz | ||
tar -xzf boost.tar.gz | ||
mv boost_1_86_0 boost | ||
rm boost.tar.gz | ||
# Download and extract Asio | ||
curl -L "https://sourceforge.net/projects/asio/files/asio/1.30.2%20%28Stable%29/asio-1.30.2.tar.gz/download" -o asio.tar.gz | ||
tar -xzf asio.tar.gz | ||
mv asio-1.30.2 asio | ||
rm asio.tar.gz | ||
# Download and install MongoDB C++ Driver | ||
curl -L "https://github.com/mongodb/mongo-cxx-driver/releases/download/r3.11.0/mongo-cxx-driver-r3.11.0.tar.gz" -o mongo-cxx-driver.tar.gz | ||
tar -xzf mongo-cxx-driver.tar.gz | ||
mv mongo-cxx-driver-r3.11.0 mongo-cxx-driver | ||
cd mongo-cxx-driver/build | ||
cmake .. -DCMAKE_BUILD_TYPE=Release -DMONGOCXX_OVERRIDE_DEFAULT_INSTALL_PREFIX=OFF | ||
sudo cmake --build . --target install | ||
cd ../.. | ||
rm mongo-cxx-driver.tar.gz | ||
- 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 ${{env.BUILD_TYPE}} | ||
run: ctest -C ${{env.BUILD_TYPE}} --output-on-failure | ||
|
||
- name: Clean up | ||
run: | | ||
cd ${{github.workspace}}/external_libraries | ||
rm -f *.tar.gz |
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