Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Fedora image #432

Merged
merged 34 commits into from
Nov 28, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
ae74387
add Fedora image
20DM Sep 26, 2024
1c7f138
no submodules here
20DM Sep 26, 2024
1be74b6
apt-get to dnf
20DM Sep 26, 2024
c03c2b0
assume yes
20DM Sep 26, 2024
d47cd28
assume yes for both, d'oh
20DM Sep 26, 2024
a84ff8c
devel typo
20DM Sep 26, 2024
efdd17b
path debug
20DM Sep 26, 2024
54f666b
adjust path for container image
20DM Sep 26, 2024
c02c0c8
install cmake
20DM Sep 26, 2024
3f29506
gcc missing??
20DM Sep 26, 2024
0a5c102
meh
20DM Sep 26, 2024
85b36df
try tiff devel
20DM Sep 26, 2024
b285583
need Catch2 v3
20DM Sep 26, 2024
f619b34
no git??
20DM Sep 26, 2024
cbad455
try pointing CMake at Catch2
20DM Sep 26, 2024
a4b7471
Merge branch 'development' into cg_fedora_support
20DM Oct 8, 2024
8f50e9a
add fedora image to matrix
20DM Nov 28, 2024
09c0e0e
add container to job name
20DM Nov 28, 2024
4db4bd3
replace exclude with include
20DM Nov 28, 2024
fd49c6c
undo CC if else
20DM Nov 28, 2024
4ca0a9c
avoid list notation
20DM Nov 28, 2024
5a6fe87
try curly braces
20DM Nov 28, 2024
a5b3abc
remove CC
20DM Nov 28, 2024
bda71b3
add Fedora to the matrix
20DM Nov 28, 2024
c710bb4
make image value a string
20DM Nov 28, 2024
a7c1831
exclude Ubuntu step for Fedora
20DM Nov 28, 2024
20ec9ab
follow ChatGPT advice
20DM Nov 28, 2024
c1463e3
use uncersioned gcc for Fedora image
20DM Nov 28, 2024
d492268
fix path
20DM Nov 28, 2024
e2c7cdf
try loading mpi module
20DM Nov 28, 2024
0488191
fix if statement
20DM Nov 28, 2024
3742362
fall back to empty string if variable not defined
20DM Nov 28, 2024
bd4bdd0
remove rogue i
20DM Nov 28, 2024
f9d7cba
disable MPI for Fedora
20DM Nov 28, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
83 changes: 31 additions & 52 deletions .github/workflows/cmake.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,58 +22,50 @@ jobs:
build:
# Skip CI if PR is a draft
if: github.event.pull_request.draft == false
name: ${{matrix.os}}-${{matrix.cxx}}-mpi:${{matrix.mpi}}-openmp:${{matrix.omp}}
# 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
name: ${{matrix.os}}-${{matrix.container}}-${{matrix.cxx}}-mpi:${{matrix.mpi}}-openmp:${{matrix.omp}}
runs-on: ${{matrix.os}}
container: ${{matrix.container}}
env:
CC: ${{ matrix.cc }}
CXX: ${{ matrix.cxx }}
strategy:
fail-fast: false
matrix:
os:
- ubuntu-20.04
- macos-14
cc:
- gcc-10
- clang
cxx:
- g++-10
- clang++
mpi:
- "ON"
- "OFF"
omp:
- "ON"
- "OFF"
exclude:
- cc: gcc-10
cxx: clang++
- cc: clang
cxx: g++-10
- os: ubuntu-20.04
cc: clang
cxx: clang++
- os: macos-14
mpi: "ON"
# This doesn't seem to work with ONNXrt yet:
- os: macos-14
cxx: g++-10
include:
- { os: ubuntu-20.04, cxx: g++-10, mpi: "ON", omp: "ON" }
- { os: ubuntu-20.04, cxx: g++-10, mpi: "ON", omp: "OFF" }
- { os: ubuntu-20.04, cxx: g++-10, mpi: "OFF", omp: "ON" }
- { os: ubuntu-20.04, cxx: g++-10, mpi: "OFF", omp: "OFF" }
- { os: ubuntu-20.04, container: "fedora:39", cxx: g++, mpi: "OFF", omp: "ON" }
- { os: macos-14, cxx: clang++, mpi: "ON", omp: "ON" }
- { os: macos-14, cxx: clang++, mpi: "OFF", omp: "OFF" }
#- { os: macos-14, cxx: clang++, mpi: "OFF", omp: "ON" }
#- { os: macos-14, cxx: clang++, mpi: "ON", omp: "OFF" }

steps:
- uses: actions/checkout@v3
with:
submodules: recursive

- name: Install Dependencies on Ubunutu
if: ${{ contains(matrix.os, 'ubuntu') }}
if: contains(matrix.os, 'ubuntu') && !contains(matrix.container, 'fedora')
run: |
sudo apt update
sudo apt install openmpi-bin libopenmpi-dev libyaml-cpp-dev ccache libeigen3-dev libtiff-dev

- name: Install Dependencies on Fedora
if: ${{ contains(matrix.container, 'fedora') }}
run: |
sudo dnf -y update
sudo dnf -y install cmake gcc gcc-c++
sudo dnf -y install openmpi openmpi-devel yaml-cpp doxygen graphviz ccache eigen3-devel libtiff-devel git

- name: Install Dependencies on MacOS
if: ${{ contains(matrix.os, 'macos') }}
run: |
brew install libtiff libomp open-mpi eigen libyaml ccache catch2
echo "CMAKE_PREFIX_PATH=/opt/homebrew/opt/libomp" >> $GITHUB_ENV
echo "/opt/homebrew/opt/ccache/libexec" >> $GITHUB_PATH
#echo "/opt/homebrew/opt/libomp" >> $GITHUB_PATH

- name: Checkout Catch2
uses: actions/checkout@v4
with:
Expand All @@ -88,19 +80,6 @@ jobs:
cmake .. -DBUILD_TESTING=OFF -DCMAKE_INSTALL_PREFIX=${{github.workspace}}/local
make -j$(nproc --ignore 1) install

- name: Install Dependencies on MacOS
if: ${{ contains(matrix.os, 'macos') }}
run: |
brew install libtiff libomp open-mpi eigen libyaml ccache catch2
echo "CMAKE_PREFIX_PATH=/opt/homebrew/opt/libomp" >> $GITHUB_ENV
echo "/opt/homebrew/opt/ccache/libexec" >> $GITHUB_PATH
#echo "/opt/homebrew/opt/libomp" >> $GITHUB_PATH

#- name: Install gcc on MacOS
# if: ${{ contains(matrix.os, 'macos') && contains(matrix.cxx, 'g++10') }}
# run: |
# brew install gcc@10

# Enable tmate debugging of manually-triggered workflows if the input option was provided
- name: Setup tmate session
uses: mxschmitt/action-tmate@v3
Expand All @@ -116,8 +95,9 @@ jobs:
uses: actions/cache@v3
with:
path: ${{runner.workspace}}/.ccache
key: ${{matrix.os}}-${{matrix.cxx}}-${{matrix.mpi}}-${{matrix.omp}}-${{ steps.ccache_cache_timestamp.outputs.date_and_time }}
key: ${{matrix.os}}-${{matrix.container}}-${{matrix.cxx}}-${{matrix.mpi}}-${{matrix.omp}}-${{ steps.ccache_cache_timestamp.outputs.date_and_time }}
restore-keys: |
${{ matrix.os }}-${{ matrix.container }}-${{ matrix.cxx }}-${{ matrix.mpi }}-${{ matrix.omp }}
${{ matrix.os }}-${{ matrix.cxx }}-${{ matrix.mpi }}-${{ matrix.omp }}
${{ matrix.os }}-${{ matrix.cxx }}-${{ matrix.mpi }}
${{ matrix.os }}-${{ matrix.cxx }}
Expand All @@ -128,8 +108,7 @@ jobs:
# The Github Actions machines are dual-core so we can build faster using 2 parallel processes
run: |
export CMAKE_PREFIX_PATH=${{github.workspace}}/local:$CMAKE_PREFIX_PATH
mkdir ${{github.workspace}}/build
cd ${{github.workspace}}/build
mkdir build && cd build
cmake .. --fresh -DCMAKE_INSTALL_PREFIX=${{github.workspace}}/local -Ddompi=${{matrix.mpi}} -Dopenmp=${{matrix.omp}}
make -j$(nproc --ignore 1) install

Expand Down
7 changes: 2 additions & 5 deletions .github/workflows/documentation.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,6 @@ jobs:
steps:
- name: Check out sopt
uses: actions/checkout@v3
with:
submodules: recursive

# Enable tmate debugging of manually-triggered workflows if the input option was provided
- name: Setup tmate session
Expand Down Expand Up @@ -52,9 +50,8 @@ jobs:
- name: Build
run: |
export CMAKE_PREFIX_PATH=${{github.workspace}}/local:$CMAKE_PREFIX_PATH
mkdir ${{github.workspace}}/build
cd ${{github.workspace}}/build
cmake .. --fresh -DCMAKE_INSTALL_PREFIX=${{github.workspace}}/local -Ddompi=OFF -Dopenmp=OFF -Ddocs=ON -Donnxrt=ON
mkdir build && cd build
cmake .. --fresh -DCMAKE_INSTALL_PREFIX=${PWD}/../local -Ddompi=OFF -Dopenmp=OFF -Ddocs=ON -Donnxrt=ON
make -j$(nproc --ignore 1)
make -j$(nproc --ignore 1) install

Expand Down
Loading