diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 3841f0300..1a25c8037 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -76,3 +76,26 @@ jobs: # XDG_RUNTIME_DIR is set. # TODO: figure out what exactly podman needs sudo -E XDG_RUNTIME_DIR= pytest-3 -s -vv + + integration-macos: + name: "Integration macos" + runs-on: macos-latest + steps: + - uses: actions/checkout@v4 + with: + ref: ${{ github.event.pull_request.head.sha }} + - name: Setup up python + uses: actions/setup-python@v4 + - name: Setup up podman + run: | + brew install podman + podman machine init + podman machine start + # debug only + podman info + - name: Install test dependencies + run: | + sudo pip install pytest flake8 + - name: Run tests + run: | + sudo pytest -s -vv diff --git a/test/test_smoke.py b/test/test_smoke.py index 1f6cb6fbe..4ba5b9c88 100644 --- a/test/test_smoke.py +++ b/test/test_smoke.py @@ -2,6 +2,7 @@ import os import pathlib import subprocess +import tempfile import pytest @@ -10,10 +11,17 @@ @pytest.fixture(name="output_path") -def output_path_fixture(tmp_path): - output_path = tmp_path / "output" - output_path.mkdir(exist_ok=True) - return output_path +def output_path_fixture(): + # pytest tmp_path cannot be used here because: + # a) on macOS its put under /private/tmp/pytest and then writing + # the output file will not work + # b) on fedora its put under /tmp which is a tmpfs but the generated + # image is relatively big (600mb) + with tempfile.TemporaryDirectory(dir="/var/tmp") as tmp_dir: + tmp_path = pathlib.Path(tmp_dir) + output_path = tmp_path / "output" + output_path.mkdir(exist_ok=True) + yield tmp_path @pytest.fixture(name="config_json") @@ -36,16 +44,22 @@ def config_json_fixture(output_path): return config_json_path +@pytest.fixture(name="journal_cursor") +def journal_cursor_fixture(): + if not testutil.has_executable("journalctl"): + return None + return testutil.journal_cursor() + + @pytest.mark.skipif(os.getuid() != 0, reason="needs root") @pytest.mark.skipif(not testutil.has_executable("podman"), reason="need podman") -def test_smoke(output_path, config_json): +def test_smoke(output_path, journal_cursor, config_json): # build local container subprocess.check_call([ "podman", "build", "-f", "Containerfile", "-t", "osbuild-deploy-container-test", ]) - cursor = testutil.journal_cursor() # and run container to deploy an image into output/disk.qcow2 subprocess.check_call([ "podman", "run", "--rm", @@ -59,8 +73,9 @@ def test_smoke(output_path, config_json): # check that there are no denials # TODO: actually check this once https://github.com/osbuild/images/pull/287 # is merged - journal_output = testutil.journal_after_cursor(cursor) - assert journal_output != "" + if journal_cursor: + journal_output = testutil.journal_after_cursor(journal_cursor) + assert journal_output != "" generated_img = pathlib.Path(output_path) / "qcow2/disk.qcow2" assert generated_img.exists(), f"output file missing, dir content: {os.listdir(os.fspath(output_path))}" # TODO: boot and do basic checks, see