def test_icp_r(self):
        base_name_source = "test_icp_r_dir_source"
        user_session = s.sessions[1]
        file_names = set(self.iput_r_large_collection(
            user_session, base_name_source, file_count=1000, file_size=100)[1])

        base_name_target = "test_icp_r_dir_target"
        assertiCmd(user_session, "icp -r " + base_name_source + " " + base_name_target, "EMPTY")
        assertiCmd(user_session, "ils", "LIST", base_name_target)
        rods_files_source = set(runCmd_ils_to_entries(user_session.runCmd("ils", [base_name_source])))
        self.assertTrue(file_names == rods_files_source,
                        msg="Files missing from rods source:\n" + str(file_names - rods_files_source) + "\n\n" +
                            "Extra files in rods source:\n" + str(rods_files_source - file_names))

        rods_files_target = set(runCmd_ils_to_entries(user_session.runCmd("ils", [base_name_target])))
        self.assertTrue(file_names == rods_files_target,
                        msg="Files missing from rods target:\n" + str(file_names - rods_files_target) + "\n\n" +
                            "Extra files in rods target:\n" + str(rods_files_target - file_names))

        vault_files_post_icp_source = set(os.listdir(os.path.join(get_vault_session_path(user_session),
                                                                  base_name_source)))

        self.assertTrue(file_names == vault_files_post_icp_source,
                        msg="Files missing from vault:\n" + str(file_names - vault_files_post_icp_source) + "\n\n" +
                            "Extra files in vault:\n" + str(vault_files_post_icp_source - file_names))

        vault_files_post_icp_target = set(os.listdir(os.path.join(get_vault_session_path(user_session),
                                                                  base_name_target)))
        self.assertTrue(file_names == vault_files_post_icp_target,
                        msg="Files missing from vault:\n" + str(file_names - vault_files_post_icp_target) + "\n\n" +
                            "Extra files in vault:\n" + str(vault_files_post_icp_target - file_names))
    def test_irsync_r_coll_to_coll(self):
        base_name_source = "test_irsync_r_coll_to_coll_source"
        user_session = s.sessions[1]
        file_names = set(
            self.iput_r_large_collection(user_session,
                                         base_name_source,
                                         file_count=1000,
                                         file_size=100)[1])
        base_name_target = "test_irsync_r_coll_to_coll_target"
        assertiCmd(
            user_session,
            "irsync -r i:" + base_name_source + " i:" + base_name_target,
            "EMPTY")
        assertiCmd(user_session, "ils", "LIST", base_name_source)
        assertiCmd(user_session, "ils", "LIST", base_name_target)
        rods_files_source = set(
            runCmd_ils_to_entries(
                user_session.runCmd("ils", [base_name_source])))
        self.assertTrue(file_names == rods_files_source,
                        msg="Files missing from rods source:\n" +
                        str(file_names - rods_files_source) + "\n\n" +
                        "Extra files in rods source:\n" +
                        str(rods_files_source - file_names))

        rods_files_target = set(
            runCmd_ils_to_entries(
                user_session.runCmd("ils", [base_name_target])))
        self.assertTrue(file_names == rods_files_target,
                        msg="Files missing from rods target:\n" +
                        str(file_names - rods_files_target) + "\n\n" +
                        "Extra files in rods target:\n" +
                        str(rods_files_target - file_names))

        vault_files_post_irsync_source = set(
            os.listdir(
                os.path.join(get_vault_session_path(user_session),
                             base_name_source)))

        self.assertTrue(file_names == vault_files_post_irsync_source,
                        msg="Files missing from vault:\n" +
                        str(file_names - vault_files_post_irsync_source) +
                        "\n\n" + "Extra files in vault:\n" +
                        str(vault_files_post_irsync_source - file_names))

        vault_files_post_irsync_target = set(
            os.listdir(
                os.path.join(get_vault_session_path(user_session),
                             base_name_target)))

        self.assertTrue(file_names == vault_files_post_irsync_target,
                        msg="Files missing from vault:\n" +
                        str(file_names - vault_files_post_irsync_target) +
                        "\n\n" + "Extra files in vault:\n" +
                        str(vault_files_post_irsync_target - file_names))
    def test_irsync_r_dir_to_coll(self):
        base_name = "test_irsync_r_dir_to_coll"
        local_dir = os.path.join(self.testing_tmp_dir, base_name)
        file_names = set(
            make_large_local_tmp_dir(local_dir, file_count=1000,
                                     file_size=100))
        user_session = s.sessions[1]

        assertiCmd(user_session, "irsync -r " + local_dir + " i:" + base_name,
                   "EMPTY")
        assertiCmd(user_session, "ils", "LIST", base_name)
        rods_files = set(
            runCmd_ils_to_entries(user_session.runCmd("ils", [base_name])))
        self.assertTrue(
            file_names == rods_files,
            msg="Files missing from rods:\n" + str(file_names - rods_files) +
            "\n\n" + "Extra files in rods:\n" + str(rods_files - file_names))

        vault_files_post_irsync = set(
            os.listdir(
                os.path.join(get_vault_session_path(user_session), base_name)))

        self.assertTrue(file_names == vault_files_post_irsync,
                        msg="Files missing from vault:\n" +
                        str(file_names - vault_files_post_irsync) + "\n\n" +
                        "Extra files in vault:\n" +
                        str(vault_files_post_irsync - file_names))
    def iput_r_large_collection(self, session, base_name, file_count, file_size):
        local_dir = os.path.join(self.testing_tmp_dir, base_name)
        local_files = make_large_local_tmp_dir(local_dir, file_count, file_size)
        assertiCmd(session, "iput -r " + local_dir, "EMPTY")
        rods_files = set(runCmd_ils_to_entries(session.runCmd("ils", [base_name])))
        self.assertTrue(set(local_files) == rods_files,
                        msg="Files missing from rods:\n" + str(set(local_files) - rods_files) + "\n\n" +
                            "Extra files in rods:\n" + str(rods_files - set(local_files)))
        vault_files = set(os.listdir(os.path.join(get_vault_session_path(session),
                                                  base_name)))
        self.assertTrue(set(local_files) == vault_files,
                        msg="Files missing from vault:\n" + str(set(local_files) - vault_files) + "\n\n" +
                            "Extra files in vault:\n" + str(vault_files - set(local_files)))

        return (local_dir, local_files)
    def test_irsync_r_dir_to_coll(self):
        base_name = "test_irsync_r_dir_to_coll"
        local_dir = os.path.join(self.testing_tmp_dir, base_name)
        file_names = set(make_large_local_tmp_dir(local_dir, file_count=1000, file_size=100))
        user_session = s.sessions[1]

        assertiCmd(user_session, "irsync -r " + local_dir + " i:" + base_name, "EMPTY")
        assertiCmd(user_session, "ils", "LIST", base_name)
        rods_files = set(runCmd_ils_to_entries(user_session.runCmd("ils", [base_name])))
        self.assertTrue(file_names == rods_files,
                        msg="Files missing from rods:\n" + str(file_names - rods_files) + "\n\n" +
                            "Extra files in rods:\n" + str(rods_files - file_names))

        vault_files_post_irsync = set(os.listdir(os.path.join(get_vault_session_path(user_session),
                                                              base_name)))

        self.assertTrue(file_names == vault_files_post_irsync,
                        msg="Files missing from vault:\n" + str(file_names - vault_files_post_irsync) + "\n\n" +
                            "Extra files in vault:\n" + str(vault_files_post_irsync - file_names))
    def test_imv_r(self):
        base_name_source = "test_imv_r_dir_source"
        user_session = s.sessions[1]
        file_names = set(
            self.iput_r_large_collection(user_session,
                                         base_name_source,
                                         file_count=1000,
                                         file_size=100)[1])

        base_name_target = "test_imv_r_dir_target"
        assertiCmd(user_session,
                   "imv " + base_name_source + " " + base_name_target, "EMPTY")
        assertiCmd(user_session, "ils " + base_name_source, "ERROR",
                   "does not exist")
        assertiCmd(user_session, "ils", "LIST", base_name_target)
        rods_files_post_imv = set(
            runCmd_ils_to_entries(
                user_session.runCmd("ils", [base_name_target])))
        self.assertTrue(file_names == rods_files_post_imv,
                        msg="Files missing from rods:\n" +
                        str(file_names - rods_files_post_imv) + "\n\n" +
                        "Extra files in rods:\n" +
                        str(rods_files_post_imv - file_names))

        vault_files_post_irm_source = set(
            os.listdir(
                os.path.join(get_vault_session_path(user_session),
                             base_name_source)))
        self.assertTrue(len(vault_files_post_irm_source) == 0)

        vault_files_post_irm_target = set(
            os.listdir(
                os.path.join(get_vault_session_path(user_session),
                             base_name_target)))
        self.assertTrue(file_names == vault_files_post_irm_target,
                        msg="Files missing from vault:\n" +
                        str(file_names - vault_files_post_irm_target) +
                        "\n\n" + "Extra files in vault:\n" +
                        str(vault_files_post_irm_target - file_names))
    def iput_r_large_collection(self, session, base_name, file_count,
                                file_size):
        local_dir = os.path.join(self.testing_tmp_dir, base_name)
        local_files = make_large_local_tmp_dir(local_dir, file_count,
                                               file_size)
        assertiCmd(session, "iput -r " + local_dir, "EMPTY")
        rods_files = set(
            runCmd_ils_to_entries(session.runCmd("ils", [base_name])))
        self.assertTrue(set(local_files) == rods_files,
                        msg="Files missing from rods:\n" +
                        str(set(local_files) - rods_files) + "\n\n" +
                        "Extra files in rods:\n" +
                        str(rods_files - set(local_files)))
        vault_files = set(
            os.listdir(os.path.join(get_vault_session_path(session),
                                    base_name)))
        self.assertTrue(set(local_files) == vault_files,
                        msg="Files missing from vault:\n" +
                        str(set(local_files) - vault_files) + "\n\n" +
                        "Extra files in vault:\n" +
                        str(vault_files - set(local_files)))

        return (local_dir, local_files)
    def test_irsync_r_coll_to_dir(self):
        base_name_source = "test_irsync_r_coll_to_dir_source"
        user_session = s.sessions[1]
        file_names = set(self.iput_r_large_collection(
            user_session, base_name_source, file_count=1000, file_size=100)[1])
        local_dir = os.path.join(self.testing_tmp_dir, "test_irsync_r_coll_to_dir_target")
        assertiCmd(user_session, "irsync -r i:" + base_name_source + " " + local_dir, "EMPTY")
        assertiCmd(user_session, "ils", "LIST", base_name_source)
        rods_files_source = set(runCmd_ils_to_entries(user_session.runCmd("ils", [base_name_source])))
        self.assertTrue(file_names == rods_files_source,
                        msg="Files missing from rods source:\n" + str(file_names - rods_files_source) + "\n\n" +
                            "Extra files in rods source:\n" + str(rods_files_source - file_names))

        local_files = set(os.listdir(local_dir))
        self.assertTrue(file_names == local_files,
                        msg="Files missing from local dir:\n" + str(file_names - local_files) + "\n\n" +
                            "Extra files in local dir:\n" + str(local_files - file_names))

        vault_files_post_irsync_source = set(os.listdir(os.path.join(get_vault_session_path(user_session),
                                                                     base_name_source)))

        self.assertTrue(file_names == vault_files_post_irsync_source,
                        msg="Files missing from vault:\n" + str(file_names - vault_files_post_irsync_source) + "\n\n" +
                            "Extra files in vault:\n" + str(vault_files_post_irsync_source - file_names))