/* * Copyright (c) 2022-2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include "b_error/b_error.h" #include "file_ex.h" #include "test_manager.h" #include "untar_file.h" namespace OHOS::FileManagement::Backup { using namespace std; using namespace testing; class UntarFileTest : public testing::Test { public: static void SetUpTestCase(void); static void TearDownTestCase(); void SetUp() override {}; void TearDown() override {}; }; void UntarFileTest::SetUpTestCase() { GTEST_LOG_(INFO) << "SetUpTestCase enter"; } void UntarFileTest::TearDownTestCase() { GTEST_LOG_(INFO) << "TearDownTestCase enter"; } static void ClearCache() { UntarFile::GetInstance().rootPath_.clear(); UntarFile::GetInstance().tarFileSize_ = 0; UntarFile::GetInstance().tarFileBlockCnt_ = 0; UntarFile::GetInstance().pos_ = 0; UntarFile::GetInstance().readCnt_ = 0; if (UntarFile::GetInstance().tarFilePtr_ != nullptr) { fclose(UntarFile::GetInstance().tarFilePtr_); UntarFile::GetInstance().tarFilePtr_ = nullptr; } TarFile::GetInstance().fileCount_ = 0; TarFile::GetInstance().tarMap_.clear(); TarFile::GetInstance().rootPath_.clear(); TarFile::GetInstance().packagePath_.clear(); TarFile::GetInstance().baseTarName_.clear(); TarFile::GetInstance().tarFileName_.clear(); TarFile::GetInstance().ioBuffer_.clear(); TarFile::GetInstance().currentTarName_.clear(); TarFile::GetInstance().currentTarFileSize_ = 0; TarFile::GetInstance().tarFileCount_ = 0; TarFile::GetInstance().currentFileName_.clear(); if (TarFile::GetInstance().currentTarFile_ != nullptr) { fclose(TarFile::GetInstance().currentTarFile_); TarFile::GetInstance().currentTarFile_ = nullptr; } } /** * @tc.number: SUB_Untar_File_GetInstance_0100 * @tc.name: SUB_Untar_File_GetInstance_0100 * @tc.desc: 测试 GetInstance 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_GetInstance_0100, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_GetInstance_0100"; try { UntarFile::GetInstance(); EXPECT_TRUE(true); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_GetInstance_0100"; } /** * @tc.number: SUB_Untar_File_UnPacket_0100 * @tc.name: SUB_Untar_File_UnPacket_0100 * @tc.desc: 测试 UnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_UnPacket_0100, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_UnPacket_0100"; try { string tarFile(""); string rootPath(""); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().UnPacket(tarFile, rootPath); EXPECT_EQ(ret, ENOENT); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_UnPacket_0100"; } /** * @tc.number: SUB_Untar_File_UnPacket_0200 * @tc.name: SUB_Untar_File_UnPacket_0200 * @tc.desc: 测试 UnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_UnPacket_0200, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_UnPacket_0200"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_UnPacket_0200"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = testDir + "/a.txt"; string bFile = testDir + "/b.txt"; SaveStringToFile(aFile, "hello"); SaveStringToFile(bFile, "world"); string tarFile = root + "test.tar"; string cmd = "tar -cvf " + tarFile + " " + testDir; string rootPath(root); if (system(cmd.c_str()) != 0) { GTEST_LOG_(INFO) << " execute tar failure, errno :" << errno; throw BError(errno); } auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().UnPacket(tarFile, rootPath); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_UnPacket_0200"; } /** * @tc.number: SUB_Untar_File_UnPacket_0300 * @tc.name: SUB_Untar_File_UnPacket_0300 * @tc.desc: 测试 UnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_UnPacket_0300, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_UnPacket_0300"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_UnPacket_0300"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = testDir + "/a.txt"; SaveStringToFile(aFile, "hello"); string rootPath(root); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().UnPacket(aFile, rootPath); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_UnPacket_0300"; } /** * @tc.number: SUB_Untar_File_UnPacket_0400 * @tc.name: SUB_Untar_File_UnPacket_0400 * @tc.desc: 测试 UnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_UnPacket_0400, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_UnPacket_0400"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_UnPacket_0400"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string tarFile = root + "test.tar"; string cmd = "tar -cvf " + tarFile + " " + testDir; if (system(cmd.c_str()) != 0) { GTEST_LOG_(INFO) << " execute tar failure, errno :" << errno; throw BError(errno); } string rootPath(root); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().UnPacket(tarFile, rootPath); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_UnPacket_0400"; } /** * @tc.number: SUB_Untar_File_UnPacket_0500 * @tc.name: SUB_Untar_File_UnPacket_0500 * @tc.desc: 测试 UnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_UnPacket_0500, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_UnPacket_0500"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_UnPacket_0500"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir/"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = testDir; string bFile = testDir; // 循环100次,用来构造超长路径和超长文件名 for (int i = 0; i < 100; i++) { aFile += "test001/test002/test003/test004/test005/"; bFile += "ab"; } aFile += "a.txt"; bFile += ".txt"; SaveStringToFile(aFile, "hello"); SaveStringToFile(bFile, "world"); string tarFile = root + "/test.0.tar"; TarMap tarMap {}; vector smallFiles; smallFiles.emplace_back(aFile); smallFiles.emplace_back(bFile); auto reportCb = [](std::string msg, int err) { return; }; TarFile::GetInstance().Packet(smallFiles, "test", root, tarMap, reportCb); string rootPath(root); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().UnPacket(tarFile, rootPath); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_UnPacket_0500"; } /** * @tc.number: SUB_Untar_File_IncrementalUnPacket_0100 * @tc.name: SUB_Untar_File_IncrementalUnPacket_0100 * @tc.desc: 测试 IncrementalUnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_IncrementalUnPacket_0100, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_IncrementalUnPacket_0100"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_IncrementalUnPacket_0100"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir/"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = testDir; string bFile = testDir; // 循环100次,用来构造超长路径和超长文件名 for (int i = 0; i < 100; i++) { aFile += "test001/test002/test003/test004/test005/"; bFile += "ab"; } aFile += "a.txt"; bFile += ".txt"; SaveStringToFile(aFile, "hello"); SaveStringToFile(bFile, "world"); TarMap tarMap {}; vector smallFiles; smallFiles.emplace_back(aFile); smallFiles.emplace_back(bFile); auto reportCb = [](std::string msg, int err) { return; }; TarFile::GetInstance().Packet(smallFiles, "test", root, tarMap, reportCb); string tarFile = root + "/test.0.tar"; string rootPath(root); unordered_map cloudFiles; auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().IncrementalUnPacket(tarFile, rootPath, cloudFiles); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_IncrementalUnPacket_0100"; } /** * @tc.number: SUB_Untar_File_IncrementalUnPacket_0200 * @tc.name: SUB_Untar_File_IncrementalUnPacket_0200 * @tc.desc: 测试 IncrementalUnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_IncrementalUnPacket_0200, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_IncrementalUnPacket_0200"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_IncrementalUnPacket_0200"); string root = tm.GetRootDirCurTest(); // 构造tarFile不存在 string tarFile = root + "/empty.0.tar"; string rootPath(root); unordered_map cloudFiles; auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().IncrementalUnPacket(tarFile, rootPath, cloudFiles); EXPECT_EQ(ret, 2); // 错误码2表示找不到文件或路径 ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_IncrementalUnPacket_0200"; } /** * @tc.number: SUB_Untar_File_IncrementalUnPacket_0300 * @tc.name: SUB_Untar_File_IncrementalUnPacket_0300 * @tc.desc: 测试 IncrementalUnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_IncrementalUnPacket_0300, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_IncrementalUnPacket_0300"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_IncrementalUnPacket_0300"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir/"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = "a.txt"; SaveStringToFile(aFile, "hello"); TarMap tarMap {}; vector smallFiles; smallFiles.emplace_back(aFile); auto reportCb = [](std::string msg, int err) { return; }; TarFile::GetInstance().Packet(smallFiles, "test", root, tarMap, reportCb); string tarFile = root + "/test.0.tar"; string rootPath(root); unordered_map cloudFiles; // 构造文件标头为空 FILE *currentTarFile = fopen(tarFile.c_str(), "wb+"); fwrite("\0", sizeof(uint8_t), 1, currentTarFile); fclose(currentTarFile); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().IncrementalUnPacket(tarFile, rootPath, cloudFiles); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_IncrementalUnPacket_0300"; } /** * @tc.number: SUB_Untar_File_IncrementalUnPacket_0400 * @tc.name: SUB_Untar_File_IncrementalUnPacket_0400 * @tc.desc: 测试 IncrementalUnPacket 接口 * @tc.size: MEDIUM * @tc.type: FUNC * @tc.level Level 1 * @tc.require: I6F3GV */ HWTEST_F(UntarFileTest, SUB_Untar_File_IncrementalUnPacket_0400, testing::ext::TestSize.Level1) { GTEST_LOG_(INFO) << "UntarFileTest-begin SUB_Untar_File_IncrementalUnPacket_0400"; try { // 预置文件和目录 TestManager tm("SUB_Untar_File_IncrementalUnPacket_0400"); string root = tm.GetRootDirCurTest(); string testDir = root + "/testdir/"; if (mkdir(testDir.data(), S_IRWXU) && errno != EEXIST) { GTEST_LOG_(INFO) << " invoked mkdir failure, errno :" << errno; throw BError(errno); } string aFile = testDir; string bFile = testDir; // 循环100次,用来构造超长路径和超长文件名 for (int i = 0; i < 100; i++) { aFile += "test001/test002/test003/test004/test005/"; bFile += "ab"; } aFile += "a.txt"; bFile += ".txt"; SaveStringToFile(aFile, "hello"); SaveStringToFile(bFile, "world"); TarMap tarMap {}; vector smallFiles; smallFiles.emplace_back(aFile); smallFiles.emplace_back(bFile); auto reportCb = [](std::string msg, int err) { return; }; TarFile::GetInstance().Packet(smallFiles, "test", root, tarMap, reportCb); string tarFile = root + "/test.0.tar"; string rootPath(root); unordered_map cloudFiles; // 构造文件标头为空 FILE *currentTarFile = fopen(tarFile.c_str(), "wb+"); fseeko(currentTarFile, 1L, SEEK_SET); fwrite("\0", sizeof(uint8_t), 1, currentTarFile); fclose(currentTarFile); auto [ret, fileInfos, errFileInfos] = UntarFile::GetInstance().IncrementalUnPacket(tarFile, rootPath, cloudFiles); EXPECT_EQ(ret, 0); ClearCache(); } catch (...) { EXPECT_TRUE(false); GTEST_LOG_(INFO) << "UntarFileTest-an exception occurred by UntarFile."; } GTEST_LOG_(INFO) << "UntarFileTest-end SUB_Untar_File_IncrementalUnPacket_0400"; } } // namespace OHOS::FileManagement::Backup