Tests: Fix test_welcome_practice #1782
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: Integration Test | |
on: | |
pull_request: | |
push: | |
branches: | |
- master | |
schedule: | |
- cron: '42 06 * * *' | |
jobs: | |
test: | |
name: Integration Test | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
steps: | |
- name: Host information | |
run: | | |
echo "::group::Host information" | |
echo "Hostname: $(hostname)" | |
echo "IP: $(hostname -I)" | |
echo "::endgroup::" | |
echo "::group::Filesystem" | |
df -h | |
echo "::endgroup::" | |
echo "::group::Memory" | |
free -h | |
echo "::endgroup::" | |
echo "::group::CPU" | |
lscpu | |
echo "::endgroup::" | |
- uses: actions/checkout@v4 | |
- uses: docker/setup-buildx-action@v3 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: '3.10' | |
cache: 'pip' | |
- name: Setup firefox | |
uses: browser-actions/setup-firefox@latest | |
- name: Install test dependencies | |
run: | | |
pip install \ | |
pytest \ | |
pytest-dependency \ | |
pytest-github-actions-annotate-failures \ | |
requests \ | |
selenium | |
- name: Make docker cache dir owned by our user | |
run: | | |
sudo chown $USER:$USER /mnt | |
- name: Restore docker data cache | |
if: github.event_name != 'schedule' | |
uses: actions/cache/restore@v4 | |
with: | |
path: | | |
/mnt/data-docker.tar.gz | |
key: docker-data-${{ runner.os }}-${{ github.run_id }} | |
restore-keys: | | |
docker-data-${{ runner.os }}- | |
# TEMP: Disable for now, cache holds bad docker network state | |
# - name: Unpack docker data cache | |
# if: github.event_name != 'schedule' | |
# run: | | |
# if [ -f /mnt/data-docker.tar.gz ]; then | |
# mkdir -p /mnt/dojo-test-data | |
# sudo tar --use-compress-program=pigz -xf /mnt/data-docker.tar.gz -C /mnt/dojo-test-data | |
# fi | |
- name: Build docker image | |
if: github.event_name != 'schedule' | |
uses: docker/build-push-action@v5 | |
with: | |
context: . | |
tags: pwncollege/dojo:test | |
load: true | |
cache-from: type=gha | |
- name: Build and cache docker image | |
if: github.event_name == 'schedule' | |
uses: docker/build-push-action@v5 | |
with: | |
context: . | |
tags: pwncollege/dojo:test | |
load: true | |
cache-to: type=gha | |
- name: Run dojo | |
run: | | |
docker run \ | |
--name dojo-test \ | |
--privileged \ | |
--detach \ | |
--rm \ | |
-v "/mnt/dojo-test-data:/data:shared" \ | |
-p 2222:22 -p 80:80 -p 443:443 \ | |
pwncollege/dojo:test | |
- name: Build and start services | |
run: | | |
docker exec dojo-test dojo wait || (docker exec dojo-test dojo compose logs && false) | |
docker exec dojo-test docker tag pwncollege-challenge pwncollege/challenge-legacy:latest | |
docker exec dojo-test docker image ls | |
- name: Wait for services to start | |
timeout-minutes: 3 | |
run: | | |
docker exec dojo-test dojo compose logs -f & | |
log_pid=$! | |
until [[ "$(docker exec dojo-test docker inspect --format='{{.State.Health.Status}}' ctfd)" == "healthy" ]]; do | |
sleep 1 | |
done | |
kill $log_pid | |
exit 0 | |
- name: Run tests | |
timeout-minutes: 4 | |
run: | | |
export MOZ_HEADLESS=1 | |
timeout 3m pytest -vrpP --durations=0 ./test || (docker exec dojo-test dojo compose logs && false) | |
- name: Pack docker data cache | |
if: github.event_name == 'schedule' | |
run: | | |
docker exec dojo-test dojo compose down | |
sudo tar --use-compress-program=pigz -cf /mnt/data-docker.tar.gz -C /mnt/dojo-test-data ./docker | |
- name: Save docker data cache | |
if: github.event_name == 'schedule' | |
uses: actions/cache/save@v4 | |
with: | |
path: | | |
/mnt/data-docker.tar.gz | |
key: docker-data-${{ runner.os }}-${{ github.run_id }} | |
- name: Final filesystem information | |
run: | | |
echo "::group::Filesystem" | |
df -h | |
echo "::endgroup::" |