summaryrefslogtreecommitdiffstats
path: root/net/base/registry_controlled_domain_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'net/base/registry_controlled_domain_unittest.cc')
-rw-r--r--net/base/registry_controlled_domain_unittest.cc148
1 files changed, 77 insertions, 71 deletions
diff --git a/net/base/registry_controlled_domain_unittest.cc b/net/base/registry_controlled_domain_unittest.cc
index 590f17b..05bfea3 100644
--- a/net/base/registry_controlled_domain_unittest.cc
+++ b/net/base/registry_controlled_domain_unittest.cc
@@ -33,33 +33,36 @@
namespace {
-class TestRegistryControlledDomainService;
-static TestRegistryControlledDomainService* test_instance_;
-
class TestRegistryControlledDomainService :
public net::RegistryControlledDomainService {
public:
-
- // Deletes the instance so a new one will be created.
- static void ResetInstance() {
- net::RegistryControlledDomainService::ResetInstance();
- }
-
// Sets and parses the given data.
static void UseDomainData(const std::string& data) {
net::RegistryControlledDomainService::UseDomainData(data);
}
- private:
- TestRegistryControlledDomainService::TestRegistryControlledDomainService() { }
- TestRegistryControlledDomainService::~TestRegistryControlledDomainService() {
+ // Creates a new dedicated instance to be used for testing, deleting any
+ // previously-set one.
+ static void UseDedicatedInstance() {
+ delete static_cast<TestRegistryControlledDomainService*>(
+ SetInstance(new TestRegistryControlledDomainService()));
+ }
+
+ // Restores RegistryControlledDomainService to using its default instance,
+ // deleting any previously-set test instance.
+ static void UseDefaultInstance() {
+ delete static_cast<TestRegistryControlledDomainService*>(SetInstance(NULL));
}
};
class RegistryControlledDomainTest : public testing::Test {
protected:
virtual void SetUp() {
- TestRegistryControlledDomainService::ResetInstance();
+ TestRegistryControlledDomainService::UseDedicatedInstance();
+ }
+
+ virtual void TearDown() {
+ TestRegistryControlledDomainService::UseDefaultInstance();
}
};
@@ -186,73 +189,74 @@ TEST_F(RegistryControlledDomainTest, TestGetRegistryLength) {
SetTestData(kTestData);
// Test GURL version of GetRegistryLength().
- EXPECT_EQ(2, GetRegistryLengthFromURL("http://a.baz.jp/file.html", false));
+ EXPECT_EQ(2U, GetRegistryLengthFromURL("http://a.baz.jp/file.html", false));
// 1
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://a.baz.jp./file.html", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://a.baz.jp./file.html", false));
// 1
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://ac.jp", false)); // 2
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://a.bar.jp", false)); // 3
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://bar.jp", false)); // 3
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://baz.bar.jp", false)); // 3 4
- EXPECT_EQ(12, GetRegistryLengthFromURL("http://a.b.baz.bar.jp", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://ac.jp", false)); // 2
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://a.bar.jp", false)); // 3
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://bar.jp", false)); // 3
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://baz.bar.jp", false)); // 3 4
+ EXPECT_EQ(12U, GetRegistryLengthFromURL("http://a.b.baz.bar.jp", false));
// 4
- EXPECT_EQ(6, GetRegistryLengthFromURL("http://foo.bar.jp", false)); // 3 5 6
- EXPECT_EQ(6, GetRegistryLengthFromURL("http://baz.pref.bar.jp", false));
+ EXPECT_EQ(6U, GetRegistryLengthFromURL("http://foo.bar.jp", false)); // 3 5 6
+ EXPECT_EQ(6U, GetRegistryLengthFromURL("http://baz.pref.bar.jp", false));
// 7
- EXPECT_EQ(11, GetRegistryLengthFromURL("http://a.b.bar.baz.com", false));
+ EXPECT_EQ(11U, GetRegistryLengthFromURL("http://a.b.bar.baz.com", false));
// 8
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://a.d.c", false)); // 9
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://.a.d.c", false)); // 9
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://..a.d.c", false)); // 9
- EXPECT_EQ(1, GetRegistryLengthFromURL("http://a.b.c", false)); // 9 10
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://baz.com", false)); // none
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://baz.com.", false)); // none
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://baz.com", true)); // none
- EXPECT_EQ(4, GetRegistryLengthFromURL("http://baz.com.", true)); // none
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://a.d.c", false)); // 9
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://.a.d.c", false)); // 9
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://..a.d.c", false)); // 9
+ EXPECT_EQ(1U, GetRegistryLengthFromURL("http://a.b.c", false)); // 9 10
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://baz.com", false)); // none
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://baz.com.", false)); // none
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://baz.com", true)); // none
+ EXPECT_EQ(4U, GetRegistryLengthFromURL("http://baz.com.", true)); // none
EXPECT_EQ(std::string::npos, GetRegistryLengthFromURL("", false));
EXPECT_EQ(std::string::npos, GetRegistryLengthFromURL("http://", false));
EXPECT_EQ(std::string::npos,
GetRegistryLengthFromURL("file:///C:/file.html", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://foo.com..", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://...", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://192.168.0.1", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://localhost", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://localhost", true));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://localhost.", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://localhost.", true));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http:////Comment", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://foo.com..", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://...", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://192.168.0.1", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://localhost", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://localhost", true));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://localhost.", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://localhost.", true));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http:////Comment", false));
// Test std::wstring version of GetRegistryLength(). Uses the same
// underpinnings as the GURL version, so this is really more of a check of
// CanonicalizeHost().
- EXPECT_EQ(2, GetRegistryLengthFromHost(L"a.baz.jp", false)); // 1
- EXPECT_EQ(3, GetRegistryLengthFromHost(L"a.baz.jp.", false)); // 1
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"ac.jp", false)); // 2
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"a.bar.jp", false)); // 3
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"bar.jp", false)); // 3
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"baz.bar.jp", false)); // 3 4
- EXPECT_EQ(12, GetRegistryLengthFromHost(L"a.b.baz.bar.jp", false)); // 4
- EXPECT_EQ(6, GetRegistryLengthFromHost(L"foo.bar.jp", false)); // 3 5 6
- EXPECT_EQ(6, GetRegistryLengthFromHost(L"baz.pref.bar.jp", false)); // 7
- EXPECT_EQ(11, GetRegistryLengthFromHost(L"a.b.bar.baz.com", false)); // 8
- EXPECT_EQ(3, GetRegistryLengthFromHost(L"a.d.c", false)); // 9
- EXPECT_EQ(3, GetRegistryLengthFromHost(L".a.d.c", false)); // 9
- EXPECT_EQ(3, GetRegistryLengthFromHost(L"..a.d.c", false)); // 9
- EXPECT_EQ(1, GetRegistryLengthFromHost(L"a.b.c", false)); // 9 10
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"baz.com", false)); // none
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"baz.com.", false)); // none
- EXPECT_EQ(3, GetRegistryLengthFromHost(L"baz.com", true)); // none
- EXPECT_EQ(4, GetRegistryLengthFromHost(L"baz.com.", true)); // none
+ EXPECT_EQ(2U, GetRegistryLengthFromHost(L"a.baz.jp", false)); // 1
+ EXPECT_EQ(3U, GetRegistryLengthFromHost(L"a.baz.jp.", false)); // 1
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"ac.jp", false)); // 2
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"a.bar.jp", false)); // 3
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"bar.jp", false)); // 3
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"baz.bar.jp", false)); // 3 4
+ EXPECT_EQ(12U, GetRegistryLengthFromHost(L"a.b.baz.bar.jp", false)); // 4
+ EXPECT_EQ(6U, GetRegistryLengthFromHost(L"foo.bar.jp", false)); // 3 5 6
+ EXPECT_EQ(6U, GetRegistryLengthFromHost(L"baz.pref.bar.jp", false)); // 7
+ EXPECT_EQ(11U, GetRegistryLengthFromHost(L"a.b.bar.baz.com", false));
+ // 8
+ EXPECT_EQ(3U, GetRegistryLengthFromHost(L"a.d.c", false)); // 9
+ EXPECT_EQ(3U, GetRegistryLengthFromHost(L".a.d.c", false)); // 9
+ EXPECT_EQ(3U, GetRegistryLengthFromHost(L"..a.d.c", false)); // 9
+ EXPECT_EQ(1U, GetRegistryLengthFromHost(L"a.b.c", false)); // 9 10
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"baz.com", false)); // none
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"baz.com.", false)); // none
+ EXPECT_EQ(3U, GetRegistryLengthFromHost(L"baz.com", true)); // none
+ EXPECT_EQ(4U, GetRegistryLengthFromHost(L"baz.com.", true)); // none
EXPECT_EQ(std::string::npos, GetRegistryLengthFromHost(L"", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"foo.com..", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"..", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"192.168.0.1", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"localhost", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"localhost", true));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"localhost.", false));
- EXPECT_EQ(0, GetRegistryLengthFromHost(L"localhost.", true));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"foo.com..", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"..", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"192.168.0.1", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"localhost", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"localhost", true));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"localhost.", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromHost(L"localhost.", true));
}
TEST_F(RegistryControlledDomainTest, TestSameDomainOrHost) {
@@ -285,12 +289,14 @@ TEST_F(RegistryControlledDomainTest, TestSameDomainOrHost) {
}
TEST_F(RegistryControlledDomainTest, TestDefaultData) {
+ TestRegistryControlledDomainService::UseDefaultInstance();
+
// Note that no data is set: we're using the default rules.
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://google.com", false));
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://stanford.edu", false));
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://ustreas.gov", false));
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://icann.net", false));
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://ferretcentral.org", false));
- EXPECT_EQ(0, GetRegistryLengthFromURL("http://nowhere.foo", false));
- EXPECT_EQ(3, GetRegistryLengthFromURL("http://nowhere.foo", true));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://google.com", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://stanford.edu", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://ustreas.gov", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://icann.net", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://ferretcentral.org", false));
+ EXPECT_EQ(0U, GetRegistryLengthFromURL("http://nowhere.foo", false));
+ EXPECT_EQ(3U, GetRegistryLengthFromURL("http://nowhere.foo", true));
}