Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1495)

Unified Diff: third_party/zlib/google/zip_reader_unittest.cc

Issue 92873003: Adds asynchronous unzip functions to ZipReader (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Cleanup Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/zlib/google/zip_reader_unittest.cc
diff --git a/third_party/zlib/google/zip_reader_unittest.cc b/third_party/zlib/google/zip_reader_unittest.cc
index 09efd9a7a669ec0707853111f8394ed9998a61d9..88ed4d3d912f71caf74a16501bbce53ade6e979d 100644
--- a/third_party/zlib/google/zip_reader_unittest.cc
+++ b/third_party/zlib/google/zip_reader_unittest.cc
@@ -11,16 +11,24 @@
#include "base/files/scoped_temp_dir.h"
#include "base/logging.h"
#include "base/md5.h"
+#include "base/message_loop/message_loop.h"
#include "base/path_service.h"
#include "base/platform_file.h"
+#include "base/run_loop.h"
#include "base/strings/utf_string_conversions.h"
#include "base/time/time.h"
+#include "testing/gmock/include/gmock/gmock.h"
satorux1 2013/12/05 04:39:37 gmock should usually be avoided in Chrome code.
Drew Haven 2013/12/09 23:33:12 I personally like gmock for mocking out interfaces
#include "testing/gtest/include/gtest/gtest.h"
#include "testing/platform_test.h"
#include "third_party/zlib/google/zip_internal.h"
namespace {
+using testing::_;
+using testing::AtLeast;
+
+const static std::string kQuuxExpectedMD5 = "d1ae4ac8a17a0e09317113ab284b57a6";
+
// Wrap PlatformFiles in a class so that we don't leak them in tests.
class PlatformFileWrapper {
public:
@@ -61,6 +69,28 @@ class PlatformFileWrapper {
base::PlatformFile file_;
};
+class MockListener : public zip::ZipReader::Listener {
+ public:
+ MockListener() {}
+ MOCK_METHOD1(OnUnzipProgress, void(int progress));
+ MOCK_METHOD0(OnUnzipSuccess, void());
+ MOCK_METHOD0(OnUnzipFailed, void());
+
+ void ExpectSuccess() {
+ EXPECT_CALL(*this, OnUnzipSuccess());
+ EXPECT_CALL(*this, OnUnzipFailed()).Times(0);
+ EXPECT_CALL(*this, OnUnzipProgress(_)).Times(AtLeast(0));
+ }
+
+ void ExpectSuccessWithProgress() {
+ EXPECT_CALL(*this, OnUnzipSuccess());
+ EXPECT_CALL(*this, OnUnzipFailed()).Times(0);
+ EXPECT_CALL(*this, OnUnzipProgress(_)).Times(AtLeast(1));
satorux1 2013/12/05 04:39:37 Instead of checking with GMock, can you do somethi
Drew Haven 2013/12/09 23:33:12 I was originally reporting the percentage because
+ }
+ protected:
+ virtual ~MockListener() { }
+};
+
} // namespace
namespace zip {
@@ -94,6 +124,9 @@ class ZipReaderTest : public PlatformTest {
test_zip_contents_.insert(base::FilePath(FILE_PATH_LITERAL("foo.txt")));
test_zip_contents_.insert(
base::FilePath(FILE_PATH_LITERAL("foo/bar/.hidden")));
+
+ mock_listener_ = new MockListener;
+ message_loop_proxy_ = base::MessageLoop::current()->message_loop_proxy();
}
virtual void TearDown() {
@@ -113,6 +146,15 @@ class ZipReaderTest : public PlatformTest {
return true;
}
+ void CompareFileAndMD5(const base::FilePath& path,
+ const std::string expected_md5) {
+ // Read the output file and compute the MD5.
+ std::string output;
+ ASSERT_TRUE(base::ReadFileToString(path, &output));
+ const std::string md5 = base::MD5String(output);
+ EXPECT_EQ(expected_md5, md5);
+ }
+
// The path to temporary directory used to contain the test operations.
base::FilePath test_dir_;
// The path to the test data directory where test.zip etc. are located.
@@ -128,6 +170,10 @@ class ZipReaderTest : public PlatformTest {
std::set<base::FilePath> test_zip_contents_;
base::ScopedTempDir temp_dir_;
+
+ scoped_refptr<MockListener> mock_listener_;
+ base::MessageLoop message_loop_;
+ scoped_refptr<base::MessageLoopProxy> message_loop_proxy_;
};
TEST_F(ZipReaderTest, Open_ValidZipFile) {
@@ -220,8 +266,7 @@ TEST_F(ZipReaderTest, ExtractCurrentEntryToFilePath_RegularFile) {
ASSERT_TRUE(base::ReadFileToString(test_dir_.AppendASCII("quux.txt"),
&output));
const std::string md5 = base::MD5String(output);
- const std::string kExpectedMD5 = "d1ae4ac8a17a0e09317113ab284b57a6";
- EXPECT_EQ(kExpectedMD5, md5);
+ EXPECT_EQ(kQuuxExpectedMD5, md5);
// quux.txt should be larger than kZipBufSize so that we can exercise
// the loop in ExtractCurrentEntry().
EXPECT_LT(static_cast<size_t>(internal::kZipBufSize), output.size());
@@ -241,8 +286,7 @@ TEST_F(ZipReaderTest, PlatformFileExtractCurrentEntryToFilePath_RegularFile) {
ASSERT_TRUE(base::ReadFileToString(test_dir_.AppendASCII("quux.txt"),
&output));
const std::string md5 = base::MD5String(output);
- const std::string kExpectedMD5 = "d1ae4ac8a17a0e09317113ab284b57a6";
- EXPECT_EQ(kExpectedMD5, md5);
+ EXPECT_EQ(kQuuxExpectedMD5, md5);
// quux.txt should be larger than kZipBufSize so that we can exercise
// the loop in ExtractCurrentEntry().
EXPECT_LT(static_cast<size_t>(internal::kZipBufSize), output.size());
@@ -264,8 +308,7 @@ TEST_F(ZipReaderTest, PlatformFileExtractCurrentEntryToFd_RegularFile) {
ASSERT_TRUE(base::ReadFileToString(test_dir_.AppendASCII("quux.txt"),
&output));
const std::string md5 = base::MD5String(output);
- const std::string kExpectedMD5 = "d1ae4ac8a17a0e09317113ab284b57a6";
- EXPECT_EQ(kExpectedMD5, md5);
+ EXPECT_EQ(kQuuxExpectedMD5, md5);
// quux.txt should be larger than kZipBufSize so that we can exercise
// the loop in ExtractCurrentEntry().
EXPECT_LT(static_cast<size_t>(internal::kZipBufSize), output.size());
@@ -296,8 +339,7 @@ TEST_F(ZipReaderTest, ExtractCurrentEntryIntoDirectory_RegularFile) {
ASSERT_TRUE(base::ReadFileToString(
test_dir_.AppendASCII("foo/bar/quux.txt"), &output));
const std::string md5 = base::MD5String(output);
- const std::string kExpectedMD5 = "d1ae4ac8a17a0e09317113ab284b57a6";
- EXPECT_EQ(kExpectedMD5, md5);
+ EXPECT_EQ(kQuuxExpectedMD5, md5);
}
TEST_F(ZipReaderTest, current_entry_info_RegularFile) {
@@ -428,4 +470,102 @@ TEST_F(ZipReaderTest, OpenFromString) {
EXPECT_EQ(std::string("This is a test.\n"), actual);
}
+// Verifies that the asynchronous extraction to a file works.
+TEST_F(ZipReaderTest, ExtractToFileAsync_RegularFile) {
+ mock_listener_->ExpectSuccessWithProgress();
+
+ ZipReader reader;
+ base::FilePath target_file = test_dir_.AppendASCII("quux.txt");
+ base::FilePath target_path(FILE_PATH_LITERAL("foo/bar/quux.txt"));
+ ASSERT_TRUE(reader.Open(test_zip_file_));
+ ASSERT_TRUE(reader.LocateAndOpenEntry(target_path));
+ reader.ExtractCurrentEntryToFilePathAsync(target_file,
+ message_loop_proxy_,
+ mock_listener_);
+
+ base::RunLoop().RunUntilIdle();
+
+ CompareFileAndMD5(target_file, kQuuxExpectedMD5);
+}
+
+// Verifies that the asynchronous extraction to a file works.
+TEST_F(ZipReaderTest, ExtractToFileAsync_Directory) {
+ mock_listener_->ExpectSuccess();
+
+ ZipReader reader;
+ base::FilePath target_path(FILE_PATH_LITERAL("foo/"));
+ ASSERT_TRUE(reader.Open(test_zip_file_));
+ ASSERT_TRUE(reader.LocateAndOpenEntry(target_path));
+ reader.ExtractCurrentEntryToFilePathAsync(target_path,
+ message_loop_proxy_,
+ mock_listener_);
+
+ base::RunLoop().RunUntilIdle();
+
+ ASSERT_TRUE(base::DirectoryExists(target_path));
+}
+
+// Verifies that the asynchronous extraction to a directory works.
+TEST_F(ZipReaderTest, ExtractIntoDirectoryAsync_RegularFile) {
+ mock_listener_->ExpectSuccessWithProgress();
+
+ ZipReader reader;
+ base::FilePath target_path(FILE_PATH_LITERAL("foo/bar/quux.txt"));
+ base::FilePath target_file = test_dir_.AppendASCII("foo/bar/quux.txt");
+ ASSERT_TRUE(reader.Open(test_zip_file_));
+ ASSERT_TRUE(reader.LocateAndOpenEntry(target_path));
+ reader.ExtractCurrentEntryIntoDirectoryAsync(test_dir_,
+ message_loop_proxy_,
+ mock_listener_);
+
+ base::RunLoop().RunUntilIdle();
+
+ ASSERT_TRUE(base::DirectoryExists(test_dir_.AppendASCII("foo/bar")));
+ CompareFileAndMD5(target_file, kQuuxExpectedMD5);
+}
+
+#if defined(OS_POSIX)
+// Verifies that the asynchronous extraction to a file descriptor works.
+TEST_F(ZipReaderTest, ExtractToFdAsync) {
+ mock_listener_->ExpectSuccessWithProgress();
+
+ ZipReader reader;
+ PlatformFileWrapper zip_fd_wrapper(test_zip_file_,
+ PlatformFileWrapper::READ_ONLY);
+ ASSERT_TRUE(reader.OpenFromPlatformFile(zip_fd_wrapper.platform_file()));
+ base::FilePath target_path(FILE_PATH_LITERAL("foo/bar/quux.txt"));
+ base::FilePath out_path = test_dir_.AppendASCII("quux.txt");
+ PlatformFileWrapper out_fd_w(out_path, PlatformFileWrapper::READ_WRITE);
+ ASSERT_TRUE(reader.LocateAndOpenEntry(target_path));
+ reader.ExtractCurrentEntryToFdAsync(out_fd_w.platform_file(),
+ message_loop_proxy_,
+ mock_listener_);
+
+ base::RunLoop().RunUntilIdle();
+
+ CompareFileAndMD5(out_path, kQuuxExpectedMD5);
+}
+#endif
+
+// Verifies that the asynchronous extraction to a platform file works.
+TEST_F(ZipReaderTest, ExtractToPlatformFileAsync) {
+ mock_listener_->ExpectSuccessWithProgress();
+
+ ZipReader reader;
+ PlatformFileWrapper zip_fd_wrapper(test_zip_file_,
+ PlatformFileWrapper::READ_ONLY);
+ ASSERT_TRUE(reader.OpenFromPlatformFile(zip_fd_wrapper.platform_file()));
+ base::FilePath target_path(FILE_PATH_LITERAL("foo/bar/quux.txt"));
+ base::FilePath out_path = test_dir_.AppendASCII("quux.txt");
+ PlatformFileWrapper out_fd_w(out_path, PlatformFileWrapper::READ_WRITE);
+ ASSERT_TRUE(reader.LocateAndOpenEntry(target_path));
+ reader.ExtractCurrentEntryToPlatformFileAsync(out_fd_w.platform_file(),
+ message_loop_proxy_,
+ mock_listener_);
+
+ base::RunLoop().RunUntilIdle();
+
+ CompareFileAndMD5(out_path, kQuuxExpectedMD5);
+}
+
} // namespace zip
« third_party/zlib/google/zip_reader.cc ('K') | « third_party/zlib/google/zip_reader.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698