qa: add test_fscrypt_dummy_encryption test case support

This will test around 130 test cases with the test_dummy_encryption
option enabled.

Signed-off-by: Xiubo Li <xiubli@redhat.com>
This commit is contained in:
Xiubo Li 2023-01-31 10:33:07 +08:00
parent 306b8bea4a
commit b420db8dba

View File

@ -34,7 +34,7 @@ class TestFscrypt(XFSTestsDev):
# accordingly. # accordingly.
proc = self.mount_a.client_remote.run(args=['sudo', './check', proc = self.mount_a.client_remote.run(args=['sudo', './check',
'-g', 'encrypt'], cwd=self.xfstests_repo_path, stdout=StringIO(), '-g', 'encrypt'], cwd=self.xfstests_repo_path, stdout=StringIO(),
stderr=StringIO(), timeout=900, check_status=False,omit_sudo=False, stderr=StringIO(), timeout=900, check_status=False, omit_sudo=False,
label='running tests for encrypt from xfstests-dev') label='running tests for encrypt from xfstests-dev')
if proc.returncode != 0: if proc.returncode != 0:
@ -49,3 +49,29 @@ class TestFscrypt(XFSTestsDev):
# skipped for now because of not supporting features in kernel or kceph. # skipped for now because of not supporting features in kernel or kceph.
self.assertEqual(proc.returncode, 0) self.assertEqual(proc.returncode, 0)
self.assertIn('Passed all 26 tests', stdout) self.assertIn('Passed all 26 tests', stdout)
def test_fscrypt_dummy_encryption_with_quick_group(self):
self.require_kernel_mount()
self.write_local_config('test_dummy_encryption')
# XXX: check_status is set to False so that we can check for command's
# failure on our own (since this command doesn't set right error code
# and error message in some cases) and print custom log messages
# accordingly. This will take a long time and set the timeout to 3 hours.
proc = self.mount_a.client_remote.run(args=['sudo', './check',
'-g', 'quick', '-E', './ceph.exclude'], cwd=self.xfstests_repo_path,
stdout=StringIO(), stderr=StringIO(), timeout=10800, check_status=False,
omit_sudo=False, label='running tests for dummy_encryption from xfstests-dev')
if proc.returncode != 0:
log.info('Command failed.')
log.info(f'Command return value: {proc.returncode}')
stdout, stderr = proc.stdout.getvalue(), proc.stderr.getvalue()
log.info(f'Command stdout -\n{stdout}')
log.info(f'Command stderr -\n{stderr}')
# Currently, many test cases will be skipped due to unsupported features,
# but still will be marked as successful.
self.assertEqual(proc.returncode, 0)
self.assertIn('Passed all ', stdout)