impure-tests: migrate bash to pytest and fix stuff
This commit is contained in:
parent
f6398c85bb
commit
9825c179a8
@ -1,75 +1,19 @@
|
|||||||
{ self, ... }: {
|
{ ... }: {
|
||||||
perSystem = { pkgs, lib, self', ... }:
|
perSystem = { pkgs, lib, ... }: {
|
||||||
let
|
packages = {
|
||||||
impureChecks = {
|
# a script that executes all other checks
|
||||||
clan-pytest-impure = pkgs.writeShellScriptBin "clan-pytest-impure" ''
|
impure-checks = pkgs.writeShellScriptBin "impure-checks" ''
|
||||||
#!${pkgs.bash}/bin/bash
|
#!${pkgs.bash}/bin/bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
export PATH="${lib.makeBinPath [
|
export PATH="${lib.makeBinPath [
|
||||||
pkgs.gitMinimal
|
pkgs.gitMinimal
|
||||||
pkgs.nix
|
pkgs.nix
|
||||||
]}"
|
]}"
|
||||||
ROOT=$(git rev-parse --show-toplevel)
|
ROOT=$(git rev-parse --show-toplevel)
|
||||||
cd "$ROOT/pkgs/clan-cli"
|
cd "$ROOT/pkgs/clan-cli"
|
||||||
nix develop "$ROOT#clan-cli" -c bash -c 'TMPDIR=/tmp python -m pytest -m impure -s ./tests'
|
nix develop "$ROOT#clan-cli" -c bash -c 'TMPDIR=/tmp python -m pytest -m impure -s ./tests'
|
||||||
'';
|
'';
|
||||||
check-clan-template = pkgs.writeShellScriptBin "check-clan-template" ''
|
|
||||||
#!${pkgs.bash}/bin/bash
|
|
||||||
set -euox pipefail
|
|
||||||
|
|
||||||
export CLANTMP=$(${pkgs.coreutils}/bin/mktemp -d)
|
|
||||||
trap "${pkgs.coreutils}/bin/chmod -R +w '$CLANTMP'; ${pkgs.coreutils}/bin/rm -rf '$CLANTMP'" EXIT
|
|
||||||
|
|
||||||
export PATH="${lib.makeBinPath [
|
|
||||||
pkgs.coreutils
|
|
||||||
pkgs.curl
|
|
||||||
pkgs.gitMinimal
|
|
||||||
pkgs.gnugrep
|
|
||||||
pkgs.jq
|
|
||||||
pkgs.openssh
|
|
||||||
pkgs.nix
|
|
||||||
self'.packages.clan-cli
|
|
||||||
]}"
|
|
||||||
|
|
||||||
cd $CLANTMP
|
|
||||||
|
|
||||||
echo initialize new clan
|
|
||||||
nix flake init -t ${self}#new-clan
|
|
||||||
|
|
||||||
echo override clan input to the current version
|
|
||||||
nix flake lock --override-input clan-core ${self}
|
|
||||||
nix flake lock --override-input nixpkgs ${self.inputs.nixpkgs}
|
|
||||||
|
|
||||||
echo ensure flake outputs can be listed
|
|
||||||
nix flake show
|
|
||||||
|
|
||||||
echo create a machine
|
|
||||||
clan machines create machine1
|
|
||||||
|
|
||||||
echo check machine1 exists
|
|
||||||
clan machines list | grep -q machine1
|
|
||||||
|
|
||||||
echo check machine1 appears in nixosConfigurations
|
|
||||||
nix flake show --json | jq '.nixosConfigurations' | grep -q machine1
|
|
||||||
|
|
||||||
echo check machine1 jsonschema can be evaluated
|
|
||||||
nix eval .#nixosConfigurations.machine1.config.clanSchema
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
in
|
|
||||||
{
|
|
||||||
packages =
|
|
||||||
impureChecks // {
|
|
||||||
# a script that executes all other checks
|
|
||||||
impure-checks = pkgs.writeShellScriptBin "impure-checks" ''
|
|
||||||
#!${pkgs.bash}/bin/bash
|
|
||||||
set -euo pipefail
|
|
||||||
${lib.concatMapStringsSep "\n" (name: ''
|
|
||||||
echo -e "\n\nrunning check ${name}\n"
|
|
||||||
${impureChecks.${name}}/bin/* "$@"
|
|
||||||
'') (lib.attrNames impureChecks)}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -6,6 +6,8 @@ from pathlib import Path
|
|||||||
from tempfile import TemporaryDirectory
|
from tempfile import TemporaryDirectory
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
|
from clan_cli.nix import nix_shell
|
||||||
|
|
||||||
from ..dirs import get_clan_flake_toplevel
|
from ..dirs import get_clan_flake_toplevel
|
||||||
from ..errors import ClanError
|
from ..errors import ClanError
|
||||||
from ..ssh import parse_deployment_address
|
from ..ssh import parse_deployment_address
|
||||||
@ -47,7 +49,8 @@ secrets={shlex.quote(str(secrets_dir))}
|
|||||||
{generator}
|
{generator}
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
subprocess.run(["bash", "-c", text], check=True)
|
cmd = nix_shell(["bash"], ["bash", "-c", text])
|
||||||
|
subprocess.run(cmd, check=True)
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
msg = "failed to the following command:\n"
|
msg = "failed to the following command:\n"
|
||||||
msg += text
|
msg += text
|
||||||
|
@ -32,6 +32,6 @@ mkShell {
|
|||||||
register-python-argcomplete --shell fish clan > $tmp_path/share/fish/vendor_completions.d/clan.fish
|
register-python-argcomplete --shell fish clan > $tmp_path/share/fish/vendor_completions.d/clan.fish
|
||||||
register-python-argcomplete --shell bash clan > $tmp_path/share/bash-completion/completions/clan
|
register-python-argcomplete --shell bash clan > $tmp_path/share/bash-completion/completions/clan
|
||||||
|
|
||||||
${clan-cli}/bin/clan machines create example
|
./bin/clan machines create example
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
31
pkgs/clan-cli/tests/end_to_end/test_basics.py
Normal file
31
pkgs/clan-cli/tests/end_to_end/test_basics.py
Normal 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")
|
@ -106,7 +106,10 @@ exec {bash} -l "${{@}}"
|
|||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def sshd(
|
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]:
|
) -> Iterator[Sshd]:
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
@ -121,7 +124,7 @@ def sshd(
|
|||||||
proc = command.run(
|
proc = command.run(
|
||||||
[sshd, "-f", str(sshd_config.path), "-D", "-p", str(port)], extra_env=env
|
[sshd, "-f", str(sshd_config.path), "-D", "-p", str(port)], extra_env=env
|
||||||
)
|
)
|
||||||
|
monkeypatch.delenv("SSH_AUTH_SOCK", raising=False)
|
||||||
while True:
|
while True:
|
||||||
print(sshd_config.path)
|
print(sshd_config.path)
|
||||||
if (
|
if (
|
||||||
|
Loading…
Reference in New Issue
Block a user