This fixture itself uses the 'use_old_replica_state' fixture, so that it's no longer needed to use it explicitly in test functions.
163 lines
4.4 KiB
Python
163 lines
4.4 KiB
Python
import nagiosplugin
|
|
from click.testing import CliRunner
|
|
|
|
from check_patroni.cli import main
|
|
|
|
from .tools import here
|
|
|
|
|
|
def test_node_tl_has_changed_ok_with_timeline(fake_restapi) -> None:
|
|
runner = CliRunner()
|
|
|
|
fake_restapi("node_tl_has_changed")
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--timeline",
|
|
"58",
|
|
],
|
|
)
|
|
assert result.exit_code == 0
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED OK - The timeline is still 58. | is_timeline_changed=0;;@1:1 timeline=58\n"
|
|
)
|
|
|
|
|
|
def test_node_tl_has_changed_ok_with_state_file(fake_restapi) -> None:
|
|
runner = CliRunner()
|
|
|
|
with open(here / "node_tl_has_changed.state_file", "w") as f:
|
|
f.write('{"timeline": 58}')
|
|
|
|
fake_restapi("node_tl_has_changed")
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--state-file",
|
|
str(here / "node_tl_has_changed.state_file"),
|
|
],
|
|
)
|
|
assert result.exit_code == 0
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED OK - The timeline is still 58. | is_timeline_changed=0;;@1:1 timeline=58\n"
|
|
)
|
|
|
|
|
|
def test_node_tl_has_changed_ko_with_timeline(fake_restapi) -> None:
|
|
runner = CliRunner()
|
|
|
|
fake_restapi("node_tl_has_changed")
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--timeline",
|
|
"700",
|
|
],
|
|
)
|
|
assert result.exit_code == 2
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED CRITICAL - The expected timeline was 700 got 58. | is_timeline_changed=1;;@1:1 timeline=58\n"
|
|
)
|
|
|
|
|
|
def test_node_tl_has_changed_ko_with_state_file_and_save(fake_restapi) -> None:
|
|
runner = CliRunner()
|
|
|
|
with open(here / "node_tl_has_changed.state_file", "w") as f:
|
|
f.write('{"timeline": 700}')
|
|
|
|
fake_restapi("node_tl_has_changed")
|
|
# test without saving the new tl
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--state-file",
|
|
str(here / "node_tl_has_changed.state_file"),
|
|
],
|
|
)
|
|
assert result.exit_code == 2
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED CRITICAL - The expected timeline was 700 got 58. | is_timeline_changed=1;;@1:1 timeline=58\n"
|
|
)
|
|
|
|
cookie = nagiosplugin.Cookie(here / "node_tl_has_changed.state_file")
|
|
cookie.open()
|
|
new_tl = cookie.get("timeline")
|
|
cookie.close()
|
|
|
|
assert new_tl == 700
|
|
|
|
# test when we save the hash
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--state-file",
|
|
str(here / "node_tl_has_changed.state_file"),
|
|
"--save",
|
|
],
|
|
)
|
|
assert result.exit_code == 2
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED CRITICAL - The expected timeline was 700 got 58. | is_timeline_changed=1;;@1:1 timeline=58\n"
|
|
)
|
|
|
|
cookie = nagiosplugin.Cookie(here / "node_tl_has_changed.state_file")
|
|
cookie.open()
|
|
new_tl = cookie.get("timeline")
|
|
cookie.close()
|
|
|
|
assert new_tl == 58
|
|
|
|
|
|
def test_node_tl_has_changed_params(fake_restapi) -> None:
|
|
# This one is placed last because it seems like the exceptions are not flushed from stderr for the next tests.
|
|
runner = CliRunner()
|
|
|
|
fake_restapi("node_tl_has_changed")
|
|
result = runner.invoke(
|
|
main,
|
|
[
|
|
"-e",
|
|
"https://10.20.199.3:8008",
|
|
"node_tl_has_changed",
|
|
"--timeline",
|
|
"58",
|
|
"--state-file",
|
|
str(here / "fake_file_name.state_file"),
|
|
],
|
|
)
|
|
assert result.exit_code == 3
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED UNKNOWN: click.exceptions.UsageError: Either --timeline or --state-file should be provided for this service\n"
|
|
)
|
|
|
|
result = runner.invoke(
|
|
main, ["-e", "https://10.20.199.3:8008", "node_tl_has_changed"]
|
|
)
|
|
assert result.exit_code == 3
|
|
assert (
|
|
result.stdout
|
|
== "NODETLHASCHANGED UNKNOWN: click.exceptions.UsageError: Either --timeline or --state-file should be provided for this service\n"
|
|
)
|