Skip to content

test: add run for smoke test #49

test: add run for smoke test

test: add run for smoke test #49

Workflow file for this run

name: Smoke Test
on:
push:
branches: [ main, trace-* ]
pull_request:
# Manual trigger
workflow_dispatch:
defaults:
run:
shell: 'bash -Eeuo pipefail -x {0}'
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Build
uses: snapcore/action-build@v1
id: snapcraft
with:
snapcraft-args: snap --output docker_${{ github.run_id}}.snap
- name: Upload
uses: actions/upload-artifact@v4
with:
name: docker_${{ github.run_id}}.snap
path: ${{ steps.snapcraft.outputs.snap }}
smoke-test:
needs: build
runs-on: ubuntu-22.04
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: docker_${{ github.run_id }}.snap
- name: Prep
run: |
# https://github.com/actions/runner-images/blob/main/images/linux/Ubuntu2204-Readme.md
# TODO figure out a better way to get Go and friends out of our path than dropping a nuke
sudo rm -rf /opt/hostedtoolcache/*
sudo apt-get purge --auto-remove -y 'docker.*' 'containerd.*' 'moby.*' 'runc.*'
sudo rm -rf /var/lib/docker /etc/docker /run/docker* /var/lib/containerd /run/containerd*
sudo ip link delete docker0 || :
sudo apt update
sudo apt install -y snapd
sudo snap refresh
sudo snap refresh --channel beta snapd
sudo snap list
- name: Install
run: |
sudo snap install --dangerous ./docker_${{ github.run_id }}.snap
# it will immediately be failing to start, so let's head that off as quickly as we can
sudo snap stop --disable docker.dockerd
sudo killall dockerd || :
- name: Connect
run: |
echo '{ "log-level": "debug" }' | sudo tee /var/snap/docker/current/config/daemon.json
# normally, snap does this automatically during install, but not when we install from a local file (for security)
sudo snap connect docker:docker-cli docker:docker-daemon
sudo snap connect docker:firewall-control :firewall-control
sudo snap connect docker:home :home
sudo snap connect docker:network-control :network-control
sudo snap connect docker:support :docker-support
sudo snap connect docker:privileged :docker-support
sudo snap stop --disable docker.dockerd # for good measure
sleep 1
sudo snap start --enable docker.dockerd
sleep 1
sudo snap logs docker.dockerd
- name: Verify
run: |
trap 'ps faux | grep -i docker; sudo systemctl status snap.docker.dockerd.service' ERR
sudo dmesg | tail -n20
sleep 1
sudo snap logs -n=20 docker.dockerd
sleep 1
sudo docker version
sudo docker info
sudo docker buildx version
sudo docker compose version
- name: Save & Load
run: |
docker pull hello-world
docker save hello-world > hello-world.tar
xz -T0 < hello-world.tar > hello-world.txz
docker rmi hello-world
docker load --input hello-world.txz
- name: Hello World
run: sudo docker run --rm hello-world
- name: Hello World (journald)
run: |
trap 'echo "error, sad day ($?)"; sleep 1; sudo snap logs -n=20 docker.dockerd; sleep 1; sudo tail -n20 /var/log/*.log; sudo dmesg | tail -n20; sudo journalctl --no-pager | grep DENIED | grep docker' ERR
expectedOutput="testing-journald-log-driver-$RANDOM-$RANDOM"
sudo docker run --name test-journald --log-driver journald bash -c 'echo "$@"' -- "$expectedOutput"
actualOutput="$(sudo docker logs test-journald)"
[ "$actualOutput" = "$expectedOutput" ]
docker rm test-journald
- name: Hello World (init)
run: sudo docker run --rm --init hello-world
- name: Docker Build
run: |
sudo docker build --pull -t debian-hello - <<'EOF'
FROM debian:buster-slim
RUN set -eux; \
apt-get update; \
apt-get install -y hello; \
rm -rf /var/lib/apt/lists/*
CMD ["hello"]
EOF
sudo docker run --rm debian-hello
sudo docker image rm debian-hello
- name: Docker Build (git)
run: |
sudo docker build --pull -t tianon/gosleep https://github.com/tianon/gosleep.git
sudo docker run --rm tianon/gosleep gosleep --help
sudo docker image rm tianon/gosleep
- name: Docker BuildKit
run: |
trap 'echo "error, sad day ($?)"; sleep 1; sudo snap logs -n=20 docker.dockerd; sleep 1; sudo tail -n20 /var/log/*.log; sudo dmesg | tail -n20; sudo journalctl --no-pager | grep DENIED | grep docker' ERR
sudo DOCKER_BUILDKIT=1 docker build --pull -t debian-hello - <<'EOF'
FROM debian:buster-slim
RUN set -eux; \
apt-get update; \
apt-get install -y hello; \
rm -rf /var/lib/apt/lists/*
CMD ["hello"]
EOF
sudo docker run --rm debian-hello
sudo docker image rm debian-hello
- name: Docker BuildKit (git)
run: |
sudo DOCKER_BUILDKIT=1 docker build --pull -t tianon/gosleep https://github.com/tianon/gosleep.git
sudo docker run --rm tianon/gosleep gosleep --help
sudo docker image rm tianon/gosleep