195 lines
6.6 KiB
C++
195 lines
6.6 KiB
C++
// Copyright 2010 The Chromium Authors
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "net/base/host_mapping_rules.h"
|
|
|
|
#include <string.h>
|
|
|
|
#include "net/base/host_port_pair.h"
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
|
#include "url/gurl.h"
|
|
#include "url/third_party/mozilla/url_parse.h"
|
|
#include "url/url_canon.h"
|
|
#include "url/url_util.h"
|
|
|
|
namespace net {
|
|
|
|
namespace {
|
|
|
|
TEST(HostMappingRulesTest, SetRulesFromString) {
|
|
HostMappingRules rules;
|
|
rules.SetRulesFromString(
|
|
"map *.com baz , map *.net bar:60, EXCLUDE *.foo.com");
|
|
|
|
HostPortPair host_port("test", 1234);
|
|
EXPECT_FALSE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("test", host_port.host());
|
|
EXPECT_EQ(1234u, host_port.port());
|
|
|
|
host_port = HostPortPair("chrome.net", 80);
|
|
EXPECT_TRUE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("bar", host_port.host());
|
|
EXPECT_EQ(60u, host_port.port());
|
|
|
|
host_port = HostPortPair("crack.com", 80);
|
|
EXPECT_TRUE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("baz", host_port.host());
|
|
EXPECT_EQ(80u, host_port.port());
|
|
|
|
host_port = HostPortPair("wtf.foo.com", 666);
|
|
EXPECT_FALSE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("wtf.foo.com", host_port.host());
|
|
EXPECT_EQ(666u, host_port.port());
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, PortSpecificMatching) {
|
|
HostMappingRules rules;
|
|
rules.SetRulesFromString(
|
|
"map *.com:80 baz:111 , map *.com:443 blat:333, EXCLUDE *.foo.com");
|
|
|
|
// No match
|
|
HostPortPair host_port("test.com", 1234);
|
|
EXPECT_FALSE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("test.com", host_port.host());
|
|
EXPECT_EQ(1234u, host_port.port());
|
|
|
|
// Match port 80
|
|
host_port = HostPortPair("crack.com", 80);
|
|
EXPECT_TRUE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("baz", host_port.host());
|
|
EXPECT_EQ(111u, host_port.port());
|
|
|
|
// Match port 443
|
|
host_port = HostPortPair("wtf.com", 443);
|
|
EXPECT_TRUE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("blat", host_port.host());
|
|
EXPECT_EQ(333u, host_port.port());
|
|
|
|
// Match port 443, but excluded.
|
|
host_port = HostPortPair("wtf.foo.com", 443);
|
|
EXPECT_FALSE(rules.RewriteHost(&host_port));
|
|
EXPECT_EQ("wtf.foo.com", host_port.host());
|
|
EXPECT_EQ(443u, host_port.port());
|
|
}
|
|
|
|
// Parsing bad rules should silently discard the rule (and never crash).
|
|
TEST(HostMappingRulesTest, ParseInvalidRules) {
|
|
HostMappingRules rules;
|
|
|
|
EXPECT_FALSE(rules.AddRuleFromString("xyz"));
|
|
EXPECT_FALSE(rules.AddRuleFromString(std::string()));
|
|
EXPECT_FALSE(rules.AddRuleFromString(" "));
|
|
EXPECT_FALSE(rules.AddRuleFromString("EXCLUDE"));
|
|
EXPECT_FALSE(rules.AddRuleFromString("EXCLUDE foo bar"));
|
|
EXPECT_FALSE(rules.AddRuleFromString("INCLUDE"));
|
|
EXPECT_FALSE(rules.AddRuleFromString("INCLUDE x"));
|
|
EXPECT_FALSE(rules.AddRuleFromString("INCLUDE x :10"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesUrl) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
GURL url("http://initial.test:111");
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("http://replacement.test:1000"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesUrlToIpv6Literal) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test [2345:6789::0abc]:1112");
|
|
|
|
GURL url("http://initial.test:111");
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("http://[2345:6789::0abc]:1112"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesUrlPreservingScheme) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
GURL url("wss://initial.test:222");
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("wss://replacement.test:1000"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesFileUrl) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
// Expect replacement port to be ignored because file URLs do not use port.
|
|
GURL url("file://initial.test/file.txt");
|
|
ASSERT_EQ(url.EffectiveIntPort(), url::PORT_UNSPECIFIED);
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("file://replacement.test/file.txt"));
|
|
EXPECT_EQ(url.EffectiveIntPort(), url::PORT_UNSPECIFIED);
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesAnyStandardUrlWithPort) {
|
|
const char kScheme[] = "foo";
|
|
url::ScopedSchemeRegistryForTests scoped_registry;
|
|
AddStandardScheme(kScheme, url::SCHEME_WITH_HOST_AND_PORT);
|
|
ASSERT_TRUE(url::IsStandard(kScheme, url::Component(0, strlen(kScheme))));
|
|
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
GURL url("foo://initial.test:100");
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("foo://replacement.test:1000"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, RewritesAnyStandardUrlWithoutPort) {
|
|
const char kScheme[] = "foo";
|
|
url::ScopedSchemeRegistryForTests scoped_registry;
|
|
AddStandardScheme(kScheme, url::SCHEME_WITH_HOST);
|
|
ASSERT_TRUE(url::IsStandard(kScheme, url::Component(0, strlen(kScheme))));
|
|
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
// Expect replacement port to be ignored.
|
|
GURL url("foo://initial.test");
|
|
ASSERT_EQ(url.EffectiveIntPort(), url::PORT_UNSPECIFIED);
|
|
EXPECT_EQ(rules.RewriteUrl(url), HostMappingRules::RewriteResult::kRewritten);
|
|
EXPECT_EQ(url, GURL("foo://replacement.test"));
|
|
EXPECT_EQ(url.EffectiveIntPort(), url::PORT_UNSPECIFIED);
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, IgnoresUnmappedUrls) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test replacement.test:1000");
|
|
|
|
GURL url("http://different.test:111");
|
|
EXPECT_EQ(rules.RewriteUrl(url),
|
|
HostMappingRules::RewriteResult::kNoMatchingRule);
|
|
EXPECT_EQ(url, GURL("http://different.test:111"));
|
|
}
|
|
|
|
TEST(HostMappingRulesTest, IgnoresInvalidReplacementUrls) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test invalid/url");
|
|
|
|
GURL url("http://initial.test");
|
|
EXPECT_EQ(rules.RewriteUrl(url),
|
|
HostMappingRules::RewriteResult::kInvalidRewrite);
|
|
EXPECT_EQ(url, GURL("http://initial.test"));
|
|
}
|
|
|
|
// Remapping to "~NOTFOUND" is documented as a special case for
|
|
// MappedHostResolver usage. Ensure that it is handled as invalid as expected.
|
|
TEST(HostMappingRulesTest, NotFoundIgnoredAsInvalidUrl) {
|
|
HostMappingRules rules;
|
|
rules.AddRuleFromString("MAP initial.test ~NOTFOUND");
|
|
|
|
GURL url("http://initial.test");
|
|
EXPECT_EQ(rules.RewriteUrl(url),
|
|
HostMappingRules::RewriteResult::kInvalidRewrite);
|
|
EXPECT_EQ(url, GURL("http://initial.test"));
|
|
}
|
|
|
|
} // namespace
|
|
|
|
} // namespace net
|