a-kenji
498d29cca1
This fixes `clan ssh` with the `--json` and `--png` flags. It will now correctly use the actual fields that are present in the generated json. - probes if the ports are accessible - if accessible will attempt a single ssh connection with the provided password, in order to not spam ssh attempts Fixes #1177
142 lines
3.2 KiB
Python
142 lines
3.2 KiB
Python
import os
|
|
import sys
|
|
|
|
import pytest
|
|
import pytest_subprocess.fake_process
|
|
from pytest_subprocess import utils
|
|
|
|
import clan_cli
|
|
from clan_cli.ssh import cli
|
|
|
|
|
|
def test_no_args(
|
|
capsys: pytest.CaptureFixture, monkeypatch: pytest.MonkeyPatch
|
|
) -> None:
|
|
monkeypatch.setattr(sys, "argv", ["", "ssh"])
|
|
with pytest.raises(SystemExit):
|
|
clan_cli.main()
|
|
captured = capsys.readouterr()
|
|
assert captured.err.startswith("usage:")
|
|
|
|
|
|
# using fp fixture from pytest-subprocess
|
|
def test_ssh_no_pass(
|
|
fp: pytest_subprocess.fake_process.FakeProcess, monkeypatch: pytest.MonkeyPatch
|
|
) -> None:
|
|
host = "somehost"
|
|
user = "user"
|
|
if os.environ.get("IN_NIX_SANDBOX"):
|
|
monkeypatch.delenv("IN_NIX_SANDBOX")
|
|
cmd: list[str | utils.Any] = [
|
|
"nix",
|
|
fp.any(),
|
|
"shell",
|
|
fp.any(),
|
|
"-c",
|
|
"ssh",
|
|
"-o",
|
|
"UserKnownHostsFile=/dev/null",
|
|
"-o",
|
|
"StrictHostKeyChecking=no",
|
|
f"{user}@{host}",
|
|
fp.any(),
|
|
]
|
|
fp.register(cmd)
|
|
cli.ssh(
|
|
host=host,
|
|
user=user,
|
|
)
|
|
assert fp.call_count(cmd) == 1
|
|
|
|
|
|
def test_ssh_with_pass(
|
|
fp: pytest_subprocess.fake_process.FakeProcess, monkeypatch: pytest.MonkeyPatch
|
|
) -> None:
|
|
host = "somehost"
|
|
user = "user"
|
|
if os.environ.get("IN_NIX_SANDBOX"):
|
|
monkeypatch.delenv("IN_NIX_SANDBOX")
|
|
cmd: list[str | utils.Any] = [
|
|
"nix",
|
|
fp.any(),
|
|
"shell",
|
|
fp.any(),
|
|
"-c",
|
|
"sshpass",
|
|
"-p",
|
|
fp.any(),
|
|
]
|
|
fp.register(cmd)
|
|
cli.ssh(
|
|
host=host,
|
|
user=user,
|
|
password="XXX",
|
|
)
|
|
assert fp.call_count(cmd) == 1
|
|
|
|
|
|
def test_ssh_no_pass_with_torify(
|
|
fp: pytest_subprocess.fake_process.FakeProcess, monkeypatch: pytest.MonkeyPatch
|
|
) -> None:
|
|
host = "somehost"
|
|
user = "user"
|
|
if os.environ.get("IN_NIX_SANDBOX"):
|
|
monkeypatch.delenv("IN_NIX_SANDBOX")
|
|
cmd: list[str | utils.Any] = [
|
|
"nix",
|
|
fp.any(),
|
|
"shell",
|
|
fp.any(),
|
|
"-c",
|
|
"torify",
|
|
"ssh",
|
|
"-o",
|
|
"UserKnownHostsFile=/dev/null",
|
|
"-o",
|
|
"StrictHostKeyChecking=no",
|
|
f"{user}@{host}",
|
|
fp.any(),
|
|
]
|
|
fp.register(cmd)
|
|
cli.ssh(
|
|
host=host,
|
|
user=user,
|
|
torify=True,
|
|
)
|
|
assert fp.call_count(cmd) == 1
|
|
|
|
|
|
def test_ssh_with_pass_with_torify(
|
|
fp: pytest_subprocess.fake_process.FakeProcess, monkeypatch: pytest.MonkeyPatch
|
|
) -> None:
|
|
host = "somehost"
|
|
user = "user"
|
|
if os.environ.get("IN_NIX_SANDBOX"):
|
|
monkeypatch.delenv("IN_NIX_SANDBOX")
|
|
cmd: list[str | utils.Any] = [
|
|
"nix",
|
|
fp.any(),
|
|
"shell",
|
|
fp.any(),
|
|
"-c",
|
|
"torify",
|
|
"sshpass",
|
|
"-p",
|
|
fp.any(),
|
|
]
|
|
fp.register(cmd)
|
|
cli.ssh(
|
|
host=host,
|
|
user=user,
|
|
password="XXX",
|
|
torify=True,
|
|
)
|
|
assert fp.call_count(cmd) == 1
|
|
|
|
|
|
def test_qrcode_scan(fp: pytest_subprocess.fake_process.FakeProcess) -> None:
|
|
cmd: list[str | utils.Any] = [fp.any()]
|
|
fp.register(cmd, stdout="https://test.test")
|
|
result = cli.qrcode_scan("test.png")
|
|
assert result == "https://test.test"
|