summaryrefslogtreecommitdiffstats
path: root/chrome/browser/content_settings/content_settings_pattern_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/content_settings/content_settings_pattern_unittest.cc')
-rw-r--r--chrome/browser/content_settings/content_settings_pattern_unittest.cc531
1 files changed, 49 insertions, 482 deletions
diff --git a/chrome/browser/content_settings/content_settings_pattern_unittest.cc b/chrome/browser/content_settings/content_settings_pattern_unittest.cc
index 57078d2..4882e34 100644
--- a/chrome/browser/content_settings/content_settings_pattern_unittest.cc
+++ b/chrome/browser/content_settings/content_settings_pattern_unittest.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Copyright (c) 2010 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.
@@ -9,503 +9,70 @@
namespace {
-ContentSettingsPattern Pattern(const std::string& str) {
- return ContentSettingsPattern::FromString(str);
-}
-
-} // namespace
-
-TEST(ContentSettingsPatternTest, RealWorldPatterns) {
- // This is the place for real world patterns that unveiled bugs.
- EXPECT_STREQ("[*.]ikea.com",
- Pattern("[*.]ikea.com").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, GURL) {
- // Document and verify GURL behavior.
- GURL url("http://mail.google.com:80");
- EXPECT_EQ(-1, url.IntPort());
- EXPECT_EQ("", url.port());
-
- url = GURL("http://mail.google.com");
- EXPECT_EQ(-1, url.IntPort());
- EXPECT_EQ("", url.port());
-
- url = GURL("https://mail.google.com:443");
- EXPECT_EQ(-1, url.IntPort());
- EXPECT_EQ("", url.port());
-
- url = GURL("https://mail.google.com");
- EXPECT_EQ(-1, url.IntPort());
- EXPECT_EQ("", url.port());
-
- url = GURL("http://mail.google.com");
- EXPECT_EQ(-1, url.IntPort());
- EXPECT_EQ("", url.port());
-}
-
-TEST(ContentSettingsPatternTest, FromURL) {
- // NOTICE: When content settings pattern are created from a GURL the following
- // happens:
- // - If the GURL scheme is "http" the scheme wildcard is used. Otherwise the
- // GURL scheme is used.
- // - A domain wildcard is added to the GURL host.
- // - A port wildcard is used instead of the schemes default port.
- // In case of non-default ports the specific GURL port is used.
- ContentSettingsPattern pattern = ContentSettingsPattern::FromURL(
- GURL("http://www.youtube.com"));
- EXPECT_TRUE(pattern.IsValid());
- EXPECT_STREQ("[*.]www.youtube.com", pattern.ToString().c_str());
-
- // Patterns created from a URL.
- pattern = ContentSettingsPattern::FromURL(GURL("http://www.google.com"));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com")));
- EXPECT_TRUE(pattern.Matches(GURL("http://foo.www.google.com")));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com:80")));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com:81")));
- EXPECT_FALSE(pattern.Matches(GURL("https://mail.google.com")));
- EXPECT_TRUE(pattern.Matches(GURL("https://www.google.com")));
-
- pattern = ContentSettingsPattern::FromURL(GURL("http://www.google.com:80"));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com")));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com:80")));
- EXPECT_TRUE(pattern.Matches(GURL("http://www.google.com:81")));
-
- pattern = ContentSettingsPattern::FromURL(GURL("https://www.google.com:443"));
- EXPECT_TRUE(pattern.Matches(GURL("https://www.google.com")));
- EXPECT_TRUE(pattern.Matches(GURL("https://www.google.com:443")));
- EXPECT_TRUE(pattern.Matches(GURL("https://www.google.com:444")));
- EXPECT_FALSE(pattern.Matches(GURL("http://www.google.com:443")));
-
- pattern = ContentSettingsPattern::FromURL(GURL("https://127.0.0.1"));
- EXPECT_TRUE(pattern.IsValid());
- EXPECT_STREQ("https://127.0.0.1", pattern.ToString().c_str());
-
- pattern = ContentSettingsPattern::FromURL(GURL("http://[::1]"));
- EXPECT_TRUE(pattern.IsValid());
-
- pattern = ContentSettingsPattern::FromURL(GURL("file:///foo/bar.html"));
- EXPECT_TRUE(pattern.IsValid());
- EXPECT_STREQ("file:///foo/bar.html", pattern.ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, FromURLNoWildcard) {
- // If no port is specifed GURLs always use the default port for the schemes
- // HTTP and HTTPS. Hence a GURL always carries a port specification either
- // explicitly or implicitly. Therefore if a content settings pattern is
- // created from a GURL with no wildcard, specific values are used for the
- // scheme, host and port part of the pattern.
- // Creating content settings patterns from strings behaves different. Pattern
- // parts that are omitted in pattern specifications (strings), are completed
- // with a wildcard.
- ContentSettingsPattern pattern = ContentSettingsPattern::FromURLNoWildcard(
- GURL("http://www.example.com"));
- EXPECT_TRUE(pattern.IsValid());
- EXPECT_STREQ("http://www.example.com:80", pattern.ToString().c_str());
- EXPECT_TRUE(pattern.Matches(GURL("http://www.example.com")));
- EXPECT_FALSE(pattern.Matches(GURL("https://www.example.com")));
- EXPECT_FALSE(pattern.Matches(GURL("http://foo.www.example.com")));
-
- pattern = ContentSettingsPattern::FromURLNoWildcard(
- GURL("https://www.example.com"));
- EXPECT_TRUE(pattern.IsValid());
- EXPECT_STREQ("https://www.example.com:443", pattern.ToString().c_str());
- EXPECT_FALSE(pattern.Matches(GURL("http://www.example.com")));
- EXPECT_TRUE(pattern.Matches(GURL("https://www.example.com")));
- EXPECT_FALSE(pattern.Matches(GURL("http://foo.www.example.com")));
-
- pattern = ContentSettingsPattern::FromURLNoWildcard(
- GURL("https://www.example.com"));
-}
-
-TEST(ContentSettingsPatternTest, Wildcard) {
- EXPECT_TRUE(ContentSettingsPattern::Wildcard().IsValid());
-
- EXPECT_TRUE(ContentSettingsPattern::Wildcard().Matches(
- GURL("http://www.google.com")));
- EXPECT_TRUE(ContentSettingsPattern::Wildcard().Matches(
- GURL("https://www.google.com")));
- EXPECT_TRUE(ContentSettingsPattern::Wildcard().Matches(
- GURL("https://myhost:8080")));
- EXPECT_TRUE(ContentSettingsPattern::Wildcard().Matches(
- GURL("file:///foo/bar.txt")));
-
- EXPECT_STREQ("*", ContentSettingsPattern::Wildcard().ToString().c_str());
-
- EXPECT_EQ(ContentSettingsPattern::IDENTITY,
- ContentSettingsPattern::Wildcard().Compare(
- ContentSettingsPattern::Wildcard()));
-}
-
-TEST(ContentSettingsPatternTest, FromString_WithNoWildcards) {
- // HTTP patterns with default port.
- EXPECT_TRUE(Pattern("http://www.example.com:80").IsValid());
- EXPECT_STREQ("http://www.example.com:80",
- Pattern("http://www.example.com:80").ToString().c_str());
- // HTTP patterns with none default port.
- EXPECT_TRUE(Pattern("http://www.example.com:81").IsValid());
- EXPECT_STREQ("http://www.example.com:81",
- Pattern("http://www.example.com:81").ToString().c_str());
-
- // HTTPS patterns with default port.
- EXPECT_TRUE(Pattern("https://www.example.com:443").IsValid());
- EXPECT_STREQ("https://www.example.com:443",
- Pattern("https://www.example.com:443").ToString().c_str());
- // HTTPS patterns with none default port.
- EXPECT_TRUE(Pattern("https://www.example.com:8080").IsValid());
- EXPECT_STREQ("https://www.example.com:8080",
- Pattern("https://www.example.com:8080").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, FromString_FilePatterns) {
- EXPECT_TRUE(Pattern("file:///").IsValid());
- EXPECT_STREQ("file:///",
- Pattern("file:///").ToString().c_str());
- EXPECT_TRUE(Pattern("file:///").Matches(
- GURL("file:///")));
- EXPECT_FALSE(Pattern("file:///").Matches(
- GURL("file:///tmp/test.html")));
-
- EXPECT_TRUE(Pattern("file:///tmp/test.html").IsValid());
- EXPECT_STREQ("file:///tmp/file.html",
- Pattern("file:///tmp/file.html").ToString().c_str());
- EXPECT_TRUE(Pattern("file:///tmp/test.html").Matches(
- GURL("file:///tmp/test.html")));
- EXPECT_FALSE(Pattern("file:///tmp/test.html").Matches(
- GURL("file:///tmp/other.html")));
- EXPECT_FALSE(Pattern("file:///tmp/test.html").Matches(
- GURL("http://example.org/")));
-}
-
-TEST(ContentSettingsPatternTest, FromString_ExtensionPatterns) {
- EXPECT_TRUE(Pattern("chrome-extension://peoadpeiejnhkmpaakpnompolbglelel/")
- .IsValid());
- EXPECT_STREQ("chrome-extension://peoadpeiejnhkmpaakpnompolbglelel/",
- Pattern("chrome-extension://peoadpeiejnhkmpaakpnompolbglelel/")
- .ToString().c_str());
- EXPECT_TRUE(Pattern("chrome-extension://peoadpeiejnhkmpaakpnompolbglelel/")
- .Matches(GURL("chrome-extension://peoadpeiejnhkmpaakpnompolbglelel/")));
-}
-
-TEST(ContentSettingsPatternTest, FromString_WithIPAdresses) {
- // IPv4
- EXPECT_TRUE(Pattern("192.168.0.1").IsValid());
- EXPECT_STREQ("192.168.1.1", Pattern("192.168.1.1").ToString().c_str());
- EXPECT_TRUE(Pattern("https://192.168.0.1:8080").IsValid());
- EXPECT_STREQ("https://192.168.0.1:8080",
- Pattern("https://192.168.0.1:8080").ToString().c_str());
- // IPv6
- EXPECT_TRUE(Pattern("[::1]").IsValid());
- EXPECT_STREQ("[::1]", Pattern("[::1]").ToString().c_str());
- EXPECT_TRUE(Pattern("https://[::1]:8080").IsValid());
- EXPECT_STREQ("https://[::1]:8080",
- Pattern("https://[::1]:8080").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, FromString_WithWildcards) {
- // Creating content settings patterns from strings completes pattern parts
- // that are omitted in pattern specifications (strings) with a wildcard.
-
- // The wildcard pattern.
- EXPECT_TRUE(Pattern("*").IsValid());
- EXPECT_STREQ("*", Pattern("*").ToString().c_str());
- EXPECT_EQ(ContentSettingsPattern::IDENTITY,
- Pattern("*").Compare(ContentSettingsPattern::Wildcard()));
-
- // Patterns with port wildcard.
- EXPECT_TRUE(Pattern("http://example.com:*").IsValid());
- EXPECT_STREQ("http://example.com",
- Pattern("http://example.com:*").ToString().c_str());
-
- EXPECT_TRUE(Pattern("https://example.com").IsValid());
- EXPECT_STREQ("https://example.com",
- Pattern("https://example.com").ToString().c_str());
-
- EXPECT_TRUE(Pattern("*://www.google.com.com:8080").IsValid());
- EXPECT_STREQ("www.google.com:8080",
- Pattern("*://www.google.com:8080").ToString().c_str());
- EXPECT_TRUE(Pattern("*://www.google.com:8080").Matches(
- GURL("http://www.google.com:8080")));
- EXPECT_TRUE(Pattern("*://www.google.com:8080").Matches(
- GURL("https://www.google.com:8080")));
- EXPECT_FALSE(
- Pattern("*://www.google.com").Matches(GURL("file:///foo/bar.html")));
-
- EXPECT_TRUE(Pattern("www.example.com:8080").IsValid());
-
- // Patterns with port and scheme wildcard.
- EXPECT_TRUE(Pattern("*://www.example.com:*").IsValid());
- EXPECT_STREQ("www.example.com",
- Pattern("*://www.example.com:*").ToString().c_str());
-
- EXPECT_TRUE(Pattern("*://www.example.com").IsValid());
- EXPECT_STREQ("www.example.com",
- Pattern("*://www.example.com").ToString().c_str());
-
- EXPECT_TRUE(Pattern("www.example.com:*").IsValid());
- EXPECT_STREQ("www.example.com",
- Pattern("www.example.com:*").ToString().c_str());
-
- EXPECT_TRUE(Pattern("www.example.com").IsValid());
- EXPECT_STREQ("www.example.com",
- Pattern("www.example.com").ToString().c_str());
- EXPECT_TRUE(Pattern("www.example.com").Matches(
- GURL("http://www.example.com/")));
- EXPECT_FALSE(Pattern("example.com").Matches(
- GURL("http://example.org/")));
-
- // Patterns with domain wildcard.
- EXPECT_TRUE(Pattern("[*.]example.com").IsValid());
- EXPECT_STREQ("[*.]example.com",
- Pattern("[*.]example.com").ToString().c_str());
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
- GURL("http://example.com/")));
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
- GURL("http://foo.example.com/")));
- EXPECT_FALSE(Pattern("[*.]example.com").Matches(
- GURL("http://example.org/")));
-
- EXPECT_TRUE(Pattern("[*.]google.com:80").Matches(
- GURL("http://mail.google.com:80")));
- EXPECT_FALSE(Pattern("[*.]google.com:80").Matches(
- GURL("http://mail.google.com:81")));
- EXPECT_TRUE(Pattern("[*.]google.com:80").Matches(
- GURL("http://www.google.com")));
-
- EXPECT_TRUE(Pattern("[*.]google.com:8080").Matches(
- GURL("http://mail.google.com:8080")));
-
- EXPECT_TRUE(Pattern("[*.]google.com:443").Matches(
- GURL("https://mail.google.com:443")));
- EXPECT_TRUE(Pattern("[*.]google.com:443").Matches(
- GURL("https://www.google.com")));
-
- EXPECT_TRUE(Pattern("[*.]google.com:4321").Matches(
- GURL("https://mail.google.com:4321")));
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
- GURL("http://example.com/")));
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
- GURL("http://www.example.com/")));
-
- // Patterns with host wildcard
- // TODO(markusheintz): Should these patterns be allowed?
- // EXPECT_TRUE(Pattern("http://*").IsValid());
- // EXPECT_TRUE(Pattern("http://*:8080").IsValid());
- EXPECT_TRUE(Pattern("*://*").IsValid());
- EXPECT_STREQ("*", Pattern("*://*").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, FromString_Canonicalized) {
- // UTF-8 patterns.
- EXPECT_TRUE(Pattern("[*.]\xC4\x87ira.com").IsValid());
- EXPECT_STREQ("[*.]xn--ira-ppa.com",
- Pattern("[*.]\xC4\x87ira.com").ToString().c_str());
- EXPECT_TRUE(Pattern("\xC4\x87ira.com").IsValid());
- EXPECT_STREQ("xn--ira-ppa.com",
- Pattern("\xC4\x87ira.com").ToString().c_str());
- EXPECT_TRUE(Pattern("file:///\xC4\x87ira.html").IsValid());
- EXPECT_STREQ("file:///%C4%87ira.html",
- Pattern("file:///\xC4\x87ira.html").ToString().c_str());
-
- // File path normalization.
- EXPECT_TRUE(Pattern("file:///tmp/bar/../test.html").IsValid());
- EXPECT_STREQ("file:///tmp/test.html",
- Pattern("file:///tmp/bar/../test.html").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, InvalidPatterns) {
- // StubObserver expects an empty pattern top be returned as empty string.
- EXPECT_FALSE(ContentSettingsPattern().IsValid());
- EXPECT_STREQ("", ContentSettingsPattern().ToString().c_str());
-
- // Empty pattern string
- EXPECT_FALSE(Pattern("").IsValid());
- EXPECT_STREQ("", Pattern("").ToString().c_str());
-
- // Pattern strings with invalid scheme part.
- EXPECT_FALSE(Pattern("ftp://myhost.org").IsValid());
- EXPECT_STREQ("", Pattern("ftp://myhost.org").ToString().c_str());
-
- // Pattern strings with invalid host part.
- EXPECT_FALSE(Pattern("*example.com").IsValid());
- EXPECT_STREQ("", Pattern("*example.com").ToString().c_str());
- EXPECT_FALSE(Pattern("example.*").IsValid());
- EXPECT_STREQ("", Pattern("example.*").ToString().c_str());
- EXPECT_FALSE(Pattern("*\xC4\x87ira.com").IsValid());
- EXPECT_STREQ("", Pattern("*\xC4\x87ira.com").ToString().c_str());
- EXPECT_FALSE(Pattern("\xC4\x87ira.*").IsValid());
- EXPECT_STREQ("", Pattern("\xC4\x87ira.*").ToString().c_str());
-
- // Pattern strings with invalid port parts.
- EXPECT_FALSE(Pattern("example.com:abc").IsValid());
- EXPECT_STREQ("", Pattern("example.com:abc").ToString().c_str());
-
- // Invalid file pattern strings.
- EXPECT_FALSE(Pattern("file://").IsValid());
- EXPECT_STREQ("", Pattern("file://").ToString().c_str());
- EXPECT_FALSE(Pattern("file:///foo/bar.html:8080").IsValid());
- EXPECT_STREQ("", Pattern("file:///foo/bar.html:8080").ToString().c_str());
-}
-
-TEST(ContentSettingsPatternTest, Compare) {
- // Test identical patterns patterns.
- ContentSettingsPattern pattern1 =
- Pattern("http://www.google.com");
- EXPECT_EQ(ContentSettingsPattern::IDENTITY, pattern1.Compare(pattern1));
- EXPECT_EQ(ContentSettingsPattern::IDENTITY,
- Pattern("http://www.google.com:80").Compare(
- Pattern("http://www.google.com:80")));
- EXPECT_EQ(ContentSettingsPattern::IDENTITY,
- Pattern("*://[*.]google.com:*").Compare(
- Pattern("*://[*.]google.com:*")));
-
- // Test disjoint patterns.
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("http://www.google.com").Compare(
- Pattern("http://www.youtube.com")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("http://[*.]google.com").Compare(
- Pattern("http://[*.]youtube.com")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("http://[*.]host.com").Compare(
- Pattern("http://[*.]evilhost.com")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("*://www.google.com:80").Compare(
- Pattern("*://www.google.com:8080")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("https://www.google.com:80").Compare(
- Pattern("http://www.google.com:80")));
-
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("http://[*.]google.com:90").Compare(
- Pattern("http://mail.google.com:80")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("https://[*.]google.com:80").Compare(
- Pattern("http://mail.google.com:80")));
- EXPECT_EQ(ContentSettingsPattern::DISJOINT,
- Pattern("https://mail.google.com:*").Compare(
- Pattern("http://mail.google.com:80")));
-
- // Test patterns with different precedences.
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("mail.google.com").Compare(
- Pattern("[*.]google.com")));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- Pattern("[*.]google.com").Compare(
- Pattern("mail.google.com")));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("[*.]mail.google.com").Compare(
- Pattern("[*.]google.com")));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- Pattern("[*.]google.com").Compare(
- Pattern("[*.]mail.google.com")));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("mail.google.com:80").Compare(
- Pattern("mail.google.com:*")));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- Pattern("mail.google.com:*").Compare(
- Pattern("mail.google.com:80")));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("https://mail.google.com:*").Compare(
- Pattern("*://mail.google.com:*")));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- Pattern("*://mail.google.com:*").Compare(
- Pattern("https://mail.google.com:*")));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("*://mail.google.com:80").Compare(
- Pattern("https://mail.google.com:*")));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- Pattern("https://mail.google.com:*").Compare(
- Pattern("*://mail.google.com:80")));
-
- // Test the wildcard pattern.
- EXPECT_EQ(ContentSettingsPattern::IDENTITY,
- ContentSettingsPattern::Wildcard().Compare(
- ContentSettingsPattern::Wildcard()));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("[*.]google.com").Compare(
- ContentSettingsPattern::Wildcard()));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- ContentSettingsPattern::Wildcard().Compare(
- Pattern("[*.]google.com")));
-
- EXPECT_EQ(ContentSettingsPattern::PREDECESSOR,
- Pattern("mail.google.com").Compare(
- ContentSettingsPattern::Wildcard()));
- EXPECT_EQ(ContentSettingsPattern::SUCCESSOR,
- ContentSettingsPattern::Wildcard().Compare(
- Pattern("mail.google.com")));
-}
-
-// Legacy tests to ensure backwards compatibility.
-
-TEST(ContentSettingsPatternTest, PatternSupport_Legacy) {
- EXPECT_TRUE(Pattern("[*.]example.com").IsValid());
- EXPECT_TRUE(Pattern("example.com").IsValid());
- EXPECT_TRUE(Pattern("192.168.0.1").IsValid());
- EXPECT_TRUE(Pattern("[::1]").IsValid());
- EXPECT_TRUE(
- Pattern("file:///tmp/test.html").IsValid());
- EXPECT_FALSE(Pattern("*example.com").IsValid());
- EXPECT_FALSE(Pattern("example.*").IsValid());
-
- EXPECT_TRUE(
- Pattern("http://example.com").IsValid());
- EXPECT_TRUE(
- Pattern("https://example.com").IsValid());
-
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
+TEST(ContentSettingsPatternTest, PatternSupport) {
+ EXPECT_TRUE(ContentSettingsPattern("[*.]example.com").IsValid());
+ EXPECT_TRUE(ContentSettingsPattern("example.com").IsValid());
+ EXPECT_TRUE(ContentSettingsPattern("192.168.0.1").IsValid());
+ EXPECT_TRUE(ContentSettingsPattern("[::1]").IsValid());
+ EXPECT_TRUE(ContentSettingsPattern("file:///tmp/test.html").IsValid());
+ EXPECT_FALSE(ContentSettingsPattern("*example.com").IsValid());
+ EXPECT_FALSE(ContentSettingsPattern("example.*").IsValid());
+ EXPECT_FALSE(ContentSettingsPattern("http://example.com").IsValid());
+
+ EXPECT_TRUE(ContentSettingsPattern("[*.]example.com").Matches(
GURL("http://example.com/")));
- EXPECT_TRUE(Pattern("[*.]example.com").Matches(
+ EXPECT_TRUE(ContentSettingsPattern("[*.]example.com").Matches(
GURL("http://www.example.com/")));
- EXPECT_TRUE(Pattern("www.example.com").Matches(
+ EXPECT_TRUE(ContentSettingsPattern("www.example.com").Matches(
GURL("http://www.example.com/")));
- EXPECT_TRUE(
- Pattern("file:///tmp/test.html").Matches(
+ EXPECT_TRUE(ContentSettingsPattern("file:///tmp/test.html").Matches(
GURL("file:///tmp/test.html")));
- EXPECT_FALSE(Pattern("").Matches(
+ EXPECT_FALSE(ContentSettingsPattern("").Matches(
GURL("http://www.example.com/")));
- EXPECT_FALSE(Pattern("[*.]example.com").Matches(
+ EXPECT_FALSE(ContentSettingsPattern("[*.]example.com").Matches(
GURL("http://example.org/")));
- EXPECT_FALSE(Pattern("example.com").Matches(
+ EXPECT_FALSE(ContentSettingsPattern("example.com").Matches(
GURL("http://example.org/")));
- EXPECT_FALSE(
- Pattern("file:///tmp/test.html").Matches(
+ EXPECT_FALSE(ContentSettingsPattern("file:///tmp/test.html").Matches(
GURL("file:///tmp/other.html")));
- EXPECT_FALSE(
- Pattern("file:///tmp/test.html").Matches(
+ EXPECT_FALSE(ContentSettingsPattern("file:///tmp/test.html").Matches(
GURL("http://example.org/")));
}
-TEST(ContentSettingsPatternTest, CanonicalizePattern_Legacy) {
+TEST(ContentSettingsPatternTest, CanonicalizePattern) {
// Basic patterns.
- EXPECT_STREQ("[*.]ikea.com", Pattern("[*.]ikea.com").ToString().c_str());
- EXPECT_STREQ("example.com", Pattern("example.com").ToString().c_str());
- EXPECT_STREQ("192.168.1.1", Pattern("192.168.1.1").ToString().c_str());
- EXPECT_STREQ("[::1]", Pattern("[::1]").ToString().c_str());
- EXPECT_STREQ("file:///tmp/file.html",
- Pattern("file:///tmp/file.html").ToString().c_str());
+ EXPECT_STREQ("[*.]ikea.com", ContentSettingsPattern("[*.]ikea.com")
+ .CanonicalizePattern().c_str());
+ EXPECT_STREQ("example.com", ContentSettingsPattern("example.com")
+ .CanonicalizePattern().c_str());
+ EXPECT_STREQ("192.168.1.1", ContentSettingsPattern("192.168.1.1")
+ .CanonicalizePattern().c_str());
+ EXPECT_STREQ("[::1]", ContentSettingsPattern("[::1]")
+ .CanonicalizePattern().c_str());
+ EXPECT_STREQ("file:///tmp/file.html", ContentSettingsPattern(
+ "file:///tmp/file.html").CanonicalizePattern().c_str());
// UTF-8 patterns.
- EXPECT_STREQ("[*.]xn--ira-ppa.com",
- Pattern("[*.]\xC4\x87ira.com").ToString().c_str());
- EXPECT_STREQ("xn--ira-ppa.com",
- Pattern("\xC4\x87ira.com").ToString().c_str());
- EXPECT_STREQ("file:///%C4%87ira.html",
- Pattern("file:///\xC4\x87ira.html").ToString().c_str());
+ EXPECT_STREQ("[*.]xn--ira-ppa.com", ContentSettingsPattern(
+ "[*.]\xC4\x87ira.com").CanonicalizePattern().c_str());
+ EXPECT_STREQ("xn--ira-ppa.com", ContentSettingsPattern(
+ "\xC4\x87ira.com").CanonicalizePattern().c_str());
+ EXPECT_STREQ("file:///%C4%87ira.html", ContentSettingsPattern(
+ "file:///\xC4\x87ira.html").CanonicalizePattern().c_str());
// file:/// normalization.
- EXPECT_STREQ("file:///tmp/test.html",
- Pattern("file:///tmp/bar/../test.html").ToString().c_str());
+ EXPECT_STREQ("file:///tmp/test.html", ContentSettingsPattern(
+ "file:///tmp/bar/../test.html").CanonicalizePattern().c_str());
// Invalid patterns.
- EXPECT_STREQ("", Pattern("*example.com").ToString().c_str());
- EXPECT_STREQ("", Pattern("example.*").ToString().c_str());
- EXPECT_STREQ("", Pattern("*\xC4\x87ira.com").ToString().c_str());
- EXPECT_STREQ("", Pattern("\xC4\x87ira.*").ToString().c_str());
+ EXPECT_STREQ("", ContentSettingsPattern(
+ "*example.com").CanonicalizePattern().c_str());
+ EXPECT_STREQ("", ContentSettingsPattern(
+ "example.*").CanonicalizePattern().c_str());
+ EXPECT_STREQ("", ContentSettingsPattern(
+ "*\xC4\x87ira.com").CanonicalizePattern().c_str());
+ EXPECT_STREQ("", ContentSettingsPattern(
+ "\xC4\x87ira.*").CanonicalizePattern().c_str());
}
+
+} // namespace