summaryrefslogtreecommitdiffstats
path: root/extensions/utility
diff options
context:
space:
mode:
Diffstat (limited to 'extensions/utility')
-rw-r--r--extensions/utility/unpacker_unittest.cc205
1 files changed, 205 insertions, 0 deletions
diff --git a/extensions/utility/unpacker_unittest.cc b/extensions/utility/unpacker_unittest.cc
new file mode 100644
index 0000000..917f66e
--- /dev/null
+++ b/extensions/utility/unpacker_unittest.cc
@@ -0,0 +1,205 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "base/files/file_util.h"
+#include "base/files/scoped_temp_dir.h"
+#include "base/path_service.h"
+#include "base/strings/string_util.h"
+#include "base/strings/utf_string_conversions.h"
+#include "base/values.h"
+#include "extensions/common/constants.h"
+#include "extensions/common/extension.h"
+#include "extensions/common/extension_paths.h"
+#include "extensions/common/manifest_constants.h"
+#include "extensions/test/test_extensions_client.h"
+#include "extensions/utility/unpacker.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+
+using base::ASCIIToUTF16;
+
+namespace extensions {
+
+namespace errors = manifest_errors;
+namespace keys = manifest_keys;
+
+class UnpackerTest : public testing::Test {
+ public:
+ ~UnpackerTest() override {
+ VLOG(1) << "Deleting temp dir: " << temp_dir_.path().LossyDisplayName();
+ VLOG(1) << temp_dir_.Delete();
+ }
+
+ void SetupUnpacker(const std::string& crx_name) {
+ base::FilePath original_path;
+ ASSERT_TRUE(PathService::Get(DIR_TEST_DATA, &original_path));
+ original_path = original_path.AppendASCII("unpacker").AppendASCII(crx_name);
+ ASSERT_TRUE(base::PathExists(original_path)) << original_path.value();
+
+ // Try bots won't let us write into DIR_TEST_DATA, so we have to create
+ // a temp folder to play in.
+ ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
+
+ base::FilePath crx_path = temp_dir_.path().AppendASCII(crx_name);
+ ASSERT_TRUE(base::CopyFile(original_path, crx_path))
+ << "Original path " << original_path.value() << ", Crx path "
+ << crx_path.value();
+
+ unpacker_.reset(new Unpacker(crx_path, std::string(), Manifest::INTERNAL,
+ Extension::NO_FLAGS));
+ }
+
+ protected:
+ base::ScopedTempDir temp_dir_;
+ scoped_ptr<Unpacker> unpacker_;
+};
+
+TEST_F(UnpackerTest, EmptyDefaultLocale) {
+ SetupUnpacker("empty_default_locale.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kInvalidDefaultLocale),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, HasDefaultLocaleMissingLocalesFolder) {
+ SetupUnpacker("has_default_missing_locales.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kLocalesTreeMissing),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, InvalidDefaultLocale) {
+ SetupUnpacker("invalid_default_locale.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kInvalidDefaultLocale),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, InvalidMessagesFile) {
+ SetupUnpacker("invalid_messages_file.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_TRUE(
+ MatchPattern(unpacker_->error_message(),
+ ASCIIToUTF16(
+ "*_locales?en_US?messages.json: Line: 2, column: 11,"
+ " Syntax error.")))
+ << unpacker_->error_message();
+}
+
+TEST_F(UnpackerTest, MissingDefaultData) {
+ SetupUnpacker("missing_default_data.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kLocalesNoDefaultMessages),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, MissingDefaultLocaleHasLocalesFolder) {
+ SetupUnpacker("missing_default_has_locales.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kLocalesNoDefaultLocaleSpecified),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, MissingMessagesFile) {
+ SetupUnpacker("missing_messages_file.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_TRUE(MatchPattern(unpacker_->error_message(),
+ ASCIIToUTF16(errors::kLocalesMessagesFileMissing) +
+ ASCIIToUTF16("*_locales?en_US?messages.json")));
+}
+
+TEST_F(UnpackerTest, NoLocaleData) {
+ SetupUnpacker("no_locale_data.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(errors::kLocalesNoDefaultMessages),
+ unpacker_->error_message());
+}
+
+TEST_F(UnpackerTest, GoodL10n) {
+ SetupUnpacker("good_l10n.crx");
+ EXPECT_TRUE(unpacker_->Run());
+ EXPECT_TRUE(unpacker_->error_message().empty());
+ ASSERT_EQ(2U, unpacker_->parsed_catalogs()->size());
+}
+
+TEST_F(UnpackerTest, NoL10n) {
+ SetupUnpacker("no_l10n.crx");
+ EXPECT_TRUE(unpacker_->Run());
+ EXPECT_TRUE(unpacker_->error_message().empty());
+ EXPECT_EQ(0U, unpacker_->parsed_catalogs()->size());
+}
+
+TEST_F(UnpackerTest, UnzipDirectoryError) {
+ const char kExpected[] = "Could not create directory for unzipping: ";
+ SetupUnpacker("good_package.crx");
+ base::FilePath path = temp_dir_.path().AppendASCII(kTempExtensionName);
+ ASSERT_TRUE(base::WriteFile(path, "foo", 3));
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_TRUE(
+ StartsWith(unpacker_->error_message(), ASCIIToUTF16(kExpected), false))
+ << "Expected prefix: \"" << kExpected << "\", actual error: \""
+ << unpacker_->error_message() << "\"";
+}
+
+TEST_F(UnpackerTest, UnzipError) {
+ const char kExpected[] = "Could not unzip extension";
+ SetupUnpacker("bad_zip.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_EQ(ASCIIToUTF16(kExpected), unpacker_->error_message());
+}
+
+namespace {
+
+// Inserts an illegal path into the browser images returned by
+// TestExtensionsClient for any extension.
+class IllegalImagePathInserter
+ : public TestExtensionsClient::BrowserImagePathsFilter {
+ public:
+ IllegalImagePathInserter(TestExtensionsClient* client) : client_(client) {
+ client_->AddBrowserImagePathsFilter(this);
+ }
+
+ virtual ~IllegalImagePathInserter() {
+ client_->RemoveBrowserImagePathsFilter(this);
+ }
+
+ void Filter(const Extension* extension,
+ std::set<base::FilePath>* paths) override {
+ base::FilePath illegal_path =
+ base::FilePath(base::FilePath::kParentDirectory)
+ .AppendASCII(kTempExtensionName)
+ .AppendASCII("product_logo_128.png");
+ paths->insert(illegal_path);
+ }
+
+ private:
+ TestExtensionsClient* client_;
+};
+
+} // namespace
+
+TEST_F(UnpackerTest, BadPathError) {
+ const char kExpected[] = "Illegal path (absolute or relative with '..'): ";
+ SetupUnpacker("good_package.crx");
+ IllegalImagePathInserter inserter(
+ static_cast<TestExtensionsClient*>(ExtensionsClient::Get()));
+
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_TRUE(
+ StartsWith(unpacker_->error_message(), ASCIIToUTF16(kExpected), false))
+ << "Expected prefix: \"" << kExpected << "\", actual error: \""
+ << unpacker_->error_message() << "\"";
+}
+
+TEST_F(UnpackerTest, ImageDecodingError) {
+ const char kExpected[] = "Could not decode image: ";
+ SetupUnpacker("bad_image.crx");
+ EXPECT_FALSE(unpacker_->Run());
+ EXPECT_TRUE(
+ StartsWith(unpacker_->error_message(), ASCIIToUTF16(kExpected), false))
+ << "Expected prefix: \"" << kExpected << "\", actual error: \""
+ << unpacker_->error_message() << "\"";
+}
+
+} // namespace extensions