Add two tests for interrupting cache mode switch
Signed-off-by: Slawomir Jankowski <slawomir.jankowski@intel.com>
This commit is contained in:
parent
5f21f4d580
commit
657023a79c
@ -270,3 +270,160 @@ def test_interrupt_core_remove(cache_mode, filesystem):
|
||||
with TestRun.step("Unmount core device."):
|
||||
core_part.unmount()
|
||||
|
||||
|
||||
@pytest.mark.parametrize("filesystem", Filesystem)
|
||||
@pytest.mark.parametrize("cache_mode", CacheMode.with_traits(CacheModeTrait.LazyWrites))
|
||||
@pytest.mark.require_disk("cache", DiskTypeSet([DiskType.optane, DiskType.nand]))
|
||||
@pytest.mark.require_disk("core", DiskTypeLowerThan("cache"))
|
||||
def test_interrupt_cache_mode_switch_immediately(cache_mode, filesystem):
|
||||
"""
|
||||
title: Test if OpenCAS works correctly after cache mode switching immediate interruption.
|
||||
description: |
|
||||
Negative test of the ability of OpenCAS to handle cache mode switching
|
||||
immediate interruption.
|
||||
pass_criteria:
|
||||
- No system crash.
|
||||
- Cache mode will not be switched after interruption.
|
||||
- Flushing would be stopped after interruption.
|
||||
- Md5sum are correct during all test steps.
|
||||
- Dirty blocks quantity after interruption is equal or lower.
|
||||
"""
|
||||
with TestRun.step("Prepare cache and core."):
|
||||
cache_part, core_part = prepare()
|
||||
|
||||
for _ in TestRun.iteration(range(iterations_per_config),
|
||||
f"Reload cache configuration {iterations_per_config} times."):
|
||||
|
||||
with TestRun.step("Start cache."):
|
||||
cache = casadm.start_cache(cache_part, cache_mode, force=True)
|
||||
|
||||
with TestRun.step("Set cleaning policy to NOP."):
|
||||
cache.set_cleaning_policy(CleaningPolicy.nop)
|
||||
|
||||
with TestRun.step(f"Add core device with {filesystem} filesystem and mount it."):
|
||||
core_part.create_filesystem(filesystem)
|
||||
core = cache.add_core(core_part)
|
||||
core.mount(mount_point)
|
||||
|
||||
with TestRun.step(f"Create test file in mount point of exported object."):
|
||||
test_file = create_test_file()
|
||||
|
||||
with TestRun.step("Check md5 sum of test file."):
|
||||
test_file_md5sum_before = test_file.md5sum()
|
||||
|
||||
with TestRun.step("Get number of dirty data on exported object before interruption."):
|
||||
os_utils.sync()
|
||||
os_utils.drop_caches(DropCachesMode.ALL)
|
||||
cache_dirty_blocks_before = cache.get_dirty_blocks()
|
||||
|
||||
with TestRun.step("Start switching cache mode."):
|
||||
flush_pid = TestRun.executor.run_in_background(cli.set_cache_mode_cmd(
|
||||
str(CacheMode.DEFAULT.name.lower()), str(cache.cache_id), "yes"))
|
||||
|
||||
with TestRun.step("Send interruption signal."):
|
||||
TestRun.executor.run(f"kill -s SIGINT {flush_pid}")
|
||||
|
||||
with TestRun.step("Check number of dirty data on exported object after interruption."):
|
||||
cache_dirty_blocks_after = cache.get_dirty_blocks()
|
||||
if cache_dirty_blocks_after >= cache_dirty_blocks_before:
|
||||
TestRun.LOGGER.error("Quantity of dirty lines after cache flush interruption "
|
||||
"should be lower.")
|
||||
if int(cache_dirty_blocks_after) == 0:
|
||||
TestRun.LOGGER.error("Quantity of dirty lines after cache flush interruption "
|
||||
"should not be zero.")
|
||||
|
||||
with TestRun.step("Check cache mode."):
|
||||
if cache.get_cache_mode() != cache_mode:
|
||||
TestRun.LOGGER.error("Cache mode should remain the same.")
|
||||
|
||||
with TestRun.step("Unmount core and stop cache."):
|
||||
core.unmount()
|
||||
cache.stop()
|
||||
|
||||
with TestRun.step("Mount core device."):
|
||||
core_part.mount(mount_point)
|
||||
|
||||
with TestRun.step("Check md5 sum of test file again."):
|
||||
if test_file_md5sum_before != test_file.md5sum():
|
||||
TestRun.LOGGER.error(
|
||||
"Md5 sums before and after interrupting core removal are different.")
|
||||
|
||||
with TestRun.step("Unmount core device."):
|
||||
core_part.unmount()
|
||||
|
||||
|
||||
@pytest.mark.parametrize("filesystem", Filesystem)
|
||||
@pytest.mark.parametrize("cache_mode", CacheMode.with_traits(CacheModeTrait.LazyWrites))
|
||||
@pytest.mark.require_disk("cache", DiskTypeSet([DiskType.optane, DiskType.nand]))
|
||||
@pytest.mark.require_disk("core", DiskTypeLowerThan("cache"))
|
||||
def test_interrupt_cache_mode_switch_delayed(cache_mode, filesystem):
|
||||
"""
|
||||
title: Test if OpenCAS works correctly after cache mode switching delayed interruption.
|
||||
description: |
|
||||
Negative test of the ability of OpenCAS to handle cache mode switching
|
||||
interruption with delay.
|
||||
pass_criteria:
|
||||
- No system crash.
|
||||
- Cache mode cannot be interrupted with delay.
|
||||
- Md5sum are correct during all test steps.
|
||||
- Dirty blocks quantity after cache mode switching is zero.
|
||||
"""
|
||||
with TestRun.step("Prepare cache and core."):
|
||||
cache_part, core_part = prepare()
|
||||
|
||||
for _ in TestRun.iteration(range(iterations_per_config),
|
||||
f"Reload cache configuration {iterations_per_config} times."):
|
||||
|
||||
with TestRun.step("Start cache."):
|
||||
cache = casadm.start_cache(cache_part, cache_mode, force=True)
|
||||
|
||||
with TestRun.step("Set cleaning policy to NOP."):
|
||||
cache.set_cleaning_policy(CleaningPolicy.nop)
|
||||
|
||||
with TestRun.step(f"Add core device with {filesystem} filesystem and mount it."):
|
||||
core_part.create_filesystem(filesystem)
|
||||
core = cache.add_core(core_part)
|
||||
core.mount(mount_point)
|
||||
|
||||
with TestRun.step(f"Create test file in mount point of exported object."):
|
||||
test_file = create_test_file()
|
||||
|
||||
with TestRun.step("Check md5 sum of test file."):
|
||||
test_file_md5sum_before = test_file.md5sum()
|
||||
|
||||
with TestRun.step("Start switching cache mode."):
|
||||
flush_pid = TestRun.executor.run_in_background(cli.set_cache_mode_cmd(
|
||||
str(CacheMode.DEFAULT.name.lower()), str(cache.cache_id), "yes"))
|
||||
sleep(2)
|
||||
|
||||
with TestRun.step("Send interruption signal."):
|
||||
percentage = casadm_parser.get_flushing_progress(cache.cache_id, core.core_id)
|
||||
while percentage < 50:
|
||||
percentage = casadm_parser.get_flushing_progress(cache.cache_id, core.core_id)
|
||||
TestRun.executor.run(f"kill -s SIGINT {flush_pid}")
|
||||
|
||||
with TestRun.step(
|
||||
"Get quantity of dirty data on exported object after sending interruption "
|
||||
"signal to cas to stop mode switching."):
|
||||
if int(cache.get_dirty_blocks()) != 0:
|
||||
TestRun.LOGGER.error("Quantity of dirty lines should be zero now.")
|
||||
|
||||
with TestRun.step("Check cache mode."):
|
||||
if cache.get_cache_mode() == cache_mode:
|
||||
TestRun.LOGGER.error("Cache mode should have changed.")
|
||||
|
||||
with TestRun.step("Unmount core and stop cache."):
|
||||
core.unmount()
|
||||
cache.stop()
|
||||
|
||||
with TestRun.step("Mount core device."):
|
||||
core_part.mount(mount_point)
|
||||
|
||||
with TestRun.step("Check md5 sum of test file again."):
|
||||
if test_file_md5sum_before != test_file.md5sum():
|
||||
TestRun.LOGGER.error(
|
||||
"Md5 sums before and after interrupting core removal are different.")
|
||||
|
||||
with TestRun.step("Unmount core device."):
|
||||
core_part.unmount()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user