ceph/qa/tasks/cephfs/test_meta_injection.py

41 lines
2.0 KiB
Python

from tasks.cephfs.cephfs_test_case import CephFSTestCase
import random
import os
class TestMetaInjection(CephFSTestCase):
def test_meta_injection(self):
conf_ori = self.fs.mds_asok(['config', 'show'])
self.fs.mds_asok(['config', 'set', 'mds_log_max_segments', '1'])
self.mount_a.run_shell(["mkdir", "metadir"])
self.mount_a.run_shell(["touch", "metadir/metafile1"])
self.mount_a.run_shell(["touch", "metadir/metafile2"])
self.fs.mds_asok(['flush', 'journal'])
dirino = self.mount_a.path_to_ino("metadir")
ino = self.mount_a.path_to_ino("metadir/metafile1")
# export meta of ino
self.fs.meta_tool(['showm', '-i', str(ino), '-o', '/tmp/meta_out'], 0, True)
out = self.mount_a.run_shell(['grep', str(ino),'/tmp/meta_out']).stdout.getvalue().strip()
# check the metadata of ino
self.assertNotEqual(out.find(u'"ino":'+ str(ino)), -1)
# amend info of ino
self.fs.get_meta_of_fs_file(dirino, "metafile1", "/tmp/meta_obj")
self.fs.meta_tool(['amend', '-i', str(ino), '--in', '/tmp/meta_out', '--yes-i-really-really-mean-it'], 0, True)
self.fs.get_meta_of_fs_file(dirino, "metafile1", "/tmp/meta_obj_chg")
# checkout meta_out after import it
ori_mds5 = self.mount_a.run_shell(["md5sum", "/tmp/meta_obj"]).stdout.getvalue().strip().split()
chg_mds5 = self.mount_a.run_shell(["md5sum", "/tmp/meta_obj_chg"]).stdout.getvalue().strip().split()
print(ori_mds5," ==> ", chg_mds5)
self.assertEqual(len(ori_mds5), 2)
self.assertEqual(len(chg_mds5), 2)
self.assertEqual(ori_mds5[0], chg_mds5[0])
self.mount_a.run_shell(["rm", "metadir", "-rf"])
self.mount_a.run_shell(["rm", "/tmp/meta_obj"])
self.mount_a.run_shell(["rm", "/tmp/meta_obj_chg"])
# restore config of mds_log_max_segments
self.fs.mds_asok(['config', 'set', 'mds_log_max_segments', conf_ori["mds_log_max_segments"]])