2023-08-23 17:40:46 +02:00
|
|
|
from click.testing import CliRunner
|
|
|
|
|
|
|
|
from check_patroni.cli import main
|
|
|
|
|
|
|
|
|
2023-09-28 09:41:33 +02:00
|
|
|
def test_node_is_leader_ok(runner: CliRunner, fake_restapi) -> None:
|
2023-09-28 10:57:24 +02:00
|
|
|
fake_restapi("node_is_leader_ok")
|
2023-08-23 17:40:46 +02:00
|
|
|
result = runner.invoke(main, ["-e", "https://10.20.199.3:8008", "node_is_leader"])
|
|
|
|
assert result.exit_code == 0
|
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "NODEISLEADER OK - This node is a leader node. | is_leader=1;;@0\n"
|
|
|
|
)
|
|
|
|
|
2023-09-28 10:57:24 +02:00
|
|
|
fake_restapi("node_is_leader_ok_standby_leader")
|
2023-08-23 17:40:46 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
["-e", "https://10.20.199.3:8008", "node_is_leader", "--is-standby-leader"],
|
|
|
|
)
|
|
|
|
print(result.stdout)
|
|
|
|
assert result.exit_code == 0
|
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "NODEISLEADER OK - This node is a standby leader node. | is_leader=1;;@0\n"
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2023-09-28 09:41:33 +02:00
|
|
|
def test_node_is_leader_ko(runner: CliRunner, fake_restapi) -> None:
|
2023-09-28 10:57:24 +02:00
|
|
|
fake_restapi("node_is_leader_ko", status=503)
|
2023-08-23 17:40:46 +02:00
|
|
|
result = runner.invoke(main, ["-e", "https://10.20.199.3:8008", "node_is_leader"])
|
|
|
|
assert result.exit_code == 2
|
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "NODEISLEADER CRITICAL - This node is not a leader node. | is_leader=0;;@0\n"
|
|
|
|
)
|
|
|
|
|
2023-09-28 10:57:24 +02:00
|
|
|
fake_restapi("node_is_leader_ko_standby_leader", status=503)
|
2023-08-23 17:40:46 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
["-e", "https://10.20.199.3:8008", "node_is_leader", "--is-standby-leader"],
|
|
|
|
)
|
|
|
|
assert result.exit_code == 2
|
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "NODEISLEADER CRITICAL - This node is not a standby leader node. | is_leader=0;;@0\n"
|
|
|
|
)
|