Skip to content

Commit

Permalink
Adds CI job to test strongSwan integration (#1472)
Browse files Browse the repository at this point in the history
This CI job tests AWS-LC against the tip of strongswan/master. We use
AWS-LC's shared library build and override the libcrypto used by
strongSwan by setting LD_LIBRARY_PATH. We also run through strongSwan's
unit test framework to make sure there are no correctness issues.
  • Loading branch information
geedo0 authored Mar 8, 2024
1 parent b47c6ff commit 74feede
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 0 deletions.
13 changes: 13 additions & 0 deletions .github/workflows/integrations.yml
Original file line number Diff line number Diff line change
Expand Up @@ -124,3 +124,16 @@ jobs:
- name: Run bind9 build
run: |
./tests/ci/integration/run_bind9_integration.sh
strongswan:
runs-on: ubuntu-latest
steps:
- name: Install OS Dependencies
run: |
sudo apt-get update
sudo apt-get -y --no-install-recommends install \
cmake gcc ninja-build golang make gperf bison flex autogen autoconf \
pkg-config libtool gettext libgmp-dev libsystemd-dev
- uses: actions/checkout@v4
- name: Run strongswan build
run: |
./tests/ci/integration/run_strongswan_integration.sh
58 changes: 58 additions & 0 deletions tests/ci/integration/run_strongswan_integration.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#!/bin/bash -exu
# Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
# SPDX-License-Identifier: Apache-2.0 OR ISC

source tests/ci/common_posix_setup.sh

# Set up environment.

# SYS_ROOT
# - SRC_ROOT(aws-lc)
# - SCRATCH_FOLDER
# - AWS_LC_BUILD_FOLDER
# - AWS_LC_INSTALL_FOLDER
# - STRONGSWAN_SRC_FOLDER

# Assumes script is executed from the root of aws-lc directory
SCRATCH_FOLDER="${SRC_ROOT}/STRONGSWAN_BUILD_ROOT"
STRONGSWAN_SRC_FOLDER="${SCRATCH_FOLDER}/strongswan"
AWS_LC_BUILD_FOLDER="${SCRATCH_FOLDER}/aws-lc-build"
AWS_LC_INSTALL_FOLDER="${SCRATCH_FOLDER}/aws-lc-install"

function strongswan_build() {
export CFLAGS="-I${AWS_LC_INSTALL_FOLDER}/include"
export LDFLAGS="-L${AWS_LC_INSTALL_FOLDER}/lib"
autoreconf -ivf
# Mirror the configuration flags set by strongSwan's CI by taking all of the
# flags specified within CONFIG when TEST is openssl-awslc in their test.sh.
# https://github.com/strongswan/strongswan/blob/44e241fccc166211ccfdd322047c1213ff3ae73c/scripts/test.sh#L468
./configure --disable-defaults --enable-pki --enable-openssl --enable-pem \
--disable-dependency-tracking --enable-silent-rules --enable-test-vectors \
--enable-monolithic=no --enable-leak-detective=no --enable-asan
make -j ${NUM_CPU_THREADS}
local openssl_plugin="${STRONGSWAN_SRC_FOLDER}/src/libstrongswan/plugins/openssl/.libs/libstrongswan-openssl.so"
ldd ${openssl_plugin} \
| grep "${AWS_LC_INSTALL_FOLDER}/lib/libcrypto.so" || exit 1
}

function strongswan_run_tests() {
make -j ${NUM_CPU_THREADS} check
}

mkdir -p ${SCRATCH_FOLDER}
rm -rf ${SCRATCH_FOLDER}/*
cd ${SCRATCH_FOLDER}

git clone --depth 1 https://github.com/strongswan/strongswan.git ${STRONGSWAN_SRC_FOLDER}

mkdir -p ${AWS_LC_BUILD_FOLDER} ${AWS_LC_INSTALL_FOLDER}

aws_lc_build ${SRC_ROOT} ${AWS_LC_BUILD_FOLDER} ${AWS_LC_INSTALL_FOLDER} \
-DBUILD_TESTING=OFF -DBUILD_TOOL=OFF -DBUILD_SHARED_LIBS=1

export LD_LIBRARY_PATH="${AWS_LC_INSTALL_FOLDER}/lib"

pushd ${STRONGSWAN_SRC_FOLDER}
strongswan_build
strongswan_run_tests
popd

0 comments on commit 74feede

Please sign in to comment.