summaryrefslogtreecommitdiffstats
path: root/extensions/browser/verified_contents_unittest.cc
diff options
context:
space:
mode:
authorasargent <asargent@chromium.org>2014-09-26 14:15:25 -0700
committerCommit bot <commit-bot@chromium.org>2014-09-26 21:15:46 +0000
commit49264e03b28ad3813382bef032839eddf893fa7e (patch)
tree6894d1f42c019d9d802217d790e96592f24b33b1 /extensions/browser/verified_contents_unittest.cc
parentaaaae22e5c7a31658ecb7a562d4d6562d54fe2e7 (diff)
downloadchromium_src-49264e03b28ad3813382bef032839eddf893fa7e.zip
chromium_src-49264e03b28ad3813382bef032839eddf893fa7e.tar.gz
chromium_src-49264e03b28ad3813382bef032839eddf893fa7e.tar.bz2
Fix case-sensitivity problems in extension content verification
On case-insensitive filesystems, extensions can generate requests (script src tags, XHR's, etc.) to their own resources using a relative path with incorrect case and have those requests work (see crbug.com/29941 for some history). However, for extension content verification, we were looking up the expected file content hashes using the relative path given in the request, not the actual filename, which meant that any difference in case would be treated as "no hashes for this file". This patch switches to using case-insensitive lookups, but uses a multimap so that case-sensitive filesystems should not experience problems. BUG=412693 TEST=Install the test extension at http://goo.gl/rOpGDu, and turn on content verification to Enforce mode in about:flags. Without this patch, the extension will get force disabled on windows/mac. With the patch, this should be fixed. Review URL: https://codereview.chromium.org/585583003 Cr-Commit-Position: refs/heads/master@{#297032}
Diffstat (limited to 'extensions/browser/verified_contents_unittest.cc')
-rw-r--r--extensions/browser/verified_contents_unittest.cc90
1 files changed, 64 insertions, 26 deletions
diff --git a/extensions/browser/verified_contents_unittest.cc b/extensions/browser/verified_contents_unittest.cc
index 80f1f81..865129c 100644
--- a/extensions/browser/verified_contents_unittest.cc
+++ b/extensions/browser/verified_contents_unittest.cc
@@ -19,21 +19,14 @@ namespace extensions {
namespace {
-bool Base64UrlStringEquals(std::string input, const std::string* bytes) {
- if (!bytes)
- return false;
- if (!VerifiedContents::FixupBase64Encoding(&input))
- return false;
+std::string DecodeBase64Url(const std::string& encoded) {
+ std::string fixed_up_base64 = encoded;
+ if (!VerifiedContents::FixupBase64Encoding(&fixed_up_base64))
+ return std::string();
std::string decoded;
- if (!base::Base64Decode(input, &decoded))
- return false;
- if (decoded.size() != bytes->size())
- return false;
-
- if (bytes->empty())
- return true;
-
- return decoded == *bytes;
+ if (!base::Base64Decode(fixed_up_base64, &decoded))
+ return std::string();
+ return decoded;
}
bool GetPublicKey(const base::FilePath& path, std::string* public_key) {
@@ -68,24 +61,69 @@ TEST(VerifiedContents, Simple) {
EXPECT_EQ(contents.extension_id(), "abcdefghijklmnopabcdefghijklmnop");
EXPECT_EQ("1.2.3", contents.version().GetString());
- EXPECT_TRUE(Base64UrlStringEquals(
- "-vyyIIn7iSCzg7X3ICUI5wZa3tG7w7vyiCckxZdJGfs",
- contents.GetTreeHashRoot(
- base::FilePath::FromUTF8Unsafe("manifest.json"))));
- EXPECT_TRUE(Base64UrlStringEquals(
- "txHiG5KQvNoPOSH5FbQo9Zb5gJ23j3oFB0Ru9DOnziw",
- contents.GetTreeHashRoot(
- base::FilePath::FromUTF8Unsafe("background.js"))));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("manifest.json"),
+ DecodeBase64Url("-vyyIIn7iSCzg7X3ICUI5wZa3tG7w7vyiCckxZdJGfs")));
+
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("background.js"),
+ DecodeBase64Url("txHiG5KQvNoPOSH5FbQo9Zb5gJ23j3oFB0Ru9DOnziw")));
base::FilePath foo_bar_html =
base::FilePath(FILE_PATH_LITERAL("foo")).AppendASCII("bar.html");
EXPECT_FALSE(foo_bar_html.IsAbsolute());
- EXPECT_TRUE(
- Base64UrlStringEquals("L37LFbT_hmtxRL7AfGZN9YTpW6yoz_ZiQ1opLJn1NZU",
- contents.GetTreeHashRoot(foo_bar_html)));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ foo_bar_html,
+ DecodeBase64Url("L37LFbT_hmtxRL7AfGZN9YTpW6yoz_ZiQ1opLJn1NZU")));
base::FilePath nonexistent = base::FilePath::FromUTF8Unsafe("nonexistent");
- EXPECT_TRUE(contents.GetTreeHashRoot(nonexistent) == NULL);
+ EXPECT_FALSE(contents.HasTreeHashRoot(nonexistent));
+
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("lowercase.html"),
+ DecodeBase64Url("HpLotLGCmmOdKYvGQmD3OkXMKGs458dbanY4WcfAZI0")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("Lowercase.Html"),
+ DecodeBase64Url("HpLotLGCmmOdKYvGQmD3OkXMKGs458dbanY4WcfAZI0")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("LOWERCASE.HTML"),
+ DecodeBase64Url("HpLotLGCmmOdKYvGQmD3OkXMKGs458dbanY4WcfAZI0")));
+
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("ALLCAPS.HTML"),
+ DecodeBase64Url("bl-eV8ENowvtw6P14D4X1EP0mlcMoG-_aOx5o9C1364")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("AllCaps.Html"),
+ DecodeBase64Url("bl-eV8ENowvtw6P14D4X1EP0mlcMoG-_aOx5o9C1364")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("allcaps.html"),
+ DecodeBase64Url("bl-eV8ENowvtw6P14D4X1EP0mlcMoG-_aOx5o9C1364")));
+
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("MixedCase.Html"),
+ DecodeBase64Url("zEAO9FwciigMNy3NtU2XNb-dS5TQMmVNx0T9h7WvXbQ")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("MIXEDCASE.HTML"),
+ DecodeBase64Url("zEAO9FwciigMNy3NtU2XNb-dS5TQMmVNx0T9h7WvXbQ")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("mixedcase.html"),
+ DecodeBase64Url("zEAO9FwciigMNy3NtU2XNb-dS5TQMmVNx0T9h7WvXbQ")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("mIxedcAse.Html"),
+ DecodeBase64Url("zEAO9FwciigMNy3NtU2XNb-dS5TQMmVNx0T9h7WvXbQ")));
+
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("mIxedcAse.Html"),
+ DecodeBase64Url("nKRqUcJg1_QZWAeCb4uFd5ouC0McuGavKp8TFDRqBgg")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("MIXEDCASE.HTML"),
+ DecodeBase64Url("nKRqUcJg1_QZWAeCb4uFd5ouC0McuGavKp8TFDRqBgg")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("mixedcase.html"),
+ DecodeBase64Url("nKRqUcJg1_QZWAeCb4uFd5ouC0McuGavKp8TFDRqBgg")));
+ EXPECT_TRUE(contents.TreeHashRootEquals(
+ base::FilePath::FromUTF8Unsafe("MixedCase.Html"),
+ DecodeBase64Url("nKRqUcJg1_QZWAeCb4uFd5ouC0McuGavKp8TFDRqBgg")));
}
} // namespace extensions