OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/file_util.h" | 5 #include "base/file_util.h" |
6 #include "base/path_service.h" | 6 #include "base/path_service.h" |
7 #include "base/scoped_temp_dir.h" | 7 #include "base/scoped_temp_dir.h" |
8 #include "base/string_util.h" | 8 #include "base/string_util.h" |
9 #include "base/utf_string_conversions.h" | 9 #include "base/utf_string_conversions.h" |
10 #include "base/values.h" | 10 #include "base/values.h" |
11 #include "chrome/common/chrome_paths.h" | 11 #include "chrome/common/chrome_paths.h" |
| 12 #include "chrome/common/extensions/extension_constants.h" |
12 #include "chrome/common/extensions/extension_manifest_constants.h" | 13 #include "chrome/common/extensions/extension_manifest_constants.h" |
13 #include "chrome/common/extensions/unpacker.h" | 14 #include "chrome/common/extensions/unpacker.h" |
14 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
15 #include "third_party/skia/include/core/SkBitmap.h" | 16 #include "third_party/skia/include/core/SkBitmap.h" |
16 | 17 |
17 namespace errors = extension_manifest_errors; | 18 namespace errors = extension_manifest_errors; |
| 19 namespace filenames = extension_filenames; |
18 namespace keys = extension_manifest_keys; | 20 namespace keys = extension_manifest_keys; |
19 | 21 |
20 namespace extensions { | 22 namespace extensions { |
21 | 23 |
22 class UnpackerTest : public testing::Test { | 24 class UnpackerTest : public testing::Test { |
23 public: | 25 public: |
24 ~UnpackerTest() { | 26 ~UnpackerTest() { |
25 LOG(WARNING) << "Deleting temp dir: " | 27 LOG(WARNING) << "Deleting temp dir: " |
26 << temp_dir_.path().LossyDisplayName(); | 28 << temp_dir_.path().LossyDisplayName(); |
27 LOG(WARNING) << temp_dir_.Delete(); | 29 LOG(WARNING) << temp_dir_.Delete(); |
(...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
184 #else | 186 #else |
185 #define MAYBE_NoL10n NoL10n | 187 #define MAYBE_NoL10n NoL10n |
186 #endif | 188 #endif |
187 TEST_F(UnpackerTest, MAYBE_NoL10n) { | 189 TEST_F(UnpackerTest, MAYBE_NoL10n) { |
188 SetupUnpacker("no_l10n.crx"); | 190 SetupUnpacker("no_l10n.crx"); |
189 EXPECT_TRUE(unpacker_->Run()); | 191 EXPECT_TRUE(unpacker_->Run()); |
190 EXPECT_TRUE(unpacker_->error_message().empty()); | 192 EXPECT_TRUE(unpacker_->error_message().empty()); |
191 EXPECT_EQ(0U, unpacker_->parsed_catalogs()->size()); | 193 EXPECT_EQ(0U, unpacker_->parsed_catalogs()->size()); |
192 } | 194 } |
193 | 195 |
| 196 // Disabled on Windows because it probably crashes intermittently as described |
| 197 // in <http://crbug.com/109238>. However, because the logic being testing here |
| 198 // is platform-independant, this test should still provide good coverage. |
| 199 #if defined(OS_WIN) |
| 200 #define MAYBE_UnzipDirectoryError DISABLED_UnzipDirectoryError |
| 201 #else |
| 202 #define MAYBE_UnzipDirectoryError UnzipDirectoryError |
| 203 #endif |
| 204 TEST_F(UnpackerTest, MAYBE_UnzipDirectoryError) { |
| 205 const char* kExpected = "Could not create directory for unzipping: "; |
| 206 SetupUnpacker("good_package.crx"); |
| 207 FilePath path = temp_dir_.path().AppendASCII(filenames::kTempExtensionName); |
| 208 ASSERT_TRUE(file_util::WriteFile(path, "foo", 3)); |
| 209 EXPECT_FALSE(unpacker_->Run()); |
| 210 EXPECT_TRUE(StartsWith(unpacker_->error_message(), |
| 211 ASCIIToUTF16(kExpected), |
| 212 false)) << "Expected prefix: \"" << kExpected |
| 213 << "\", actual error: \"" << unpacker_->error_message() |
| 214 << "\""; |
| 215 } |
| 216 |
| 217 // Disabled on Windows because it probably crashes intermittently as described |
| 218 // in <http://crbug.com/109238>. However, because the logic being testing here |
| 219 // is platform-independant, this test should still provide good coverage. |
| 220 #if defined(OS_WIN) |
| 221 #define MAYBE_UnzipError DISABLED_UnzipError |
| 222 #else |
| 223 #define MAYBE_UnzipError UnzipError |
| 224 #endif |
| 225 TEST_F(UnpackerTest, MAYBE_UnzipError) { |
| 226 const char* kExpected = "Could not unzip extension"; |
| 227 SetupUnpacker("bad_zip.crx"); |
| 228 EXPECT_FALSE(unpacker_->Run()); |
| 229 EXPECT_EQ(ASCIIToUTF16(kExpected), unpacker_->error_message()); |
| 230 } |
| 231 |
| 232 // Disabled on Windows because it probably crashes intermittently as described |
| 233 // in <http://crbug.com/109238>. However, because the logic being testing here |
| 234 // is platform-independant, this test should still provide good coverage. |
| 235 #if defined(OS_WIN) |
| 236 #define MAYBE_BadPathError DISABLED_BadPathError |
| 237 #else |
| 238 #define MAYBE_BadPathError BadPathError |
| 239 #endif |
| 240 TEST_F(UnpackerTest, MAYBE_BadPathError) { |
| 241 const char* kExpected = "Illegal path (absolute or relative with '..'): "; |
| 242 SetupUnpacker("bad_path.crx"); |
| 243 EXPECT_FALSE(unpacker_->Run()); |
| 244 EXPECT_TRUE(StartsWith(unpacker_->error_message(), |
| 245 ASCIIToUTF16(kExpected), |
| 246 false)) << "Expected prefix: \"" << kExpected |
| 247 << "\", actual error: \"" << unpacker_->error_message() |
| 248 << "\""; |
| 249 } |
| 250 |
| 251 |
| 252 // Disabled on Windows because it probably crashes intermittently as described |
| 253 // in <http://crbug.com/109238>. However, because the logic being testing here |
| 254 // is platform-independant, this test should still provide good coverage. |
| 255 #if defined(OS_WIN) |
| 256 #define MAYBE_ImageDecodingError DISABLED_ImageDecodingError |
| 257 #else |
| 258 #define MAYBE_ImageDecodingError ImageDecodingError |
| 259 #endif |
| 260 TEST_F(UnpackerTest, MAYBE_ImageDecodingError) { |
| 261 const char* kExpected = "Could not decode image: "; |
| 262 SetupUnpacker("bad_image.crx"); |
| 263 EXPECT_FALSE(unpacker_->Run()); |
| 264 EXPECT_TRUE(StartsWith(unpacker_->error_message(), |
| 265 ASCIIToUTF16(kExpected), |
| 266 false)) << "Expected prefix: \"" << kExpected |
| 267 << "\", actual error: \"" << unpacker_->error_message() |
| 268 << "\""; |
| 269 } |
| 270 |
194 } // namespace extensions | 271 } // namespace extensions |
OLD | NEW |