summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-28 02:30:43 +0000
committeraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-28 02:30:43 +0000
commited45566a74d2a8dae55ab4e2589ce5f0d78e49b2 (patch)
tree7c24abaa9d7e76f2482e9ef75be0c25bc2319a9a
parenta4c34a20c8b0a2fae699edbacf1e82655dab147f (diff)
downloadchromium_src-ed45566a74d2a8dae55ab4e2589ce5f0d78e49b2.zip
chromium_src-ed45566a74d2a8dae55ab4e2589ce5f0d78e49b2.tar.gz
chromium_src-ed45566a74d2a8dae55ab4e2589ce5f0d78e49b2.tar.bz2
Filter out hidden files, both when loading extensions and when
packaging them. We also special case the common OS X zip dropping "__MACOSX" when loading extensions. BUG=23004 Review URL: http://codereview.chromium.org/340018 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30312 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/extensions/extension_creator.cc2
-rw-r--r--chrome/browser/extensions/extension_file_util.cc3
-rw-r--r--chrome/common/zip.cc6
-rw-r--r--chrome/common/zip.h5
-rw-r--r--chrome/common/zip_unittest.cc42
-rwxr-xr-x[-rw-r--r--]chrome/test/data/zip/test.zipbin4952 -> 5065 bytes
-rw-r--r--chrome/test/data/zip/test/foo/bar/.hidden1
-rwxr-xr-x[-rw-r--r--]chrome/test/data/zip/test_nocompress.zipbin14139 -> 14252 bytes
8 files changed, 46 insertions, 13 deletions
diff --git a/chrome/browser/extensions/extension_creator.cc b/chrome/browser/extensions/extension_creator.cc
index 8f65ad5..d9bc4d6 100644
--- a/chrome/browser/extensions/extension_creator.cc
+++ b/chrome/browser/extensions/extension_creator.cc
@@ -123,7 +123,7 @@ bool ExtensionCreator::CreateZip(const FilePath& extension_dir,
file_util::CreateNewTempDirectory(FILE_PATH_LITERAL("chrome_"), zip_path);
*zip_path = zip_path->Append(FILE_PATH_LITERAL("extension.zip"));
- if (!Zip(extension_dir, *zip_path)) {
+ if (!Zip(extension_dir, *zip_path, false)) { // no hidden files
error_message_ = "Failed to create temporary zip file during packaging.";
return false;
}
diff --git a/chrome/browser/extensions/extension_file_util.cc b/chrome/browser/extensions/extension_file_util.cc
index 5b1e16c..26a551b 100644
--- a/chrome/browser/extensions/extension_file_util.cc
+++ b/chrome/browser/extensions/extension_file_util.cc
@@ -384,7 +384,8 @@ bool CheckForIllegalFilenames(const FilePath& extension_path,
std::string* error) {
// Reserved underscore names.
static const char* reserved_names[] = {
- Extension::kLocaleFolder
+ Extension::kLocaleFolder,
+ "__MACOSX"
};
static std::set<std::string> reserved_underscore_names(
reserved_names, reserved_names + arraysize(reserved_names));
diff --git a/chrome/common/zip.cc b/chrome/common/zip.cc
index 9c0adea..097f035 100644
--- a/chrome/common/zip.cc
+++ b/chrome/common/zip.cc
@@ -258,7 +258,8 @@ static bool AddEntryToZip(zipFile zip_file, const FilePath& path,
return success;
}
-bool Zip(const FilePath& src_dir, const FilePath& dest_file) {
+bool Zip(const FilePath& src_dir, const FilePath& dest_file,
+ bool include_hidden_files) {
DCHECK(file_util::DirectoryExists(src_dir));
#if defined(OS_WIN)
@@ -291,6 +292,9 @@ bool Zip(const FilePath& src_dir, const FilePath& dest_file) {
file_util::FileEnumerator::DIRECTORIES));
for (FilePath path = file_enumerator.Next(); !path.value().empty();
path = file_enumerator.Next()) {
+ if (!include_hidden_files && path.BaseName().ToWStringHack()[0] == L'.')
+ continue;
+
if (!AddEntryToZip(zip_file, path, src_dir)) {
success = false;
return false;
diff --git a/chrome/common/zip.h b/chrome/common/zip.h
index 23823d8..2c3d456 100644
--- a/chrome/common/zip.h
+++ b/chrome/common/zip.h
@@ -12,7 +12,10 @@
// Zip the contents of src_dir into dest_file. src_path must be a directory.
// An entry will *not* be created in the zip for the root folder -- children
// of src_dir will be at the root level of the created zip.
-bool Zip(const FilePath& src_dir, const FilePath& dest_file);
+// If |include_hidden_files| is true, files starting with "." are included.
+// Otherwise they are omitted.
+bool Zip(const FilePath& src_dir, const FilePath& dest_file,
+ bool include_hidden_files);
// Unzip the contents of zip_file into dest_dir.
bool Unzip(const FilePath& zip_file, const FilePath& dest_dir);
diff --git a/chrome/common/zip_unittest.cc b/chrome/common/zip_unittest.cc
index dfa07249..ae43a09 100644
--- a/chrome/common/zip_unittest.cc
+++ b/chrome/common/zip_unittest.cc
@@ -33,20 +33,24 @@ class ZipTest : public PlatformTest {
zip_contents_.insert(zip_path);
zip_contents_.insert(zip_path.AppendASCII("baz.txt"));
zip_contents_.insert(zip_path.AppendASCII("quux.txt"));
+ zip_contents_.insert(zip_path.AppendASCII(".hidden"));
}
virtual void TearDown() {
PlatformTest::TearDown();
}
- void TestUnzipFile(const FilePath::StringType& filename, bool need_success) {
+ void TestUnzipFile(const FilePath::StringType& filename,
+ bool expect_hidden_files, bool need_success) {
FilePath test_dir;
ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_dir));
test_dir = test_dir.AppendASCII("zip");
- TestUnzipFile(test_dir.Append(filename), need_success);
+ TestUnzipFile(test_dir.Append(filename), expect_hidden_files,
+ need_success);
}
- void TestUnzipFile(const FilePath& path, bool need_success) {
+ void TestUnzipFile(const FilePath& path, bool expect_hidden_files,
+ bool need_success) {
ASSERT_TRUE(file_util::PathExists(path)) << "no file " << path.value();
if (need_success) {
ASSERT_TRUE(Unzip(path, test_dir_));
@@ -70,7 +74,15 @@ class ZipTest : public PlatformTest {
}
next_path = files.Next();
}
- EXPECT_EQ(count, zip_contents_.size());
+
+ size_t expected_count = 0;
+ for (std::set<FilePath>::iterator iter = zip_contents_.begin();
+ iter != zip_contents_.end(); ++iter) {
+ if (expect_hidden_files || iter->BaseName().ToWStringHack()[0] != L'.')
+ ++expected_count;
+ }
+
+ EXPECT_EQ(expected_count, count);
}
// the path to temporary directory used to contain the test operations
@@ -83,15 +95,15 @@ class ZipTest : public PlatformTest {
};
TEST_F(ZipTest, Unzip) {
- TestUnzipFile(FILE_PATH_LITERAL("test.zip"), true);
+ TestUnzipFile(FILE_PATH_LITERAL("test.zip"), true, true);
}
TEST_F(ZipTest, UnzipUncompressed) {
- TestUnzipFile(FILE_PATH_LITERAL("test_nocompress.zip"), true);
+ TestUnzipFile(FILE_PATH_LITERAL("test_nocompress.zip"), true, true);
}
TEST_F(ZipTest, UnzipEvil) {
- TestUnzipFile(FILE_PATH_LITERAL("evil.zip"), false);
+ TestUnzipFile(FILE_PATH_LITERAL("evil.zip"), true, false);
FilePath evil_file = test_dir_;
evil_file = evil_file.AppendASCII(
"../levilevilevilevilevilevilevilevilevilevilevilevil");
@@ -107,9 +119,21 @@ TEST_F(ZipTest, Zip) {
ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
FilePath zip_file = temp_dir.path().AppendASCII("out.zip");
- EXPECT_TRUE(Zip(src_dir, zip_file));
+ EXPECT_TRUE(Zip(src_dir, zip_file, true));
+ TestUnzipFile(zip_file, true, true);
+}
+
+TEST_F(ZipTest, ZipIgnoreHidden) {
+ FilePath src_dir;
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &src_dir));
+ src_dir = src_dir.AppendASCII("zip").AppendASCII("test");
+
+ ScopedTempDir temp_dir;
+ ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
+ FilePath zip_file = temp_dir.path().AppendASCII("out.zip");
- TestUnzipFile(zip_file, true);
+ EXPECT_TRUE(Zip(src_dir, zip_file, false));
+ TestUnzipFile(zip_file, false, true);
}
} // namespace
diff --git a/chrome/test/data/zip/test.zip b/chrome/test/data/zip/test.zip
index e32f108..4bafe30 100644..100755
--- a/chrome/test/data/zip/test.zip
+++ b/chrome/test/data/zip/test.zip
Binary files differ
diff --git a/chrome/test/data/zip/test/foo/bar/.hidden b/chrome/test/data/zip/test/foo/bar/.hidden
new file mode 100644
index 0000000..136c05e
--- /dev/null
+++ b/chrome/test/data/zip/test/foo/bar/.hidden
@@ -0,0 +1 @@
+hidden
diff --git a/chrome/test/data/zip/test_nocompress.zip b/chrome/test/data/zip/test_nocompress.zip
index f95e1d2..25d66c2 100644..100755
--- a/chrome/test/data/zip/test_nocompress.zip
+++ b/chrome/test/data/zip/test_nocompress.zip
Binary files differ