This source file includes following definitions.
- quit_
- OnZipDone
- success
- SetUpOnMainThread
- zip_archive_path
- zip_base_dir
- IN_PROC_BROWSER_TEST_F
- IN_PROC_BROWSER_TEST_F
#include "chrome/browser/chromeos/file_manager/zip_file_creator.h"
#include <vector>
#include "base/callback.h"
#include "base/file_util.h"
#include "base/files/file_path.h"
#include "base/files/scoped_temp_dir.h"
#include "base/rand_util.h"
#include "base/run_loop.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "content/public/test/test_utils.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/zlib/google/zip_reader.h"
namespace file_manager {
namespace {
class TestObserver : public ZipFileCreator::Observer {
public:
explicit TestObserver(const base::Closure& quit)
: success_(false), quit_(quit) {}
virtual void OnZipDone(bool success) OVERRIDE {
success_ = success;
quit_.Run();
}
const bool success() const { return success_; }
private:
bool success_;
const base::Closure quit_;
};
class ZipFileCreatorTest : public InProcessBrowserTest {
protected:
virtual void SetUpOnMainThread() OVERRIDE {
ASSERT_TRUE(dir_.CreateUniqueTempDir());
ASSERT_TRUE(base::CreateDirectory(zip_base_dir()));
}
base::FilePath zip_archive_path() const {
return dir_.path().AppendASCII("test.zip");
}
base::FilePath zip_base_dir() const {
return dir_.path().AppendASCII("files");
}
protected:
base::ScopedTempDir dir_;
};
}
IN_PROC_BROWSER_TEST_F(ZipFileCreatorTest, FailZipForAbsentFile) {
base::RunLoop run_loop;
TestObserver observer(content::GetQuitTaskForRunLoop(&run_loop));
std::vector<base::FilePath> paths;
paths.push_back(base::FilePath(FILE_PATH_LITERAL("not.exist")));
scoped_refptr<ZipFileCreator> zipper(new ZipFileCreator(
&observer, zip_base_dir(), paths, zip_archive_path()));
zipper->Start();
content::RunThisRunLoop(&run_loop);
EXPECT_FALSE(observer.success());
}
IN_PROC_BROWSER_TEST_F(ZipFileCreatorTest, SomeFilesZip) {
const base::FilePath kDir1(FILE_PATH_LITERAL("foo"));
const base::FilePath kFile1(kDir1.AppendASCII("bar"));
const base::FilePath kFile2(FILE_PATH_LITERAL("random"));
const int kRandomDataSize = 100000;
const std::string kRandomData = base::RandBytesAsString(kRandomDataSize);
base::CreateDirectory(zip_base_dir().Append(kDir1));
base::WriteFile(zip_base_dir().Append(kFile1), "123", 3);
base::WriteFile(zip_base_dir().Append(kFile2),
kRandomData.c_str(), kRandomData.size());
base::RunLoop run_loop;
TestObserver observer(content::GetQuitTaskForRunLoop(&run_loop));
std::vector<base::FilePath> paths;
paths.push_back(kDir1);
paths.push_back(kFile1);
paths.push_back(kFile2);
scoped_refptr<ZipFileCreator> zipper(new ZipFileCreator(
&observer, zip_base_dir(), paths, zip_archive_path()));
zipper->Start();
content::RunThisRunLoop(&run_loop);
EXPECT_TRUE(observer.success());
zip::ZipReader reader;
ASSERT_TRUE(reader.Open(zip_archive_path()));
EXPECT_EQ(3, reader.num_entries());
while (reader.HasMore()) {
ASSERT_TRUE(reader.OpenCurrentEntryInZip());
const zip::ZipReader::EntryInfo* entry = reader.current_entry_info();
if (entry->file_path() == kDir1.AsEndingWithSeparator()) {
EXPECT_TRUE(entry->is_directory());
} else if (entry->file_path() == kFile1) {
EXPECT_FALSE(entry->is_directory());
EXPECT_EQ(3, entry->original_size());
} else if (entry->file_path() == kFile2) {
EXPECT_FALSE(entry->is_directory());
EXPECT_EQ(kRandomDataSize, entry->original_size());
const base::FilePath out = dir_.path().AppendASCII("archived_content");
EXPECT_TRUE(reader.ExtractCurrentEntryToFilePath(out));
EXPECT_TRUE(base::ContentsEqual(zip_base_dir().Append(kFile2), out));
} else {
ADD_FAILURE();
}
ASSERT_TRUE(reader.AdvanceToNextEntry());
}
}
}