Attempt to run tests on Alma Linux
This commit is contained in:
parent
f21bac7d1c
commit
429da3f4c1
2 changed files with 296 additions and 46 deletions
|
|
@ -7,34 +7,99 @@ jobs:
|
||||||
test:
|
test:
|
||||||
runs-on: docker
|
runs-on: docker
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- distro: debian
|
||||||
|
image: docker.io/library/debian:13
|
||||||
|
python: python3
|
||||||
|
- distro: almalinux
|
||||||
|
image: docker.io/library/almalinux:9
|
||||||
|
python: python3.11
|
||||||
|
|
||||||
|
container:
|
||||||
|
image: ${{ matrix.image }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
|
- name: Install system dependencies
|
||||||
|
env:
|
||||||
|
DISTRO: ${{ matrix.distro }}
|
||||||
|
PYTHON_BIN: ${{ matrix.python }}
|
||||||
|
run: |
|
||||||
|
set -eux
|
||||||
|
|
||||||
|
case "${DISTRO}" in
|
||||||
|
debian)
|
||||||
|
mkdir -m 755 -p /etc/apt/keyrings
|
||||||
|
apt-get update
|
||||||
|
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
|
||||||
|
ca-certificates curl gnupg git tar gzip findutils bash \
|
||||||
|
ansible ansible-lint python3 python3-venv python3-pip pipx systemctl python3-apt jq python3-jsonschema \
|
||||||
|
puppet hiera
|
||||||
|
curl -fsSL https://packages.broadcom.com/artifactory/api/security/keypair/SaltProjectKey/public | gpg --dearmor | tee /etc/apt/keyrings/salt-archive-keyring.pgp > /dev/null
|
||||||
|
curl -fsSL https://github.com/saltstack/salt-install-guide/releases/latest/download/salt.sources | tee /etc/apt/sources.list.d/salt.sources
|
||||||
|
apt-get update
|
||||||
|
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
|
||||||
|
salt-master salt-minion salt-ssh salt-syndic salt-cloud salt-api
|
||||||
|
;;
|
||||||
|
almalinux)
|
||||||
|
dnf -y upgrade --refresh
|
||||||
|
dnf -y install \
|
||||||
|
ca-certificates curl gnupg2 git tar gzip findutils bash which jq \
|
||||||
|
dnf-plugins-core epel-release
|
||||||
|
dnf -y config-manager --set-enabled crb || true
|
||||||
|
curl -fsSL https://github.com/saltstack/salt-install-guide/releases/latest/download/salt.repo > /etc/yum.repos.d/salt.repo
|
||||||
|
dnf -y install https://yum.puppet.com/puppet8-release-el-9.noarch.rpm
|
||||||
|
dnf -y makecache
|
||||||
|
dnf -y install \
|
||||||
|
python3.11 python3.11-devel python3.11-pip gcc make \
|
||||||
|
ansible-core ansible-lint systemd rpm httpd \
|
||||||
|
puppet-agent \
|
||||||
|
salt-master salt-minion salt-ssh salt-syndic salt-cloud salt-api
|
||||||
|
echo "/opt/puppetlabs/bin" >> "$GITHUB_PATH"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unsupported CI distro: ${DISTRO}" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install system dependencies
|
|
||||||
run: |
|
|
||||||
mkdir -m 755 -p /etc/apt/keyrings
|
|
||||||
curl -fsSL https://packages.broadcom.com/artifactory/api/security/keypair/SaltProjectKey/public | gpg --dearmor | tee /etc/apt/keyrings/salt-archive-keyring.pgp > /dev/null
|
|
||||||
curl -fsSL https://github.com/saltstack/salt-install-guide/releases/latest/download/salt.sources | tee /etc/apt/sources.list.d/salt.sources
|
|
||||||
apt-get update
|
|
||||||
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
|
|
||||||
ansible ansible-lint python3-venv pipx systemctl python3-apt jq python3-jsonschema \
|
|
||||||
puppet hiera \
|
|
||||||
salt-master salt-minion salt-ssh salt-syndic salt-cloud salt-api
|
|
||||||
|
|
||||||
- name: Install Poetry
|
- name: Install Poetry
|
||||||
|
env:
|
||||||
|
PYTHON_BIN: ${{ matrix.python }}
|
||||||
run: |
|
run: |
|
||||||
pipx install poetry==1.8.3
|
set -eux
|
||||||
|
if ! command -v pipx >/dev/null 2>&1; then
|
||||||
|
"${PYTHON_BIN}" -m pip install --user pipx
|
||||||
|
fi
|
||||||
|
PIPX_BIN="$(command -v pipx || true)"
|
||||||
|
if [ -z "${PIPX_BIN}" ]; then
|
||||||
|
PIPX_BIN="${HOME}/.local/bin/pipx"
|
||||||
|
fi
|
||||||
|
"${PIPX_BIN}" install --python "${PYTHON_BIN}" poetry==1.8.3
|
||||||
/root/.local/bin/poetry --version
|
/root/.local/bin/poetry --version
|
||||||
echo "$HOME/.local/bin" >> "$GITHUB_PATH"
|
echo "$HOME/.local/bin" >> "$GITHUB_PATH"
|
||||||
|
|
||||||
- name: Install project deps (including test extras)
|
- name: Install project deps (including test extras)
|
||||||
|
env:
|
||||||
|
PYTHON_BIN: ${{ matrix.python }}
|
||||||
run: |
|
run: |
|
||||||
|
poetry env use "${PYTHON_BIN}"
|
||||||
poetry install --with dev
|
poetry install --with dev
|
||||||
|
|
||||||
- name: Install sops
|
- name: Install sops
|
||||||
run: |
|
run: |
|
||||||
curl -L -o /usr/local/bin/sops https://github.com/getsops/sops/releases/download/v3.13.1/sops-v3.13.1.linux.amd64
|
set -eux
|
||||||
|
case "$(uname -m)" in
|
||||||
|
x86_64) sops_arch=amd64 ;;
|
||||||
|
aarch64|arm64) sops_arch=arm64 ;;
|
||||||
|
*) echo "Unsupported architecture for sops: $(uname -m)" >&2; exit 1 ;;
|
||||||
|
esac
|
||||||
|
curl -L -o /usr/local/bin/sops "https://github.com/getsops/sops/releases/download/v3.13.1/sops-v3.13.1.linux.${sops_arch}"
|
||||||
chmod +x /usr/local/bin/sops
|
chmod +x /usr/local/bin/sops
|
||||||
|
|
||||||
- name: Run test script
|
- name: Run test script
|
||||||
|
|
|
||||||
251
tests.sh
251
tests.sh
|
|
@ -2,6 +2,10 @@
|
||||||
|
|
||||||
set -Eeuo pipefail
|
set -Eeuo pipefail
|
||||||
|
|
||||||
|
if [[ -d /opt/puppetlabs/bin ]]; then
|
||||||
|
export PATH="/opt/puppetlabs/bin:${PATH}"
|
||||||
|
fi
|
||||||
|
|
||||||
PROJECT_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
PROJECT_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||||
TMP_PARENT="${TMPDIR:-/tmp}"
|
TMP_PARENT="${TMPDIR:-/tmp}"
|
||||||
KEEP_WORKDIR=0
|
KEEP_WORKDIR=0
|
||||||
|
|
@ -64,50 +68,228 @@ require_root() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
require_debian_ci() {
|
require_supported_ci_os() {
|
||||||
if [[ -r /etc/os-release ]]; then
|
if [[ -r /etc/os-release ]]; then
|
||||||
# shellcheck disable=SC1091
|
# shellcheck disable=SC1091
|
||||||
. /etc/os-release
|
. /etc/os-release
|
||||||
if [[ "${ID:-}" != "debian" || "${VERSION_ID:-}" != "13" ]]; then
|
case "${ID:-}" in
|
||||||
printf 'WARNING: tests.sh is maintained for Debian 13 CI; detected %s %s.\n' "${ID:-unknown}" "${VERSION_ID:-unknown}" >&2
|
debian)
|
||||||
|
if [[ "${VERSION_ID:-}" != "13" ]]; then
|
||||||
|
printf 'WARNING: tests.sh is maintained for Debian 13 CI; detected Debian %s.\n' "${VERSION_ID:-unknown}" >&2
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
almalinux|rhel|rocky|centos|fedora)
|
||||||
|
printf 'Detected RPM-family CI host: %s %s.\n' "${ID:-unknown}" "${VERSION_ID:-unknown}" >&2
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
printf 'WARNING: tests.sh is maintained for Debian 13 and AlmaLinux/RHEL-family CI; detected %s %s.\n' "${ID:-unknown}" "${VERSION_ID:-unknown}" >&2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
os_id() {
|
||||||
|
if [[ -r /etc/os-release ]]; then
|
||||||
|
# shellcheck disable=SC1091
|
||||||
|
. /etc/os-release
|
||||||
|
printf '%s' "${ID:-unknown}"
|
||||||
|
else
|
||||||
|
printf 'unknown'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
os_version_major() {
|
||||||
|
if [[ -r /etc/os-release ]]; then
|
||||||
|
# shellcheck disable=SC1091
|
||||||
|
. /etc/os-release
|
||||||
|
printf '%s' "${VERSION_ID%%.*}"
|
||||||
|
else
|
||||||
|
printf 'unknown'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
is_debian() {
|
||||||
|
[[ "$(os_id)" == "debian" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
is_rpm_family() {
|
||||||
|
case "$(os_id)" in
|
||||||
|
almalinux|rhel|rocky|centos|fedora) return 0 ;;
|
||||||
|
*) return 1 ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_update_once() {
|
||||||
|
if is_debian; then
|
||||||
|
if [[ -z "${APT_UPDATED:-}" ]]; then
|
||||||
|
section "Setup: apt metadata"
|
||||||
|
run apt-get update
|
||||||
|
APT_UPDATED=1
|
||||||
fi
|
fi
|
||||||
|
elif is_rpm_family; then
|
||||||
|
if [[ -z "${DNF_UPDATED:-}" ]]; then
|
||||||
|
section "Setup: dnf metadata"
|
||||||
|
run dnf -y makecache
|
||||||
|
DNF_UPDATED=1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
fail "Unsupported package manager for OS $(os_id)."
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
apt_update_once() {
|
translate_packages() {
|
||||||
if [[ -z "${APT_UPDATED:-}" ]]; then
|
local translated=()
|
||||||
section "Setup: apt metadata"
|
local pkg
|
||||||
run apt-get update
|
for pkg in "$@"; do
|
||||||
APT_UPDATED=1
|
if is_debian; then
|
||||||
|
translated+=("${pkg}")
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "${pkg}" in
|
||||||
|
ansible) translated+=(ansible-core) ;;
|
||||||
|
apache2) translated+=(httpd) ;;
|
||||||
|
gnupg) translated+=(gnupg2) ;;
|
||||||
|
lsb-release) translated+=(redhat-lsb-core) ;;
|
||||||
|
puppet) translated+=(puppet-agent) ;;
|
||||||
|
python3-apt) ;;
|
||||||
|
python3-jsonschema) translated+=(python3-jsonschema) ;;
|
||||||
|
python3-venv) ;;
|
||||||
|
systemctl) translated+=(systemd) ;;
|
||||||
|
*) translated+=("${pkg}") ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
printf '%s\n' "${translated[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_install() {
|
||||||
|
local packages=()
|
||||||
|
local pkg
|
||||||
|
|
||||||
|
while IFS= read -r pkg; do
|
||||||
|
[[ -n "${pkg}" ]] && packages+=("${pkg}")
|
||||||
|
done < <(translate_packages "$@")
|
||||||
|
|
||||||
|
if [[ "${#packages[@]}" -eq 0 ]]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
pkg_update_once
|
||||||
|
if is_debian; then
|
||||||
|
run env DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends "${packages[@]}"
|
||||||
|
elif is_rpm_family; then
|
||||||
|
ensure_epel_repo
|
||||||
|
run dnf -y install "${packages[@]}"
|
||||||
|
else
|
||||||
|
fail "Unsupported package manager for OS $(os_id)."
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
apt_install() {
|
pkg_remove_purge() {
|
||||||
apt_update_once
|
if is_debian; then
|
||||||
run env DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends "$@"
|
run env DEBIAN_FRONTEND=noninteractive apt-get remove -y --purge "$@"
|
||||||
|
elif is_rpm_family; then
|
||||||
|
run dnf -y remove "$@"
|
||||||
|
else
|
||||||
|
fail "Unsupported package manager for OS $(os_id)."
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
apt_remove_purge() {
|
ensure_epel_repo() {
|
||||||
run env DEBIAN_FRONTEND=noninteractive apt-get remove -y --purge "$@"
|
if ! is_rpm_family; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
if rpm -q epel-release >/dev/null 2>&1; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
run dnf -y install dnf-plugins-core epel-release
|
||||||
|
run dnf -y config-manager --set-enabled crb || true
|
||||||
|
DNF_UPDATED=
|
||||||
|
}
|
||||||
|
|
||||||
|
ensure_salt_repo() {
|
||||||
|
if is_debian; then
|
||||||
|
if [[ -e /etc/apt/sources.list.d/salt.sources ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
section "Setup: Salt apt repository"
|
||||||
|
pkg_install ca-certificates curl gnupg
|
||||||
|
run mkdir -m 755 -p /etc/apt/keyrings
|
||||||
|
run bash -c "curl -fsSL https://packages.broadcom.com/artifactory/api/security/keypair/SaltProjectKey/public | gpg --dearmor --yes -o /etc/apt/keyrings/salt-archive-keyring.pgp"
|
||||||
|
run bash -c "curl -fsSL https://github.com/saltstack/salt-install-guide/releases/latest/download/salt.sources > /etc/apt/sources.list.d/salt.sources"
|
||||||
|
APT_UPDATED=
|
||||||
|
elif is_rpm_family; then
|
||||||
|
if [[ -e /etc/yum.repos.d/salt.repo ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
section "Setup: Salt dnf repository"
|
||||||
|
pkg_install ca-certificates curl
|
||||||
|
run bash -c "curl -fsSL https://github.com/saltstack/salt-install-guide/releases/latest/download/salt.repo > /etc/yum.repos.d/salt.repo"
|
||||||
|
DNF_UPDATED=
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
ensure_puppet_repo() {
|
||||||
|
if ! is_rpm_family; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
if rpm -q puppet8-release >/dev/null 2>&1 || [[ -e /etc/yum.repos.d/puppet8-release.repo ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
section "Setup: Puppet dnf repository"
|
||||||
|
local major
|
||||||
|
major="$(os_version_major)"
|
||||||
|
run dnf -y install "https://yum.puppet.com/puppet8-release-el-${major}.noarch.rpm"
|
||||||
|
DNF_UPDATED=
|
||||||
|
}
|
||||||
|
|
||||||
|
ensure_mig5_rpm_repo() {
|
||||||
|
if ! is_rpm_family; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
if [[ -e /etc/yum.repos.d/mig5.repo ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
section "Setup: mig5 dnf repository"
|
||||||
|
pkg_install ca-certificates curl
|
||||||
|
run rpm --import https://mig5.net/static/mig5.asc
|
||||||
|
cat >/etc/yum.repos.d/mig5.repo <<'EOF'
|
||||||
|
[mig5]
|
||||||
|
name=mig5 Repository
|
||||||
|
baseurl=https://rpm.mig5.net/$releasever/rpm/$basearch
|
||||||
|
enabled=1
|
||||||
|
gpgcheck=1
|
||||||
|
repo_gpgcheck=1
|
||||||
|
gpgkey=https://mig5.net/static/mig5.asc
|
||||||
|
EOF
|
||||||
|
run dnf -y upgrade --refresh
|
||||||
|
DNF_UPDATED=1
|
||||||
}
|
}
|
||||||
|
|
||||||
ensure_jinjaturtle() {
|
ensure_jinjaturtle() {
|
||||||
section "Setup: JinjaTurtle apt package"
|
section "Setup: JinjaTurtle package"
|
||||||
if command -v jinjaturtle >/dev/null 2>&1; then
|
if command -v jinjaturtle >/dev/null 2>&1; then
|
||||||
printf 'jinjaturtle already available at: %s\n' "$(command -v jinjaturtle)"
|
printf 'jinjaturtle already available at: %s\n' "$(command -v jinjaturtle)"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
apt_install ca-certificates curl gnupg lsb-release
|
if is_debian; then
|
||||||
run mkdir -p /usr/share/keyrings
|
pkg_install ca-certificates curl gnupg lsb-release
|
||||||
run bash -c "curl -fsSL https://mig5.net/static/mig5.asc | gpg --dearmor --yes -o /usr/share/keyrings/mig5.gpg"
|
run mkdir -p /usr/share/keyrings
|
||||||
|
run bash -c "curl -fsSL https://mig5.net/static/mig5.asc | gpg --dearmor --yes -o /usr/share/keyrings/mig5.gpg"
|
||||||
|
|
||||||
local codename
|
local codename
|
||||||
codename="$(lsb_release -cs)"
|
codename="$(lsb_release -cs)"
|
||||||
run bash -c "printf '%s\n' 'deb [arch=amd64 signed-by=/usr/share/keyrings/mig5.gpg] https://apt.mig5.net ${codename} main' > /etc/apt/sources.list.d/mig5.list"
|
run bash -c "printf '%s\n' 'deb [arch=amd64 signed-by=/usr/share/keyrings/mig5.gpg] https://apt.mig5.net ${codename} main' > /etc/apt/sources.list.d/mig5.list"
|
||||||
run apt-get update
|
run apt-get update
|
||||||
APT_UPDATED=1
|
APT_UPDATED=1
|
||||||
run env DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends jinjaturtle
|
run env DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends jinjaturtle
|
||||||
|
elif is_rpm_family; then
|
||||||
|
ensure_mig5_rpm_repo
|
||||||
|
pkg_install jinjaturtle
|
||||||
|
else
|
||||||
|
fail "Unsupported OS for JinjaTurtle package install: $(os_id)."
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
require_cmd() {
|
require_cmd() {
|
||||||
|
|
@ -119,25 +301,28 @@ require_cmd() {
|
||||||
}
|
}
|
||||||
|
|
||||||
ensure_ansible() {
|
ensure_ansible() {
|
||||||
|
ensure_epel_repo
|
||||||
if ! command -v ansible-playbook >/dev/null 2>&1 || ! command -v ansible-lint >/dev/null 2>&1; then
|
if ! command -v ansible-playbook >/dev/null 2>&1 || ! command -v ansible-lint >/dev/null 2>&1; then
|
||||||
apt_install ansible ansible-lint
|
pkg_install ansible ansible-lint
|
||||||
fi
|
fi
|
||||||
require_cmd ansible-playbook "Install the Debian ansible package."
|
require_cmd ansible-playbook "Install the ansible/ansible-core package."
|
||||||
require_cmd ansible-lint "Install the Debian ansible-lint package."
|
require_cmd ansible-lint "Install the ansible-lint package."
|
||||||
}
|
}
|
||||||
|
|
||||||
ensure_puppet() {
|
ensure_puppet() {
|
||||||
|
ensure_puppet_repo
|
||||||
if ! command -v puppet >/dev/null 2>&1; then
|
if ! command -v puppet >/dev/null 2>&1; then
|
||||||
apt_install puppet || apt_install puppet-agent
|
pkg_install puppet || pkg_install puppet-agent
|
||||||
fi
|
fi
|
||||||
require_cmd puppet "Install Puppet before running the Puppet noop integration tests."
|
require_cmd puppet "Install Puppet before running the Puppet noop integration tests."
|
||||||
}
|
}
|
||||||
|
|
||||||
ensure_salt() {
|
ensure_salt() {
|
||||||
|
ensure_salt_repo
|
||||||
if ! command -v salt-call >/dev/null 2>&1; then
|
if ! command -v salt-call >/dev/null 2>&1; then
|
||||||
apt_install salt-minion || true
|
pkg_install salt-minion || true
|
||||||
fi
|
fi
|
||||||
require_cmd salt-call "Install Salt's salt-call binary before running the Salt noop integration tests. On Debian 13 this may require configuring the upstream Salt/Broadcom package repository first."
|
require_cmd salt-call "Install Salt's salt-call binary before running the Salt noop integration tests. This may require configuring the upstream Salt/Broadcom package repository first."
|
||||||
}
|
}
|
||||||
|
|
||||||
run_pytests() {
|
run_pytests() {
|
||||||
|
|
@ -148,7 +333,7 @@ run_pytests() {
|
||||||
|
|
||||||
prepare_harvest_fixture() {
|
prepare_harvest_fixture() {
|
||||||
section "Common harvest fixture and CLI smoke checks"
|
section "Common harvest fixture and CLI smoke checks"
|
||||||
apt_install jq apache2
|
pkg_install jq apache2
|
||||||
|
|
||||||
cat >"${JINJATURTLE_FIXTURE}" <<'EOF'
|
cat >"${JINJATURTLE_FIXTURE}" <<'EOF'
|
||||||
[enroll_tests]
|
[enroll_tests]
|
||||||
|
|
@ -164,11 +349,11 @@ EOF
|
||||||
run bash -c "poetry run enroll explain '${BUNDLE_DIR}' --format json | jq"
|
run bash -c "poetry run enroll explain '${BUNDLE_DIR}' --format json | jq"
|
||||||
run poetry run enroll validate --fail-on-warnings "${BUNDLE_DIR}"
|
run poetry run enroll validate --fail-on-warnings "${BUNDLE_DIR}"
|
||||||
|
|
||||||
apt_install cowsay
|
pkg_install cowsay
|
||||||
run poetry run enroll harvest --out "${BUNDLE_DIFF_DIR}" --include-path "${JINJATURTLE_FIXTURE}"
|
run poetry run enroll harvest --out "${BUNDLE_DIFF_DIR}" --include-path "${JINJATURTLE_FIXTURE}"
|
||||||
run poetry run enroll validate --fail-on-warnings "${BUNDLE_DIFF_DIR}"
|
run poetry run enroll validate --fail-on-warnings "${BUNDLE_DIFF_DIR}"
|
||||||
run bash -c "poetry run enroll diff --old '${BUNDLE_DIR}' --new '${BUNDLE_DIFF_DIR}' --format json | jq"
|
run bash -c "poetry run enroll diff --old '${BUNDLE_DIR}' --new '${BUNDLE_DIFF_DIR}' --format json | jq"
|
||||||
apt_remove_purge cowsay
|
pkg_remove_purge cowsay
|
||||||
}
|
}
|
||||||
|
|
||||||
assert_template_files() {
|
assert_template_files() {
|
||||||
|
|
@ -318,7 +503,7 @@ run_salt_noop_tests() {
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
require_root
|
require_root
|
||||||
require_debian_ci
|
require_supported_ci_os
|
||||||
run_pytests
|
run_pytests
|
||||||
prepare_harvest_fixture
|
prepare_harvest_fixture
|
||||||
run_ansible_noop_tests
|
run_ansible_noop_tests
|
||||||
|
|
|
||||||
Reference in a new issue