CTN: obtain client's username from both CA certs and the client cert #374
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
name: libnetconf2 CI | |
on: | |
push: | |
branches: | |
- master | |
- devel | |
pull_request: | |
branches: | |
- master | |
- devel | |
env: | |
DEFAULT_PACKAGES: libcmocka-dev zlib1g-dev libssh-dev libssl-dev libpam0g-dev libcurl4-openssl-dev | |
jobs: | |
git-branch: | |
name: Get git branch | |
runs-on: ubuntu-latest | |
outputs: | |
branch-name: ${{ steps.get-git-branch.outputs.branch-name }} | |
steps: | |
- id: get-git-branch | |
run: | | |
if ${{ github.event_name == 'push' }} | |
then export GIT_BRANCH=`echo ${{ github.ref }} | cut -d'/' -f 3` | |
else | |
export GIT_BRANCH=${{ github.base_ref }} | |
fi | |
echo "branch-name=$GIT_BRANCH" >> $GITHUB_OUTPUT | |
build: | |
name: ${{ matrix.config.name }} | |
runs-on: ${{ matrix.config.os }} | |
needs: git-branch | |
strategy: | |
fail-fast: false | |
matrix: | |
config: | |
- { | |
name: "Release, gcc, OpenSSL", | |
os: "ubuntu-22.04", | |
build-type: "Release", | |
dep-build-type: "Release", | |
cc: "gcc", | |
options: "-DENABLE_TESTS=ON -DENABLE_DNSSEC=ON", | |
tls-lib: "OpenSSL", | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "Release, gcc, MbedTLS", | |
os: "ubuntu-22.04", | |
build-type: "Release", | |
dep-build-type: "Release", | |
cc: "gcc", | |
options: "-DENABLE_TESTS=ON -DENABLE_DNSSEC=ON", | |
tls-lib: "MbedTLS", | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "Release, clang", | |
os: "ubuntu-22.04", | |
build-type: "Release", | |
dep-build-type: "Release", | |
cc: "clang", | |
options: "-DENABLE_TESTS=ON -DENABLE_DNSSEC=ON", | |
tls-lib: "OpenSSL", | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "Debug, gcc, OpenSSL", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "gcc", | |
options: "-DENABLE_DNSSEC=ON", | |
tls-lib: "OpenSSL", | |
packages: "valgrind", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "Debug, gcc, MbedTLS", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "gcc", | |
options: "-DENABLE_DNSSEC=ON", | |
tls-lib: "MbedTLS", | |
packages: "valgrind", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "Debug, clang", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "clang", | |
options: "-DENABLE_DNSSEC=ON", | |
tls-lib: "OpenSSL", | |
# no valgrind because it does not support DWARF5 yet generated by clang 14 | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "No SSH nor TLS", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "gcc", | |
options: "-DENABLE_SSH_TLS=OFF", | |
tls-lib: "", | |
packages: "valgrind", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "ASAN and UBSAN, OpenSSL", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "clang", | |
options: "-DCMAKE_C_FLAGS=-fsanitize=address,undefined -DENABLE_VALGRIND_TESTS=OFF", | |
tls-lib: "OpenSSL", | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "ASAN and UBSAN, MbedTLS", | |
os: "ubuntu-22.04", | |
build-type: "Debug", | |
dep-build-type: "Release", | |
cc: "clang", | |
options: "-DCMAKE_C_FLAGS=-fsanitize=address,undefined -DENABLE_VALGRIND_TESTS=OFF", | |
tls-lib: "MbedTLS", | |
packages: "", | |
snaps: "", | |
make-prepend: "", | |
make-target: "" | |
} | |
- { | |
name: "ABI Check", | |
os: "ubuntu-22.04", | |
build-type: "ABICheck", | |
dep-build-type: "Debug", | |
cc: "gcc", | |
options: "", | |
tls-lib: "OpenSSL", | |
packages: "abi-dumper abi-compliance-checker snap", | |
snaps: "core universal-ctags", | |
make-prepend: "", | |
make-target: "abi-check" | |
} | |
steps: | |
- uses: actions/checkout@main | |
- name: Deps-packages | |
shell: bash | |
run: | | |
sudo apt-get update | |
sudo apt-get install $DEFAULT_PACKAGES ${{ matrix.config.packages }} | |
if ${{ matrix.config.snaps != '' }} | |
then sudo snap refresh; sudo snap install ${{ matrix.config.snaps }} | |
fi | |
- name: Deps-uncrustify | |
shell: bash | |
working-directory: ${{ github.workspace }} | |
run: | | |
git clone --branch uncrustify-0.77.1 https://github.com/uncrustify/uncrustify | |
cd uncrustify | |
mkdir build | |
cd build | |
CC=${{ matrix.config.cc }} cmake .. | |
make | |
sudo make install | |
if: ${{ matrix.config.name == 'Debug, gcc, OpenSSL' || matrix.config.name == 'Debug, gcc, MbedTLS' }} | |
- name: Deps-libyang | |
shell: bash | |
run: | | |
git clone -b ${{ needs.git-branch.outputs.branch-name }} https://github.com/CESNET/libyang.git | |
cd libyang | |
mkdir build | |
cd build | |
CC=${{ matrix.config.cc }} cmake -DCMAKE_BUILD_TYPE=${{ matrix.config.dep-build-type }} -DENABLE_TESTS=OFF .. | |
make -j2 | |
sudo make install | |
- name: Deps-libval | |
shell: bash | |
run: | | |
git clone https://github.com/DNSSEC-Tools/DNSSEC-Tools.git dnssec-tools | |
cd dnssec-tools/dnssec-tools/validator | |
./configure | |
make -j2 | |
sudo make install | |
- name: Deps-MbedTLS | |
shell: bash | |
run: | | |
git clone -b mbedtls-3.5.2 https://github.com/Mbed-TLS/mbedtls.git | |
cd mbedtls | |
mkdir build | |
cd build | |
CC=${{ matrix.config.cc }} cmake -DUSE_SHARED_MBEDTLS_LIBRARY=On -DENABLE_TESTING=Off .. | |
make -j2 | |
sudo make install | |
if: ${{ matrix.config.tls-lib == 'MbedTLS' }} | |
- name: Configure | |
shell: bash | |
working-directory: ${{ github.workspace }} | |
run: | | |
mkdir build | |
cd build | |
CC=${{ matrix.config.cc }} cmake -DCMAKE_BUILD_TYPE=${{ matrix.config.build-type }} ${{ matrix.config.options }} .. | |
- name: Build | |
shell: bash | |
working-directory: ${{ github.workspace }}/build | |
run: | | |
export LC_ALL=C.UTF-8 | |
export PATH=/snap/bin:${{ github.workspace }}/coverity-tools/bin:$PATH | |
${{ matrix.config.make-prepend }} make ${{ matrix.config.make-target }} | |
- name: Test | |
shell: bash | |
working-directory: ${{ github.workspace }}/build | |
run: | | |
export LSAN_OPTIONS=suppressions=${{ github.workspace }}/tests/library_lsan.supp | |
ctest -j4 --output-on-failure |