mirror of https://github.com/ceph/ceph
41 lines
2.0 KiB
Python
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"]])
|