Files
clan-core/pkgs/clan-cli/tests/test_vms_api.py
2023-10-03 11:51:31 +02:00

91 lines
2.8 KiB
Python

import os
from pathlib import Path
import pytest
from api import TestClient
from httpx import SyncByteStream
def is_running_in_ci() -> bool:
# Check if pytest is running in GitHub Actions
if os.getenv("GITHUB_ACTIONS") == "true":
print("Running on GitHub Actions")
return True
# Check if pytest is running in Travis CI
if os.getenv("TRAVIS") == "true":
print("Running on Travis CI")
return True
# Check if pytest is running in Circle CI
if os.getenv("CIRCLECI") == "true":
print("Running on Circle CI")
return True
return False
@pytest.mark.impure
def test_inspect(api: TestClient, test_flake_with_core: Path) -> None:
response = api.post(
"/api/vms/inspect",
json=dict(flake_url=str(test_flake_with_core), flake_attr="vm1"),
)
assert response.status_code == 200, "Failed to inspect vm"
config = response.json()["config"]
assert config.get("flake_attr") == "vm1"
assert config.get("cores") == 1
assert config.get("memory_size") == 1024
assert config.get("graphics") is True
def test_incorrect_uuid(api: TestClient) -> None:
uuid_endpoints = [
"/api/vms/{}/status",
"/api/vms/{}/logs",
]
for endpoint in uuid_endpoints:
response = api.get(endpoint.format("1234"))
assert response.status_code == 422, "Failed to get vm status"
@pytest.mark.impure
def test_create(api: TestClient, test_flake_with_core: Path) -> None:
if is_running_in_ci():
pytest.skip("Skipping test in CI. As it requires KVM")
print(f"flake_url: {test_flake_with_core} ")
response = api.post(
"/api/vms/create",
json=dict(
flake_url=str(test_flake_with_core),
flake_attr="vm1",
cores=1,
memory_size=1024,
graphics=True,
),
)
assert response.status_code == 200, "Failed to create vm"
uuid = response.json()["uuid"]
assert len(uuid) == 36
assert uuid.count("-") == 4
response = api.get(f"/api/vms/{uuid}/status")
assert response.status_code == 200, "Failed to get vm status"
response = api.get(f"/api/vms/{uuid}/logs")
print("=========VM LOGS==========")
assert isinstance(response.stream, SyncByteStream)
for line in response.stream:
assert line != b"", "Failed to get vm logs"
print(line.decode("utf-8"))
print("=========END LOGS==========")
assert response.status_code == 200, "Failed to get vm logs"
response = api.get(f"/api/vms/{uuid}/status")
assert response.status_code == 200, "Failed to get vm status"
returncodes = response.json()["returncode"]
assert response.json()["running"] is False, "VM is still running. Should be stopped"
for exit_code in returncodes:
assert exit_code == 0, "One VM failed with exit code != 0"