mirror of
https://github.com/TECHNOFAB11/zfs-localpv.git
synced 2025-12-12 14:30:12 +01:00
feat(e2e-test): Add e2e-tests for zfs-localpv (#298)
Signed-off-by: w3aman <aman.gupta@mayadata.io>
This commit is contained in:
parent
53f872fcf1
commit
4e73638b5a
137 changed files with 8745 additions and 0 deletions
146
e2e-tests/experiments/functional/backup_and_restore/test.yml
Normal file
146
e2e-tests/experiments/functional/backup_and_restore/test.yml
Normal file
|
|
@ -0,0 +1,146 @@
|
|||
- hosts: localhost
|
||||
connection: local
|
||||
gather_facts: False
|
||||
|
||||
vars_files:
|
||||
- test_vars.yml
|
||||
- /mnt/parameters.yml
|
||||
|
||||
tasks:
|
||||
|
||||
- block:
|
||||
|
||||
## Generating the testname for zfs volume resize test
|
||||
- include_tasks: /e2e-tests/hack/create_testname.yml
|
||||
|
||||
## Record SOT (start of test) in e2e result e2e-cr (e2e-custom-resource)
|
||||
- include_tasks: /e2e-tests/hack/update_e2e_result_resource.yml
|
||||
vars:
|
||||
status: 'SOT'
|
||||
|
||||
- name: Identify the data consistency util to be invoked
|
||||
template:
|
||||
src: data_persistence.j2
|
||||
dest: data_persistence.yml
|
||||
|
||||
- include_vars:
|
||||
file: data_persistence.yml
|
||||
|
||||
- name: Record the data consistency util path
|
||||
set_fact:
|
||||
data_consistency_util_path: "{{ consistencyutil }}"
|
||||
when: data_persistence != ''
|
||||
|
||||
- name: Install velero
|
||||
include_tasks: "./setup_dependency.yml"
|
||||
|
||||
- name: Get the application pod name
|
||||
shell: >
|
||||
kubectl get pod -n {{ app_ns }} -l {{ app_label }}
|
||||
--no-headers -o custom-columns=:.metadata.name
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: application_pod_name
|
||||
|
||||
- name: Record the application pod name
|
||||
set_fact:
|
||||
app_pod_name: "{{ application_pod_name.stdout }}"
|
||||
|
||||
- name: Check if the application pod is in running state
|
||||
shell: >
|
||||
kubectl get pod {{ app_pod_name }} -n {{ app_ns }}
|
||||
--no-headers -o custom-columns=:.status.phase
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: app_pod_status
|
||||
failed_when: "'Running' not in app_pod_status.stdout"
|
||||
|
||||
- block:
|
||||
|
||||
- name: Create some test data
|
||||
include: "{{ data_consistency_util_path }}"
|
||||
vars:
|
||||
status: 'LOAD'
|
||||
ns: "{{ app_ns }}"
|
||||
pod_name: "{{ app_pod_name }}"
|
||||
when: data_persistence != ''
|
||||
|
||||
- name: Create the backup of the namespace in which application is deployed
|
||||
include_tasks: "./backup.yml"
|
||||
|
||||
when: action == 'backup' or action == 'schedule_backup' or action == 'incremental_backup'
|
||||
|
||||
|
||||
- block:
|
||||
|
||||
- name: Get the application node name
|
||||
shell: >
|
||||
kubectl get pod {{ app_pod_name }} -n {{ app_ns }}
|
||||
--no-headers -o custom-columns=:.spec.nodeName
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: application_node_name
|
||||
|
||||
- name: Record the application node name
|
||||
set_fact:
|
||||
source_node: "{{ application_node_name.stdout }}"
|
||||
|
||||
- name: Get any one of the nodes from remaining worker nodes in cluster
|
||||
shell: >
|
||||
kubectl get nodes --no-headers | grep -v master | grep -v {{ source_node }} | shuf -n 1 | awk '{print $1}'
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: random_node
|
||||
|
||||
- name: Record this random node as destination node for restoring on differet node
|
||||
set_fact:
|
||||
destination_node: "{{ random_node.stdout }}"
|
||||
|
||||
- name: Update the restore item action configmap with test specific values
|
||||
template:
|
||||
src: RestoreItemAction_configmap.j2
|
||||
dest: RestoreItemAction_configmap.yml
|
||||
|
||||
- name: Apply the configmap
|
||||
shell: kubectl apply -f RestoreItemAction_configmap.yml
|
||||
args:
|
||||
executable: /bin/bash
|
||||
register: status
|
||||
failed_when: "status.rc != 0"
|
||||
|
||||
when: lookup('env','RESTORE_IN_DIFF_NODE') == "true"
|
||||
|
||||
- block:
|
||||
|
||||
- name: Restore the backup
|
||||
include_tasks: "./restore.yml"
|
||||
when: lookup('env','RESTORE_IN_DIFF_NAMESPACE') == "true"
|
||||
|
||||
- name: Restore the backup
|
||||
include_tasks: "./restore.yml"
|
||||
vars:
|
||||
app_ns_new: "{{ app_ns }}"
|
||||
when: lookup('env','RESTORE_IN_DIFF_NAMESPACE') == "false"
|
||||
|
||||
when: action == 'restore'
|
||||
|
||||
- block:
|
||||
|
||||
- name: Restore the incremental backups
|
||||
include_tasks: "./incremental_restore.yml"
|
||||
|
||||
when: action == 'incremental_restore'
|
||||
|
||||
|
||||
- set_fact:
|
||||
flag: "Pass"
|
||||
|
||||
rescue:
|
||||
- set_fact:
|
||||
flag: "Fail"
|
||||
|
||||
always:
|
||||
# RECORD END-OF-TEST IN e2e RESULT CR
|
||||
- include_tasks: /e2e-tests/hack/update_e2e_result_resource.yml
|
||||
vars:
|
||||
status: 'EOT'
|
||||
Loading…
Add table
Add a link
Reference in a new issue