summaryrefslogtreecommitdiffstats
path: root/qa/tasks/cephfs/test_recovery_fs.py
blob: bbcdf97697277023feaf8fb960afdb7335f4919e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import logging
from os.path import join as os_path_join

from tasks.cephfs.cephfs_test_case import CephFSTestCase

log = logging.getLogger(__name__)

class TestFSRecovery(CephFSTestCase):
    """
    Tests for recovering FS after loss of FSMap
    """

    CLIENTS_REQUIRED = 1
    MDSS_REQUIRED = 3

    def test_recover_fs_after_fsmap_removal(self):
        data_pool = self.fs.get_data_pool_name()
        metadata_pool = self.fs.get_metadata_pool_name()
        # write data in mount, and fsync
        self.mount_a.create_n_files('file_on_fs', 1, sync=True)
        # faild MDSs to allow removing the file system in the next step
        self.fs.fail()
        # Remove file system to lose FSMap and keep the pools intact.
        # This mimics the scenario where the monitor store is rebuilt
        # using  OSDs to recover a cluster with corrupt monitor store.
        # The FSMap is permanently lost, but the FS pools are
        # recovered/intact
        self.fs.rm()
        # Recreate file system with pool and previous fscid
        self.fs.mon_manager.raw_cluster_cmd(
            'fs', 'new', self.fs.name, metadata_pool, data_pool,
            '--recover', '--force', '--fscid', f'{self.fs.id}')
        self.fs.set_joinable()
        # Check status of file system
        self.fs.wait_for_daemons()
        # check data in file sytem is intact
        filepath = os_path_join(self.mount_a.hostfs_mntpt, 'file_on_fs_0')
        self.assertEqual(self.mount_a.read_file(filepath), "0")