Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# usage: configs vmname test_config (or '' for default)
|
|
|
|
#
|
|
|
|
# Sets the following variables:
|
|
|
|
# CONFIGFLAGS options to ./configure
|
|
|
|
# SSHD_CONFOPTS sshd_config options
|
|
|
|
# TEST_TARGET make target used when testing. defaults to "tests".
|
|
|
|
# LTESTS
|
|
|
|
|
|
|
|
config=$1
|
2022-11-26 23:16:15 +01:00
|
|
|
if [ "$config" = "" ]; then
|
|
|
|
config="default"
|
|
|
|
fi
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
|
2022-07-12 04:54:24 +02:00
|
|
|
unset CC CFLAGS CPPFLAGS LDFLAGS LTESTS SUDO
|
|
|
|
|
2022-11-04 06:59:26 +01:00
|
|
|
TEST_TARGET="tests compat-tests"
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
LTESTS=""
|
2021-02-21 22:09:27 +01:00
|
|
|
SKIP_LTESTS=""
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
SUDO=sudo # run with sudo by default
|
|
|
|
TEST_SSH_UNSAFE_PERMISSIONS=1
|
2022-01-12 06:58:13 +01:00
|
|
|
# Stop on first test failure to minimize logs
|
|
|
|
TEST_SSH_FAIL_FATAL=yes
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
|
|
|
|
CONFIGFLAGS=""
|
|
|
|
LIBCRYPTOFLAGS=""
|
|
|
|
|
|
|
|
case "$config" in
|
|
|
|
default|sol64)
|
|
|
|
;;
|
2021-04-26 06:49:59 +02:00
|
|
|
c89)
|
|
|
|
CC="gcc"
|
|
|
|
CFLAGS="-Wall -std=c89 -pedantic -Werror=vla"
|
2021-09-29 09:48:09 +02:00
|
|
|
CONFIGFLAGS="--without-zlib"
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2021-04-26 06:49:59 +02:00
|
|
|
TEST_TARGET=t-exec
|
|
|
|
;;
|
2022-02-12 00:24:56 +01:00
|
|
|
cygwin-release)
|
2022-08-26 08:26:06 +02:00
|
|
|
# See https://cygwin.com/git/?p=git/cygwin-packages/openssh.git;a=blob;f=openssh.cygport;hb=HEAD
|
|
|
|
CONFIGFLAGS="--with-xauth=/usr/bin/xauth --with-security-key-builtin"
|
|
|
|
CONFIGFLAGS="$CONFIGFLAGS --with-kerberos5=/usr --with-libedit --disable-strip"
|
2022-02-12 00:24:56 +01:00
|
|
|
;;
|
2021-10-21 06:00:53 +02:00
|
|
|
clang-12-Werror)
|
|
|
|
CC="clang-12"
|
|
|
|
# clang's implicit-fallthrough requires that the code be annotated with
|
|
|
|
# __attribute__((fallthrough)) and does not understand /* FALLTHROUGH */
|
2022-02-28 12:21:36 +01:00
|
|
|
CFLAGS="-Wall -Wextra -O2 -Wno-error=implicit-fallthrough -Wno-error=unused-parameter"
|
2021-10-21 06:00:53 +02:00
|
|
|
CONFIGFLAGS="--with-pam --with-Werror"
|
|
|
|
;;
|
2022-07-05 08:23:28 +02:00
|
|
|
*-sanitize-*)
|
|
|
|
case "$config" in
|
|
|
|
gcc-*)
|
|
|
|
CC=gcc
|
|
|
|
;;
|
|
|
|
clang-*)
|
|
|
|
# Find the newest available version of clang
|
|
|
|
for i in `seq 10 99`; do
|
|
|
|
clang="`which clang-$i 2>/dev/null`"
|
|
|
|
[ -x "$clang" ] && CC="$clang"
|
|
|
|
done
|
|
|
|
;;
|
|
|
|
esac
|
2022-07-05 04:02:33 +02:00
|
|
|
# Put Sanitizer logs in regress dir.
|
|
|
|
SANLOGS=`pwd`/regress
|
2022-07-03 13:46:44 +02:00
|
|
|
# - We replace chroot with chdir so that the sanitizer in the preauth
|
|
|
|
# privsep process can read /proc.
|
|
|
|
# - clang does not recognizes explicit_bzero so we use bzero
|
|
|
|
# (see https://github.com/google/sanitizers/issues/1507
|
|
|
|
# - openssl and zlib trip ASAN.
|
|
|
|
# - sp_pwdp returned by getspnam trips ASAN, hence disabling shadow.
|
|
|
|
case "$config" in
|
2022-07-05 08:23:28 +02:00
|
|
|
*-sanitize-address)
|
2022-07-03 13:46:44 +02:00
|
|
|
CFLAGS="-fsanitize=address -fno-omit-frame-pointer"
|
|
|
|
LDFLAGS="-fsanitize=address"
|
2022-07-05 08:23:28 +02:00
|
|
|
CPPFLAGS='-Dchroot=chdir -Dexplicit_bzero=bzero -D_FORTIFY_SOURCE=0 -DASAN_OPTIONS=\"detect_leaks=0:log_path='$SANLOGS'/asan.log\"'
|
|
|
|
CONFIGFLAGS=""
|
2022-07-03 13:46:44 +02:00
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
;;
|
|
|
|
clang-sanitize-memory)
|
2022-07-12 04:54:24 +02:00
|
|
|
CFLAGS="-fsanitize=memory -fsanitize-memory-track-origins -fno-omit-frame-pointer"
|
2022-07-03 13:46:44 +02:00
|
|
|
LDFLAGS="-fsanitize=memory"
|
2022-07-05 04:02:33 +02:00
|
|
|
CPPFLAGS='-Dchroot=chdir -Dexplicit_bzero=bzero -DMSAN_OPTIONS=\"log_path='$SANLOGS'/msan.log\"'
|
2023-03-26 05:49:43 +02:00
|
|
|
CONFIGFLAGS="--without-zlib --without-shadow"
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2022-07-03 13:46:44 +02:00
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
;;
|
2022-07-05 10:35:53 +02:00
|
|
|
*-sanitize-undefined)
|
2022-07-03 13:46:44 +02:00
|
|
|
CFLAGS="-fsanitize=undefined"
|
|
|
|
LDFLAGS="-fsanitize=undefined"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo unknown sanitize option;
|
|
|
|
exit 1;;
|
|
|
|
esac
|
|
|
|
features="--disable-security-key --disable-pkcs11"
|
|
|
|
hardening="--without-sandbox --without-hardening --without-stackprotect"
|
|
|
|
privsep="--with-privsep-user=root"
|
|
|
|
CONFIGFLAGS="$CONFIGFLAGS $features $hardening $privsep"
|
|
|
|
# Because we hobble chroot we can't test it.
|
|
|
|
SKIP_LTESTS=sftp-chroot
|
|
|
|
;;
|
2021-10-21 06:00:53 +02:00
|
|
|
gcc-11-Werror)
|
|
|
|
CC="gcc"
|
|
|
|
# -Wnoformat-truncation in gcc 7.3.1 20180130 fails on fmt_scaled
|
2022-02-28 12:21:36 +01:00
|
|
|
CFLAGS="-Wall -Wextra -O2 -Wno-format-truncation -Wimplicit-fallthrough=4 -Wno-unused-parameter"
|
2021-10-21 06:00:53 +02:00
|
|
|
CONFIGFLAGS="--with-pam --with-Werror"
|
|
|
|
;;
|
2021-09-29 03:36:13 +02:00
|
|
|
clang*|gcc*)
|
|
|
|
CC="$config"
|
|
|
|
;;
|
2021-02-17 08:41:30 +01:00
|
|
|
kitchensink)
|
2021-02-18 04:54:07 +01:00
|
|
|
CONFIGFLAGS="--with-kerberos5 --with-libedit --with-pam"
|
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} --with-security-key-builtin --with-selinux"
|
2022-12-07 08:58:25 +01:00
|
|
|
CFLAGS="-DSK_DEBUG -DSANDBOX_SECCOMP_FILTER_DEBUG"
|
2021-02-17 08:41:30 +01:00
|
|
|
;;
|
|
|
|
hardenedmalloc)
|
|
|
|
CONFIGFLAGS="--with-ldflags=-lhardened_malloc"
|
|
|
|
;;
|
2021-10-12 13:55:51 +02:00
|
|
|
tcmalloc)
|
|
|
|
CONFIGFLAGS="--with-ldflags=-ltcmalloc"
|
|
|
|
;;
|
2021-10-22 13:54:33 +02:00
|
|
|
krb5|heimdal)
|
2021-02-17 08:41:30 +01:00
|
|
|
CONFIGFLAGS="--with-kerberos5"
|
|
|
|
;;
|
|
|
|
libedit)
|
|
|
|
CONFIGFLAGS="--with-libedit"
|
|
|
|
;;
|
2022-02-18 02:12:21 +01:00
|
|
|
musl)
|
|
|
|
CC="musl-gcc"
|
|
|
|
CONFIGFLAGS="--without-zlib"
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
;;
|
2021-04-23 02:26:35 +02:00
|
|
|
pam-krb5)
|
|
|
|
CONFIGFLAGS="--with-pam --with-kerberos5"
|
|
|
|
SSHD_CONFOPTS="UsePam yes"
|
|
|
|
;;
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
*pam)
|
|
|
|
CONFIGFLAGS="--with-pam"
|
|
|
|
SSHD_CONFOPTS="UsePam yes"
|
|
|
|
;;
|
2023-03-24 05:02:52 +01:00
|
|
|
boringssl)
|
|
|
|
CONFIGFLAGS="--disable-pkcs11"
|
|
|
|
LIBCRYPTOFLAGS="--with-ssl-dir=/opt/boringssl --with-rpath=-Wl,-rpath,"
|
|
|
|
;;
|
2021-04-26 06:02:03 +02:00
|
|
|
libressl-*)
|
|
|
|
LIBCRYPTOFLAGS="--with-ssl-dir=/opt/libressl --with-rpath=-Wl,-rpath,"
|
2021-02-17 08:41:30 +01:00
|
|
|
;;
|
2021-04-26 06:02:03 +02:00
|
|
|
openssl-*)
|
|
|
|
LIBCRYPTOFLAGS="--with-ssl-dir=/opt/openssl --with-rpath=-Wl,-rpath,"
|
2022-11-09 10:59:20 +01:00
|
|
|
# OpenSSL 1.1.1 specifically has a bug in its RNG that breaks reexec
|
|
|
|
# fallback. See https://bugzilla.mindrot.org/show_bug.cgi?id=3483
|
|
|
|
if [ "$config" = "openssl-1.1.1" ]; then
|
|
|
|
SKIP_LTESTS="reexec"
|
|
|
|
fi
|
2021-02-17 08:41:30 +01:00
|
|
|
;;
|
|
|
|
selinux)
|
|
|
|
CONFIGFLAGS="--with-selinux"
|
|
|
|
;;
|
|
|
|
sk)
|
|
|
|
CONFIGFLAGS="--with-security-key-builtin"
|
|
|
|
;;
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
without-openssl)
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2021-02-17 08:41:30 +01:00
|
|
|
TEST_TARGET=t-exec
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
;;
|
2022-11-08 01:03:31 +01:00
|
|
|
valgrind-[1-5]|valgrind-unit)
|
2021-02-20 03:34:02 +01:00
|
|
|
# rlimit sandbox and FORTIFY_SOURCE confuse Valgrind.
|
|
|
|
CONFIGFLAGS="--without-sandbox --without-hardening"
|
|
|
|
CONFIGFLAGS="$CONFIGFLAGS --with-cppflags=-D_FORTIFY_SOURCE=0"
|
2021-04-07 02:05:10 +02:00
|
|
|
TEST_TARGET="t-exec USE_VALGRIND=1"
|
|
|
|
TEST_SSH_ELAPSED_TIMES=1
|
|
|
|
export TEST_SSH_ELAPSED_TIMES
|
2021-02-20 03:34:02 +01:00
|
|
|
# Valgrind slows things down enough that the agent timeout test
|
|
|
|
# won't reliably pass, and the unit tests run longer than allowed
|
2022-11-07 23:17:04 +01:00
|
|
|
# by github so split into separate tests.
|
|
|
|
tests2="integrity try-ciphers"
|
2022-08-31 12:26:30 +02:00
|
|
|
tests3="krl forward-control sshsig agent-restrict kextype sftp"
|
2022-01-19 14:49:57 +01:00
|
|
|
tests4="cert-userkey cert-hostkey kextype sftp-perm keygen-comment percent"
|
2022-11-07 23:17:04 +01:00
|
|
|
tests5="rekey"
|
2021-04-07 02:05:10 +02:00
|
|
|
case "$config" in
|
|
|
|
valgrind-1)
|
2023-01-31 09:35:44 +01:00
|
|
|
# All tests except agent-timeout (which is flaky under valgrind),
|
|
|
|
# connection-timeout (which doesn't work since it's so slow)
|
2022-08-11 05:33:51 +02:00
|
|
|
# and hostbased (since valgrind won't let ssh exec keysign).
|
|
|
|
# Slow ones are run separately to increase parallelism.
|
2023-01-31 09:35:44 +01:00
|
|
|
SKIP_LTESTS="agent-timeout connection-timeout hostbased"
|
|
|
|
SKIP_LTESTS="$SKIP_LTESTS ${tests2} ${tests3} ${tests4} ${tests5}"
|
2021-04-07 02:05:10 +02:00
|
|
|
;;
|
|
|
|
valgrind-2)
|
|
|
|
LTESTS="${tests2}"
|
|
|
|
;;
|
|
|
|
valgrind-3)
|
|
|
|
LTESTS="${tests3}"
|
|
|
|
;;
|
|
|
|
valgrind-4)
|
|
|
|
LTESTS="${tests4}"
|
|
|
|
;;
|
2022-11-07 23:17:04 +01:00
|
|
|
valgrind-5)
|
|
|
|
LTESTS="${tests5}"
|
|
|
|
;;
|
2021-04-08 05:31:08 +02:00
|
|
|
valgrind-unit)
|
|
|
|
TEST_TARGET="unit USE_VALGRIND=1"
|
|
|
|
;;
|
2021-04-07 02:05:10 +02:00
|
|
|
esac
|
2021-02-19 00:16:56 +01:00
|
|
|
;;
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
*)
|
|
|
|
echo "Unknown configuration $config"
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# The Solaris 64bit targets are special since they need a non-flag arg.
|
|
|
|
case "$config" in
|
|
|
|
sol64*)
|
2023-03-28 00:50:06 +02:00
|
|
|
CONFIGFLAGS="--target=x86_64 --with-cflags=-m64 --with-ldflags=-m64 ${CONFIGFLAGS}"
|
2023-03-27 13:05:29 +02:00
|
|
|
LIBCRYPTOFLAGS="--with-ssl-dir=/usr/local/ssl64 --with-rpath=-Wl,-rpath,"
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case "${TARGET_HOST}" in
|
2022-04-01 04:16:47 +02:00
|
|
|
aix*)
|
2023-03-27 02:08:00 +02:00
|
|
|
CONFIGFLAGS="--disable-security-key"
|
2023-03-27 10:21:19 +02:00
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2022-04-01 04:16:47 +02:00
|
|
|
# These are slow real or virtual machines so skip the slowest tests
|
|
|
|
# (which tend to be thw ones that transfer lots of data) so that the
|
|
|
|
# test run does not time out.
|
2022-04-04 07:16:51 +02:00
|
|
|
# The agent-restrict test fails due to some quoting issue when run
|
|
|
|
# with sh or ksh so specify bash for now.
|
2023-02-21 07:51:09 +01:00
|
|
|
TEST_TARGET="t-exec unit TEST_SHELL=bash"
|
2022-04-01 04:16:47 +02:00
|
|
|
SKIP_LTESTS="rekey sftp"
|
|
|
|
;;
|
2022-11-28 11:09:28 +01:00
|
|
|
debian-riscv64)
|
|
|
|
# This machine is fairly slow, so skip the unit tests.
|
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
;;
|
2021-08-15 04:45:10 +02:00
|
|
|
dfly58*|dfly60*)
|
2021-08-13 05:00:14 +02:00
|
|
|
# scp 3-way connection hangs on these so skip until sorted.
|
|
|
|
SKIP_LTESTS=scp3
|
|
|
|
;;
|
2022-04-04 15:52:11 +02:00
|
|
|
fbsd6)
|
|
|
|
# Native linker is not great with PIC so OpenSSL is built w/out.
|
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} --disable-security-key"
|
|
|
|
;;
|
2021-08-15 11:37:22 +02:00
|
|
|
hurd)
|
2021-08-15 15:25:26 +02:00
|
|
|
SKIP_LTESTS="forwarding multiplex proxy-connect hostkey-agent agent-ptrace"
|
2021-08-15 11:37:22 +02:00
|
|
|
;;
|
2021-05-27 13:23:15 +02:00
|
|
|
minix3)
|
2023-03-26 05:49:43 +02:00
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} --disable-security-key"
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2021-05-27 13:23:15 +02:00
|
|
|
# Minix does not have a loopback interface so we have to skip any
|
2021-12-10 00:27:27 +01:00
|
|
|
# test that relies on one.
|
2022-02-22 01:14:51 +01:00
|
|
|
# Also, Minix seems to be very limited in the number of select()
|
|
|
|
# calls that can be operating concurrently, so prune additional tests for that.
|
2023-01-07 13:24:50 +01:00
|
|
|
T="addrmatch agent-restrict brokenkeys cfgmatch cfgmatchlisten cfgparse
|
2023-02-01 07:17:26 +01:00
|
|
|
connect connect-uri exit-status forwarding hostkey-agent
|
|
|
|
key-options keyscan knownhosts-command login-timeout
|
2021-12-10 00:27:27 +01:00
|
|
|
reconfigure reexec rekey scp scp-uri scp3 sftp sftp-badcmds
|
|
|
|
sftp-batch sftp-cmds sftp-glob sftp-perm sftp-uri stderr-data
|
|
|
|
transfer"
|
2023-02-01 07:17:26 +01:00
|
|
|
# Unix domain sockets don't work quite like we expect, so also skip any tests
|
|
|
|
# that use multiplexing.
|
|
|
|
T="$T connection-timeout dynamic-forward forward-control multiplex"
|
2021-12-10 00:27:27 +01:00
|
|
|
SKIP_LTESTS="$(echo $T)"
|
2021-05-27 13:23:15 +02:00
|
|
|
TEST_TARGET=t-exec
|
|
|
|
SUDO=""
|
|
|
|
;;
|
2021-04-25 06:15:02 +02:00
|
|
|
nbsd4)
|
|
|
|
# System compiler will ICE on some files with fstack-protector
|
2021-10-06 06:40:58 +02:00
|
|
|
# SHA256 functions in sha2.h conflict with OpenSSL's breaking sk-dummy
|
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} --without-hardening --disable-security-key"
|
2021-04-25 06:15:02 +02:00
|
|
|
;;
|
2022-03-25 22:13:46 +01:00
|
|
|
openwrt-*)
|
2023-03-26 05:49:43 +02:00
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} --without-zlib"
|
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2022-03-25 22:13:46 +01:00
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
;;
|
2021-02-18 00:10:00 +01:00
|
|
|
sol10|sol11)
|
|
|
|
# sol10 VM is 32bit and the unit tests are slow.
|
|
|
|
# sol11 has 4 test configs so skip unit tests to speed up.
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
TEST_TARGET="tests SKIP_UNIT=1"
|
|
|
|
;;
|
2021-04-20 17:08:04 +02:00
|
|
|
win10)
|
|
|
|
# No sudo on Windows.
|
|
|
|
SUDO=""
|
|
|
|
;;
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
esac
|
|
|
|
|
2021-09-29 11:30:59 +02:00
|
|
|
case "`./config.guess`" in
|
2022-08-12 07:08:47 +02:00
|
|
|
*cygwin)
|
|
|
|
SUDO=""
|
2022-11-04 06:59:26 +01:00
|
|
|
# Don't run compat tests on cygwin as they don't currently compile.
|
|
|
|
TEST_TARGET="tests"
|
2022-08-12 07:08:47 +02:00
|
|
|
;;
|
2021-09-29 10:42:47 +02:00
|
|
|
*-darwin*)
|
2022-08-12 07:08:47 +02:00
|
|
|
# Unless specified otherwise, build without OpenSSL on Mac OS since
|
|
|
|
# modern versions don't ship with libcrypto.
|
2021-09-29 10:42:47 +02:00
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
2021-09-29 10:53:32 +02:00
|
|
|
TEST_TARGET=t-exec
|
2021-09-29 10:42:47 +02:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2023-03-26 05:22:53 +02:00
|
|
|
# Unless specifically configured, search for a suitable version of OpenSSL,
|
|
|
|
# otherwise build without it.
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
if [ -z "${LIBCRYPTOFLAGS}" ]; then
|
2023-03-26 05:22:53 +02:00
|
|
|
LIBCRYPTOFLAGS="--without-openssl"
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
# last-match
|
2023-03-26 05:22:53 +02:00
|
|
|
for i in /usr /usr/local /usr/local/ssl /usr/local/opt/openssl; do
|
|
|
|
ver="none"
|
2021-02-17 10:21:29 +01:00
|
|
|
if [ -x ${i}/bin/openssl ]; then
|
2023-03-26 05:22:53 +02:00
|
|
|
ver="$(${i}/bin/openssl version)"
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
fi
|
2023-03-26 05:22:53 +02:00
|
|
|
case "$ver" in
|
|
|
|
none) ;;
|
|
|
|
"OpenSSL 0."*|"OpenSSL 1.0."*|"OpenSSL 1.1.0"*) ;;
|
|
|
|
"LibreSSL 2."*|"LibreSSL 3.0."*) ;;
|
|
|
|
*) LIBCRYPTOFLAGS="--with-ssl-dir=${i}" ;;
|
|
|
|
esac
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
done
|
2023-03-26 05:39:45 +02:00
|
|
|
if [ "${LIBCRYPTOFLAGS}" = "--without-openssl" ]; then
|
|
|
|
TEST_TARGET="t-exec"
|
|
|
|
fi
|
Add self-hosted runners for VMs of other platforms.
Github only hosts a limited number of platforms, and the runner code
is only supported on slightly wider range of platforms. To increase
our test coverage beyond that, we run the runner natively on a VM host,
where it runs a jobs that boot VMs of other platforms, waits for them
to come up then runs the build and test by ssh'ing into the guest.
This means that the minimum dependencies for the guests are quite low
(basically just sshd, a compiler and make).
The interface to the VM host is fairly simple (basically 3 scripts:
vmstartup, vmrun and vmshutdown), but those are specific to the VM host
so are not in the public repo. We also mount the working directory on the
host via sshfs, so things like artifact upload by the runner also work.
As part of this we are moving the per-test-target configs into a single
place (.github/configs) where there will be referenced by a single short
"config" key. I plan to make the github-hosted runners use this too.
The self-hosted runners are run off a private repo on github since that
prevents third parties from accessing them[0], and since runner quota is
limited on private repos, we avoid running the tests we run on the public
repo.
[0] https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners#self-hosted-runner-security-with-public-repositories
2021-01-15 04:11:43 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
CONFIGFLAGS="${CONFIGFLAGS} ${LIBCRYPTOFLAGS}"
|
|
|
|
|
2021-04-26 06:29:03 +02:00
|
|
|
if [ -x "$(which plink 2>/dev/null)" ]; then
|
|
|
|
REGRESS_INTEROP_PUTTY=yes
|
|
|
|
export REGRESS_INTEROP_PUTTY
|
|
|
|
fi
|
|
|
|
|
2022-07-03 13:46:44 +02:00
|
|
|
export CC CFLAGS CPPFLAGS LDFLAGS LTESTS SUDO
|
2022-01-12 06:58:13 +01:00
|
|
|
export TEST_TARGET TEST_SSH_UNSAFE_PERMISSIONS TEST_SSH_FAIL_FATAL
|