chore: Update salt installation repository #668
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 |