blob: 84d53c4fde948dd2d60d8b3be30a1ebc7a26d74c (
plain)
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
|
---
- name: create directory for drain scenario
ansible.builtin.file:
path: /tmp/resiliency/node-drain
state: directory
mode: '0755'
tags: prepare
- name: Get compute node list
community.kubernetes.k8s_info:
kind: Node
label_selectors: "! node-role.kubernetes.io/master"
register: kubernetes_computer_node_list
tags: prepare
- name: Set Fact first compute node Internal IP
ansible.builtin.set_fact:
first_node_ip: "{{ item.address }}"
when: "'Hostname' in item.type"
with_items:
"{{ (kubernetes_computer_node_list.resources | first).status.addresses }}"
tags: prepare
- name: Set Compute for the drain chaos
ansible.builtin.set_fact:
compute_chaos: "{{ first_node_ip }}"
when: compute_chaos is not defined
tags: prepare
- name: Prepare rbac file for drain experiment
ansible.builtin.template:
src: node-drain-rbac.yaml.j2
dest: /tmp/resiliency/node-drain/node-drain-rbac.yaml
mode: 0600
tags: prepare
- name: Prepare chaos file for drain experiment
ansible.builtin.template:
src: node-drain-chaos.yaml.j2
dest: /tmp/resiliency/node-drain/node-drain-chaos.yaml
mode: 0600
tags: prepare
- name: Apply drain rbac
community.kubernetes.k8s:
state: present
src: /tmp/resiliency/node-drain/node-drain-rbac.yaml
tags: apply
- name: Cordon the Chosen node
ansible.builtin.shell: "kubectl cordon {{ compute_chaos }}"
- name: Apply chaos drain experiment
community.kubernetes.k8s:
state: present
src: /tmp/resiliency/node-drain/node-drain-chaos.yaml
tags: apply
- name: wait for the end of chaos
run_once: true
community.kubernetes.k8s_info:
kind: ChaosEngine
api_version: litmuschaos.io/v1alpha1
name: onap-chaos-drain
namespace: "{{ onap_namespace }}"
register: chaosengine_status
changed_when:
&chaos_test chaosengine_status is defined and
chaosengine_status.resources[0].status.engineStatus == "completed"
until: *chaos_test
retries: 5
delay: 120
tags: wait
# - name: Print the chaos engine object
# ansible.builtin.debug:
# msg: "{{chaosengine_status.resources[0].status.engineStatus }}"
- name: get results
run_once: true
community.kubernetes.k8s_info:
kind: ChaosResult
api_version: litmuschaos.io/v1alpha1
name: onap-chaos-drain-node-drain
namespace: "{{ onap_namespace }}"
register: chaosresult_drain
changed_when:
&chaos_result chaosresult_drain is defined and
(chaosresult_drain.resources[0].status.experimentStatus.verdict == "Pass" or
chaosresult_drain.resources[0].status.experimentStatus.verdict == "Fail" )
until: *chaos_result
retries: 5
delay: 10
tags: wait
- name: Print the chaos result object
ansible.builtin.debug:
msg: "{{ chaosresult_drain.resources[0].status.experimentStatus.verdict}}"
- name: Print the chaos result verdict
ansible.builtin.debug:
msg: " The test is {{ chaosresult_drain.resources[0].status.experimentStatus.verdict}}-ed"
- name: Uncordon the Chosen node
ansible.builtin.shell: "kubectl uncordon {{ compute_chaos }}"
|