mirror of
https://gitlab.alpinelinux.org/alpine/abuild.git
synced 2025-01-02 20:42:43 +00:00
94122d7bec
use a fake openssl for abuild-keykey and pre-generate the abuild keys. This makes tests run significantly faster as we dont need to generate new keys for each abuild-keygen test.
106 lines
2.2 KiB
Plaintext
Executable File
106 lines
2.2 KiB
Plaintext
Executable File
#!/usr/bin/env atf-sh
|
|
|
|
SRCDIR="$(atf_get_srcdir)"
|
|
. "$SRCDIR"/test_env.sh
|
|
init_tests \
|
|
abuild_keygen_help \
|
|
abuild_keygen_invalid_opts \
|
|
abuild_keygen_invalid_arg \
|
|
abuild_keygen_non_interactive \
|
|
abuild_keygen_append \
|
|
abuild_keygen_install_without_sudo \
|
|
abuild_keygen_install_interactive \
|
|
abuild_keygen_install_non_interactive \
|
|
abuild_keygen_install_doas
|
|
|
|
export ABUILD_SHAREDIR="$SRCDIR"/..
|
|
export GIT=false
|
|
export FAKEKEY="$SRCDIR/testdata/abuild.key"
|
|
export FAKEKEYPUB="$SRCDIR/testdata/abuild.key.pub"
|
|
|
|
PATH="$SRCDIR/bin:$PATH"
|
|
|
|
abuild_keygen_help_body() {
|
|
atf_check -s exit:0 \
|
|
-o not-empty \
|
|
-e empty \
|
|
abuild-keygen --help
|
|
}
|
|
|
|
abuild_keygen_invalid_opts_body() {
|
|
atf_check -s exit:1 \
|
|
-o empty \
|
|
-e not-empty \
|
|
abuild-keygen -INVALID
|
|
}
|
|
|
|
abuild_keygen_invalid_arg_body() {
|
|
atf_check -s exit:2 \
|
|
-o empty \
|
|
-e not-empty \
|
|
abuild-keygen INVALID
|
|
}
|
|
|
|
abuild_keygen_non_interactive_body() {
|
|
atf_check -s exit:0 \
|
|
-o empty \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen -n
|
|
}
|
|
|
|
abuild_keygen_append_body() {
|
|
PACKAGER="Test User <user@example.com>" \
|
|
atf_check -s exit:0 \
|
|
\
|
|
-o empty \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen --append -n
|
|
grep '^PACKAGER_PRIVKEY=.*user@example.com' "$HOME"/.abuild/abuild.conf \
|
|
|| atf_fail 'PACKAGER_PRIVKEY not set in abuild.conf'
|
|
}
|
|
|
|
abuild_keygen_install_without_sudo_body() {
|
|
SUDO=false \
|
|
atf_check -s exit:1 \
|
|
\
|
|
-o empty \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen --install -n
|
|
}
|
|
|
|
abuild_keygen_install_interactive_body() {
|
|
echo | abuild_keygen_install_root="$PWD" SUDO= \
|
|
atf_check -s exit:0 \
|
|
\
|
|
-o match:"Enter file" \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen --install
|
|
}
|
|
|
|
abuild_keygen_install_non_interactive_body() {
|
|
abuild_keygen_install_root="$PWD" SUDO= \
|
|
atf_check -s exit:0 \
|
|
\
|
|
-o empty \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen --install -n
|
|
}
|
|
|
|
abuild_keygen_install_doas_body() {
|
|
mkdir bin
|
|
cat >bin/doas<<-EOF
|
|
#!/bin/sh
|
|
echo "fake doas"
|
|
"\$@"
|
|
EOF
|
|
chmod +x bin/doas
|
|
|
|
PATH="$PWD/bin:$PATH" abuild_keygen_install_root="$PWD" \
|
|
atf_check -s exit:0 \
|
|
\
|
|
-o match:"fake doas" \
|
|
-e match:"(Generating|writing) RSA" \
|
|
abuild-keygen --install -n
|
|
}
|
|
|