1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
import pytest
import json
from openshift_checks.logging.fluentd import Fluentd
def canned_fluentd(exec_oc=None):
"""Create a Fluentd check object with canned exec_oc method"""
check = Fluentd("dummy") # fails if a module is actually invoked
if exec_oc:
check._exec_oc = exec_oc
return check
def assert_error(error, expect_error):
if expect_error:
assert error
assert expect_error in error
else:
assert not error
fluentd_pod_node1 = {
"metadata": {
"labels": {"component": "fluentd", "deploymentconfig": "logging-fluentd"},
"name": "logging-fluentd-1",
},
"spec": {"host": "node1", "nodeName": "node1"},
"status": {
"containerStatuses": [{"ready": True}],
"conditions": [{"status": "True", "type": "Ready"}],
}
}
fluentd_pod_node2_down = {
"metadata": {
"labels": {"component": "fluentd", "deploymentconfig": "logging-fluentd"},
"name": "logging-fluentd-2",
},
"spec": {"host": "node2", "nodeName": "node2"},
"status": {
"containerStatuses": [{"ready": False}],
"conditions": [{"status": "False", "type": "Ready"}],
}
}
fluentd_node1 = {
"metadata": {
"labels": {"logging-infra-fluentd": "true", "kubernetes.io/hostname": "node1"},
"name": "node1",
},
"status": {"addresses": [{"type": "InternalIP", "address": "10.10.1.1"}]},
}
fluentd_node2 = {
"metadata": {
"labels": {"logging-infra-fluentd": "true", "kubernetes.io/hostname": "hostname"},
"name": "node2",
},
"status": {"addresses": [{"type": "InternalIP", "address": "10.10.1.2"}]},
}
fluentd_node3_unlabeled = {
"metadata": {
"labels": {"kubernetes.io/hostname": "hostname"},
"name": "node3",
},
"status": {"addresses": [{"type": "InternalIP", "address": "10.10.1.3"}]},
}
@pytest.mark.parametrize('pods, nodes, expect_error', [
(
[],
[],
'No nodes appear to be defined',
),
(
[],
[fluentd_node3_unlabeled],
'There are no nodes with the fluentd label',
),
(
[],
[fluentd_node1, fluentd_node3_unlabeled],
'Fluentd will not aggregate logs from these nodes.',
),
(
[],
[fluentd_node2],
"nodes are supposed to have a Fluentd pod but do not",
),
(
[fluentd_pod_node1, fluentd_pod_node1],
[fluentd_node1],
'more Fluentd pods running than nodes labeled',
),
(
[fluentd_pod_node2_down],
[fluentd_node2],
"Fluentd pods are supposed to be running",
),
(
[fluentd_pod_node1],
[fluentd_node1],
None,
),
])
def test_get_fluentd_pods(pods, nodes, expect_error):
check = canned_fluentd(exec_oc=lambda cmd, args: json.dumps(dict(items=nodes)))
error = check.check_fluentd(pods)
assert_error(error, expect_error)
|