impure-tests: migrate bash to pytest and fix stuff

This commit is contained in:
DavHau
2023-09-22 18:32:09 +02:00
parent f6398c85bb
commit 9825c179a8
5 changed files with 57 additions and 76 deletions

View File

@@ -0,0 +1,31 @@
import json
import subprocess
from pathlib import Path
import pytest
from cli import Cli
@pytest.mark.impure
def test_basics(
monkeypatch: pytest.MonkeyPatch, temporary_dir: Path, capsys: pytest.CaptureFixture
) -> None:
monkeypatch.chdir(temporary_dir)
cli = Cli()
cli.run(["create"])
assert (temporary_dir / ".clan-flake").exists()
cli.run(["machines", "create", "machine1"])
capsys.readouterr() # flush cache
cli.run(["machines", "list"])
assert "machine1" in capsys.readouterr().out
flake_show = subprocess.run(
["nix", "flake", "show", "--json"],
check=True,
capture_output=True,
text=True,
)
flake_outputs = json.loads(flake_show.stdout)
try:
flake_outputs["nixosConfigurations"]["machine1"]
except KeyError:
pytest.fail("nixosConfigurations.machine1 not found in flake outputs")

View File

@@ -106,7 +106,10 @@ exec {bash} -l "${{@}}"
@pytest.fixture
def sshd(
sshd_config: SshdConfig, command: "Command", unused_tcp_port: "PortFunction"
sshd_config: SshdConfig,
command: "Command",
unused_tcp_port: "PortFunction",
monkeypatch: pytest.MonkeyPatch,
) -> Iterator[Sshd]:
import subprocess
@@ -121,7 +124,7 @@ def sshd(
proc = command.run(
[sshd, "-f", str(sshd_config.path), "-D", "-p", str(port)], extra_env=env
)
monkeypatch.delenv("SSH_AUTH_SOCK", raising=False)
while True:
print(sshd_config.path)
if (