2022-02-07 15:11:05 +01:00
|
|
|
from click.testing import CliRunner
|
2023-03-20 11:44:19 +01:00
|
|
|
from pytest_mock import MockerFixture
|
2021-08-11 19:09:14 +02:00
|
|
|
|
2022-02-07 15:11:05 +01:00
|
|
|
from check_patroni.cli import main
|
2023-03-20 11:44:19 +01:00
|
|
|
|
|
|
|
from .tools import my_mock
|
2021-08-11 19:09:14 +02:00
|
|
|
|
|
|
|
|
|
|
|
# TODO Lag threshold tests
|
2023-08-22 11:08:38 +02:00
|
|
|
def test_cluster_has_relica_ok(
|
|
|
|
mocker: MockerFixture, use_old_replica_state: bool
|
|
|
|
) -> None:
|
2021-08-11 19:09:14 +02:00
|
|
|
runner = CliRunner()
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
my_mock(mocker, "cluster_has_replica_ok", 200, use_old_replica_state)
|
2021-08-11 19:09:14 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main, ["-e", "https://10.20.199.3:8008", "cluster_has_replica"]
|
|
|
|
)
|
|
|
|
assert result.exit_code == 0
|
2023-08-22 11:08:38 +02:00
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "CLUSTERHASREPLICA OK - healthy_replica is 2 | healthy_replica=2 srv2_lag=0 srv3_lag=0 unhealthy_replica=0\n"
|
|
|
|
)
|
2021-08-11 19:09:14 +02:00
|
|
|
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
def test_cluster_has_replica_ok_with_count_thresholds(
|
|
|
|
mocker: MockerFixture, use_old_replica_state: bool
|
|
|
|
) -> None:
|
2021-08-11 19:09:14 +02:00
|
|
|
runner = CliRunner()
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
my_mock(mocker, "cluster_has_replica_ok", 200, use_old_replica_state)
|
2021-08-13 11:00:43 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
[
|
|
|
|
"-e",
|
|
|
|
"https://10.20.199.3:8008",
|
|
|
|
"cluster_has_replica",
|
|
|
|
"--warning",
|
|
|
|
"@1",
|
|
|
|
"--critical",
|
|
|
|
"@0",
|
|
|
|
],
|
|
|
|
)
|
|
|
|
assert result.exit_code == 0
|
2023-08-22 11:08:38 +02:00
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "CLUSTERHASREPLICA OK - healthy_replica is 2 | healthy_replica=2;@1;@0 srv2_lag=0 srv3_lag=0 unhealthy_replica=0\n"
|
|
|
|
)
|
2021-08-13 11:00:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_cluster_has_replica_ok_with_count_thresholds_lag(
|
|
|
|
mocker: MockerFixture,
|
2023-08-22 11:08:38 +02:00
|
|
|
use_old_replica_state: bool,
|
2021-08-13 11:00:43 +02:00
|
|
|
) -> None:
|
|
|
|
runner = CliRunner()
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
my_mock(mocker, "cluster_has_replica_ok_lag", 200, use_old_replica_state)
|
2021-08-13 11:00:43 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
[
|
|
|
|
"-e",
|
|
|
|
"https://10.20.199.3:8008",
|
|
|
|
"cluster_has_replica",
|
|
|
|
"--warning",
|
|
|
|
"@1",
|
|
|
|
"--critical",
|
|
|
|
"@0",
|
|
|
|
"--max-lag",
|
|
|
|
"1MB",
|
|
|
|
],
|
|
|
|
)
|
|
|
|
assert result.exit_code == 0
|
2023-08-22 11:08:38 +02:00
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "CLUSTERHASREPLICA OK - healthy_replica is 2 | healthy_replica=2;@1;@0 srv2_lag=1024 srv3_lag=0 unhealthy_replica=0\n"
|
|
|
|
)
|
2021-08-13 11:00:43 +02:00
|
|
|
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
def test_cluster_has_replica_ko_with_count_thresholds(
|
|
|
|
mocker: MockerFixture, use_old_replica_state: bool
|
|
|
|
) -> None:
|
2021-08-13 11:00:43 +02:00
|
|
|
runner = CliRunner()
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
my_mock(mocker, "cluster_has_replica_ko", 200, use_old_replica_state)
|
2021-08-11 19:09:14 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
[
|
|
|
|
"-e",
|
|
|
|
"https://10.20.199.3:8008",
|
|
|
|
"cluster_has_replica",
|
2021-08-13 11:00:43 +02:00
|
|
|
"--warning",
|
|
|
|
"@1",
|
|
|
|
"--critical",
|
|
|
|
"@0",
|
|
|
|
],
|
|
|
|
)
|
|
|
|
assert result.exit_code == 1
|
2023-08-22 11:08:38 +02:00
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "CLUSTERHASREPLICA WARNING - healthy_replica is 1 (outside range @0:1) | healthy_replica=1;@1;@0 srv3_lag=0 unhealthy_replica=1\n"
|
|
|
|
)
|
2021-08-13 11:00:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_cluster_has_replica_ko_with_count_thresholds_and_lag(
|
|
|
|
mocker: MockerFixture,
|
2023-08-22 11:08:38 +02:00
|
|
|
use_old_replica_state: bool,
|
2021-08-13 11:00:43 +02:00
|
|
|
) -> None:
|
|
|
|
runner = CliRunner()
|
|
|
|
|
2023-08-22 11:08:38 +02:00
|
|
|
my_mock(mocker, "cluster_has_replica_ko_lag", 200, use_old_replica_state)
|
2021-08-13 11:00:43 +02:00
|
|
|
result = runner.invoke(
|
|
|
|
main,
|
|
|
|
[
|
|
|
|
"-e",
|
|
|
|
"https://10.20.199.3:8008",
|
|
|
|
"cluster_has_replica",
|
|
|
|
"--warning",
|
|
|
|
"@1",
|
2021-08-11 19:09:14 +02:00
|
|
|
"--critical",
|
2021-08-13 11:00:43 +02:00
|
|
|
"@0",
|
|
|
|
"--max-lag",
|
|
|
|
"1MB",
|
2021-08-11 19:09:14 +02:00
|
|
|
],
|
|
|
|
)
|
|
|
|
assert result.exit_code == 2
|
2023-08-22 11:08:38 +02:00
|
|
|
assert (
|
|
|
|
result.stdout
|
|
|
|
== "CLUSTERHASREPLICA CRITICAL - healthy_replica is 0 (outside range @0:0) | healthy_replica=0;@1;@0 srv2_lag=10241024 srv3_lag=20000000 unhealthy_replica=2\n"
|
|
|
|
)
|