Skip to content

feat: Install salt-minion for tests using bootstrap-salt #663

feat: Install salt-minion for tests using bootstrap-salt

feat: Install salt-minion for tests using bootstrap-salt #663

Workflow file for this run

name: Build and test Docker image
on:
pull_request:
branches:
- main
paths-ignore:
- "./**/*.md"
- "docs/"
- "social/"
- ".editorconfig"
- ".gitignore"
- ".shellcheckrc"
- "compose.yml"
- "LICENSE"
- "Makefile"
env:
IMAGE_NAME: localhost:5000/${{ github.repository }}:${{ github.sha }}
REGISTRY_PATH: ${{ github.workspace }}/registry
jobs:
build:
name: Build
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
with:
driver-opts: network=host
- name: Start Docker registry
run: |
docker run --rm --detach --publish 5000:5000 \
--volume ${REGISTRY_PATH}:/var/lib/registry \
--name registry registry:2
- name: Build docker-salt-master image
uses: docker/[email protected]
with:
context: .
file: ./Dockerfile
platforms: linux/amd64,linux/arm64
outputs: |
type=image,annotation-index.org.opencontainers.image.description=salt-master latest containerized
cache-from: type=gha
cache-to: type=gha,mode=max
pull: true
push: true
tags: ${{ env.IMAGE_NAME }}
- name: Stop Docker registry
run: docker stop registry
- name: Upload Docker registry data for testing
uses: actions/upload-artifact@v4
with:
name: docker-registry-data
path: ${{ env.REGISTRY_PATH }}/
test:
name: Test
runs-on: ubuntu-latest
needs: build
strategy:
matrix:
platform:
- linux/amd64
- linux/arm64
env:
DOCKER_CLI_EXPERIMENTAL: enabled
PLATFORM: ${{ matrix.platform }}
BOOTUP_WAIT_SECONDS: ${{ matrix.platform == 'linux/amd64' && 30 || 90 }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Download Docker registry data from build job
uses: actions/download-artifact@v4
with:
name: docker-registry-data
path: ${{ env.REGISTRY_PATH }}
- name: Enable Docker experimental
run: |
# Enable docker daemon experimental support.
echo '{"experimental": true}' | sudo tee /etc/docker/daemon.json
sudo systemctl restart docker
# Install QEMU multi-architecture support for docker buildx.
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
- name: Start Docker registry
run: |
docker run --rm --detach --publish 5000:5000 \
--volume ${REGISTRY_PATH}:/var/lib/registry \
--name registry registry:2
sleep 10
- name: Import Docker images
run: docker pull --platform ${{ env.PLATFORM }} ${IMAGE_NAME}
- name: Docker inspect
run: docker buildx imagetools inspect ${IMAGE_NAME} | grep '${{ env.PLATFORM }}'
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: "3.10"
- name: Install and configure salt-minion
run: |
# Install salt-minion from salt repos
curl -o bootstrap-salt.sh -L https://bootstrap.saltproject.io/bootstrap-salt.sh
sudo sh bootstrap-salt.sh -dXP stable
sudo systemctl stop salt-minion
sudo systemctl disable salt-minion
sudo rm -f /var/log/salt/minion
- name: Install tests utils
run: |
sudo apt-get update
sudo apt-get install -y jq
- name: Execute basic tests
if: always()
run: tests/basic/test.sh
- name: Execute keys mount point tests
if: always()
run: tests/keys-mount-point/test.sh
- name: Execute healthcheck tests
if: always()
run: tests/healthcheck/test.sh
- name: Execute salt-api tests
if: always()
run: tests/salt-api/test.sh
- name: Execute salt-minion tests
if: always()
run: tests/salt-minion/test.sh
- name: Execute gitfs tests
if: always()
env:
GITFS_KEYS_DIR: tests/gitfs/data/keys/gitfs
SSH_PRIVATE_KEY: ${{ secrets.TESTS_REPO_PRIVATE_KEY }}
SSH_PUBLIC_KEY: ${{ secrets.TESTS_REPO_PUBLIC_KEY }}
run: |
mkdir -p "${GITFS_KEYS_DIR}"
echo "${SSH_PRIVATE_KEY}" | base64 -d > "${GITFS_KEYS_DIR}"/gitfs_ssh
chmod 600 "${GITFS_KEYS_DIR}"/gitfs_ssh
echo "${SSH_PUBLIC_KEY}" | base64 -d > "${GITFS_KEYS_DIR}"/gitfs_ssh.pub
chmod 644 "${GITFS_KEYS_DIR}"/gitfs_ssh.pub
tests/gitfs/test.sh
- name: Execute config-reloader tests
if: always()
run: tests/config-reloader/test.sh
- name: Execute GPG tests
if: always()
run: tests/gpg/test.sh
- name: Python Extra Packages tests
if: always()
run: tests/python-extra-packages/test.sh
- name: Cleanup
if: always()
run: |
docker rm --force registry