-
Notifications
You must be signed in to change notification settings - Fork 170
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
create multiple cnv workloads (#10673)
Signed-off-by: Avdhoot <[email protected]>
- Loading branch information
1 parent
4688944
commit fe4c7f9
Showing
5 changed files
with
266 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
cnv_vm_configs: | ||
- volume_interface: PVC | ||
access_mode: ReadWriteMany | ||
sc_compression: default | ||
- volume_interface: PVC | ||
access_mode: ReadWriteMany | ||
sc_compression: aggressive | ||
- volume_interface: PVC | ||
access_mode: ReadWriteOnce | ||
sc_compression: default | ||
- volume_interface: DVT | ||
access_mode: ReadWriteMany | ||
sc_compression: default | ||
- volume_interface: DVT | ||
access_mode: ReadWriteMany | ||
sc_compression: aggressive |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
128 changes: 128 additions & 0 deletions
128
tests/functional/workloads/cnv/test_multi_vm_configurations.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,128 @@ | ||
import logging | ||
import pytest | ||
|
||
from ocs_ci.framework.testlib import E2ETest | ||
from ocs_ci.framework.pytest_customization.marks import workloads, magenta_squad | ||
from ocs_ci.helpers.cnv_helpers import cal_md5sum_vm | ||
from ocs_ci.helpers.performance_lib import run_oc_command | ||
from ocs_ci.helpers.keyrotation_helper import PVKeyrotation | ||
from ocs_ci.utility.utils import run_cmd | ||
from ocs_ci.ocs import constants | ||
|
||
logger = logging.getLogger(__name__) | ||
|
||
|
||
@magenta_squad | ||
class TestCNVVM(E2ETest): | ||
""" | ||
Includes tests related to CNV+ODF workloads. | ||
""" | ||
|
||
@pytest.fixture(autouse=True) | ||
def setup(self, project_factory, multi_cnv_workload): | ||
""" | ||
Setting up VMs for tests | ||
""" | ||
|
||
# Create a project | ||
proj_obj = project_factory() | ||
( | ||
self.vm_objs_def, | ||
self.vm_objs_aggr, | ||
self.sc_obj_def_compr, | ||
self.sc_obj_aggressive, | ||
) = multi_cnv_workload(namespace=proj_obj.namespace) | ||
|
||
logger.info("All vms created successfully") | ||
|
||
def verify_keyrotation(self, vm_objs, sc_obj): | ||
""" | ||
Verify the keyrotation is succeed. | ||
Args: | ||
vm_objs (obj): virtual machine Object | ||
sc_obj (obj): storage class object | ||
""" | ||
for vm in vm_objs: | ||
if vm.volume_interface == constants.VM_VOLUME_PVC: | ||
pvk_obj = PVKeyrotation(sc_obj) | ||
volume_name = vm.pvc_obj.get().get("spec", {}).get("volumeName") | ||
volume_handle = None | ||
for line in run_oc_command( | ||
f"describe pv {volume_name}", namespace=vm.namespace | ||
): | ||
if "VolumeHandle:" in line: | ||
volume_handle = line.split()[1] | ||
break | ||
if not volume_handle: | ||
logger.error(f"Cannot get volume handle for pv {volume_name}") | ||
raise Exception("Cannot get volume handle") | ||
assert pvk_obj.wait_till_keyrotation( | ||
volume_handle | ||
), f"Failed to rotate Key for the PVC {vm.pvc_obj.name}" | ||
|
||
@workloads | ||
@pytest.mark.polarion_id("OCS-6298") | ||
def test_cnv_vms(self, setup, setup_cnv): | ||
""" | ||
Tests to verify configuration for non-GS like environment | ||
Steps: | ||
1) Create VMs using fixture multi_cnv_workload | ||
2) Validate data integrity using md5sum. | ||
a. create file locally and take md5sum | ||
b. copy same file to vm and take md5sum | ||
c. Validate both are same or not | ||
3) Validate pvc level key rotation | ||
4) Stop the VM | ||
5) Delete the VM (as part of factory teardown) | ||
""" | ||
all_vm_list = self.vm_objs_def + self.vm_objs_aggr | ||
|
||
# 1.Validate data integrity using md5sum. | ||
file_name = "/tmp/dd_file" | ||
vm_filepath = "/home/admin/dd_file1_copy" | ||
|
||
# Create file locally | ||
cmd = f"dd if=/dev/zero of={file_name} bs=1M count=1024" | ||
run_cmd(cmd) | ||
# Calculate the MD5 checksum | ||
if file_name: | ||
cmd = f"md5sum {file_name}" | ||
md5sum_on_local = run_cmd(cmd).split()[0] | ||
if md5sum_on_local: | ||
logger.info(f"MD5 checksum of the file: {md5sum_on_local}") | ||
else: | ||
raise ValueError( | ||
"MD5 checksum could not be calculated. Ensure the file exists and is accessible." | ||
) | ||
else: | ||
raise ValueError( | ||
"File name is not provided. Please specify a valid file name." | ||
) | ||
# Copy local file to all vms | ||
for vm_obj in all_vm_list: | ||
vm_obj.scp_to_vm( | ||
local_path=file_name, | ||
vm_dest_path=vm_filepath, | ||
) | ||
# Take md5sum of copied file and compare with md5sum taken locally | ||
for vm_obj in all_vm_list: | ||
md5sum_on_vm = cal_md5sum_vm(vm_obj, vm_filepath, username=None) | ||
assert ( | ||
md5sum_on_vm == md5sum_on_local | ||
), f"md5sum has changed after copying file on {vm_obj.name}" | ||
|
||
# 2.Verify PV Keyrotation. | ||
# Process VMs with default compression | ||
self.verify_keyrotation(self.vm_objs_def, self.sc_obj_def_compr) | ||
# Process VMs with aggressive compression | ||
self.verify_keyrotation(self.vm_objs_aggr, self.sc_obj_aggressive) | ||
|
||
# 3.Stop all VMs | ||
for vm_obj in all_vm_list: | ||
vm_obj.stop() |