2024-12-28 01:01:05 -05:00
|
|
|
from typing import Callable
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from tests.conftest import Dotfiles
|
|
|
|
|
|
|
|
|
|
|
|
def test_shell_allow_stdout(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify shell command STDOUT works."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{
|
|
|
|
"command": "echo apple",
|
|
|
|
"stdout": True,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
output = capfd.readouterr()
|
2024-12-28 01:01:05 -05:00
|
|
|
assert any(line.startswith("apple") for line in output.out.splitlines()), output
|
2022-04-29 07:13:21 -04:00
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_overrides_1(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that '-vv' overrides the implicit default stdout=False."""
|
|
|
|
|
|
|
|
dotfiles.write_config([{"shell": [{"command": "echo apple"}]}])
|
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
lines = capfd.readouterr().out.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in lines)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_overrides_2(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that '-vv' overrides an explicit stdout=False."""
|
|
|
|
|
|
|
|
dotfiles.write_config([{"shell": [{"command": "echo apple", "stdout": False}]}])
|
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
lines = capfd.readouterr().out.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in lines)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_overrides_3(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that '-vv' overrides an explicit defaults:shell:stdout=False."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{"defaults": {"shell": {"stdout": False}}},
|
|
|
|
{"shell": [{"command": "echo apple"}]},
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_stderr(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that commands can output to STDERR."""
|
|
|
|
|
|
|
|
dotfiles.write_config([{"shell": [{"command": "echo apple >&2"}]}])
|
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
stderr = capfd.readouterr().err.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stderr)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_stderr_with_explicit_stdout_off(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that commands can output to STDERR with STDOUT explicitly off."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{
|
|
|
|
"command": "echo apple >&2",
|
|
|
|
"stdout": False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
stderr = capfd.readouterr().err.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stderr)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_cli_verbosity_stderr_with_defaults_stdout_off(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that commands can output to STDERR with defaults:shell:stdout=False."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"defaults": {
|
|
|
|
"shell": {
|
|
|
|
"stdout": False,
|
|
|
|
},
|
2022-04-29 07:13:21 -04:00
|
|
|
},
|
|
|
|
},
|
2022-04-30 21:42:36 -04:00
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{"command": "echo apple >&2"},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot("-vv")
|
|
|
|
|
|
|
|
stderr = capfd.readouterr().err.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stderr)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_single_v_verbosity_stdout(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that a single '-v' verbosity doesn't override stdout=False."""
|
|
|
|
|
|
|
|
dotfiles.write_config([{"shell": [{"command": "echo apple"}]}])
|
|
|
|
run_dotbot("-v")
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("apple") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_single_v_verbosity_stderr(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that a single '-v' verbosity doesn't override stderr=False."""
|
|
|
|
|
|
|
|
dotfiles.write_config([{"shell": [{"command": "echo apple >&2"}]}])
|
|
|
|
run_dotbot("-v")
|
|
|
|
|
|
|
|
stderr = capfd.readouterr().err.splitlines()
|
|
|
|
assert not any(line.startswith("apple") for line in stderr)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_compact_stdout_1(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that shell command stdout works in compact form."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{"defaults": {"shell": {"stdout": True}}},
|
|
|
|
{"shell": ["echo apple"]},
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_compact_stdout_2(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that shell command stdout works in compact form."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{"defaults": {"shell": {"stdout": True}}},
|
|
|
|
{"shell": [["echo apple", "echoing message"]]},
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert any(line.startswith("apple") for line in stdout)
|
|
|
|
assert any(line.startswith("echoing message") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_stdout_disabled_by_default(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that the shell command disables stdout by default."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": ["echo banana"],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("banana") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_can_override_defaults(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that the shell command can override defaults."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{"defaults": {"shell": {"stdout": True}}},
|
|
|
|
{"shell": [{"command": "echo apple", "stdout": False}]},
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("apple") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_quiet_default(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that quiet is off by default."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{
|
|
|
|
"command": "echo banana",
|
|
|
|
"description": "echoing a thing...",
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("banana") for line in stdout)
|
|
|
|
assert any("echo banana" in line for line in stdout)
|
|
|
|
assert any(line.startswith("echoing a thing...") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_quiet_enabled_with_description(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-04-29 07:13:21 -04:00
|
|
|
"""Verify that only the description is shown when quiet is enabled."""
|
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{
|
|
|
|
"command": "echo banana",
|
|
|
|
"description": "echoing a thing...",
|
|
|
|
"quiet": True,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("banana") for line in stdout)
|
|
|
|
assert not any("echo banana" in line for line in stdout)
|
|
|
|
assert any(line.startswith("echoing a thing...") for line in stdout)
|
|
|
|
|
|
|
|
|
2024-12-28 01:01:05 -05:00
|
|
|
def test_shell_quiet_enabled_without_description(
|
|
|
|
capfd: pytest.CaptureFixture[str], dotfiles: Dotfiles, run_dotbot: Callable[..., None]
|
|
|
|
) -> None:
|
2022-12-16 14:52:33 -05:00
|
|
|
"""Verify nothing is shown when quiet is enabled with no description."""
|
2022-04-29 07:13:21 -04:00
|
|
|
|
2022-04-30 21:42:36 -04:00
|
|
|
dotfiles.write_config(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"shell": [
|
|
|
|
{
|
|
|
|
"command": "echo banana",
|
|
|
|
"quiet": True,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
)
|
2022-04-29 07:13:21 -04:00
|
|
|
run_dotbot()
|
|
|
|
|
|
|
|
stdout = capfd.readouterr().out.splitlines()
|
|
|
|
assert not any(line.startswith("banana") for line in stdout)
|
2022-12-16 14:52:33 -05:00
|
|
|
assert not any(line.startswith("echo banana") for line in stdout)
|