1*6777b538SAndroid Build Coastguard Worker // Copyright 2009 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "net/dns/dns_util.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include <string_view>
8*6777b538SAndroid Build Coastguard Worker
9*6777b538SAndroid Build Coastguard Worker #include "base/test/scoped_feature_list.h"
10*6777b538SAndroid Build Coastguard Worker #include "net/dns/dns_test_util.h"
11*6777b538SAndroid Build Coastguard Worker #include "net/dns/public/dns_over_https_config.h"
12*6777b538SAndroid Build Coastguard Worker #include "net/dns/public/dns_protocol.h"
13*6777b538SAndroid Build Coastguard Worker #include "net/dns/public/doh_provider_entry.h"
14*6777b538SAndroid Build Coastguard Worker #include "testing/gmock/include/gmock/gmock.h"
15*6777b538SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
16*6777b538SAndroid Build Coastguard Worker
17*6777b538SAndroid Build Coastguard Worker namespace net {
18*6777b538SAndroid Build Coastguard Worker
19*6777b538SAndroid Build Coastguard Worker namespace {
20*6777b538SAndroid Build Coastguard Worker // Returns the DoH provider entry in `DohProviderEntry::GetList()` that matches
21*6777b538SAndroid Build Coastguard Worker // `provider`. Crashes if there is no matching entry.
GetDohProviderEntry(std::string_view provider)22*6777b538SAndroid Build Coastguard Worker const DohProviderEntry& GetDohProviderEntry(std::string_view provider) {
23*6777b538SAndroid Build Coastguard Worker auto provider_list = DohProviderEntry::GetList();
24*6777b538SAndroid Build Coastguard Worker auto it =
25*6777b538SAndroid Build Coastguard Worker base::ranges::find(provider_list, provider, &DohProviderEntry::provider);
26*6777b538SAndroid Build Coastguard Worker CHECK(it != provider_list.end());
27*6777b538SAndroid Build Coastguard Worker return **it;
28*6777b538SAndroid Build Coastguard Worker }
29*6777b538SAndroid Build Coastguard Worker } // namespace
30*6777b538SAndroid Build Coastguard Worker
31*6777b538SAndroid Build Coastguard Worker class DNSUtilTest : public testing::Test {};
32*6777b538SAndroid Build Coastguard Worker
TEST_F(DNSUtilTest,GetURLFromTemplateWithoutParameters)33*6777b538SAndroid Build Coastguard Worker TEST_F(DNSUtilTest, GetURLFromTemplateWithoutParameters) {
34*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("https://dnsserver.example.net/dns-query",
35*6777b538SAndroid Build Coastguard Worker GetURLFromTemplateWithoutParameters(
36*6777b538SAndroid Build Coastguard Worker "https://dnsserver.example.net/dns-query{?dns}"));
37*6777b538SAndroid Build Coastguard Worker }
38*6777b538SAndroid Build Coastguard Worker
TEST_F(DNSUtilTest,GetDohUpgradeServersFromDotHostname)39*6777b538SAndroid Build Coastguard Worker TEST_F(DNSUtilTest, GetDohUpgradeServersFromDotHostname) {
40*6777b538SAndroid Build Coastguard Worker std::vector<DnsOverHttpsServerConfig> doh_servers =
41*6777b538SAndroid Build Coastguard Worker GetDohUpgradeServersFromDotHostname("");
42*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(0u, doh_servers.size());
43*6777b538SAndroid Build Coastguard Worker
44*6777b538SAndroid Build Coastguard Worker doh_servers = GetDohUpgradeServersFromDotHostname("unrecognized");
45*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(0u, doh_servers.size());
46*6777b538SAndroid Build Coastguard Worker
47*6777b538SAndroid Build Coastguard Worker doh_servers = GetDohUpgradeServersFromDotHostname(
48*6777b538SAndroid Build Coastguard Worker "family-filter-dns.cleanbrowsing.org");
49*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(1u, doh_servers.size());
50*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("https://doh.cleanbrowsing.org/doh/family-filter{?dns}",
51*6777b538SAndroid Build Coastguard Worker doh_servers[0].server_template());
52*6777b538SAndroid Build Coastguard Worker
53*6777b538SAndroid Build Coastguard Worker base::test::ScopedFeatureList scoped_feature_list;
54*6777b538SAndroid Build Coastguard Worker scoped_feature_list.InitWithFeatures(
55*6777b538SAndroid Build Coastguard Worker /*enabled_features=*/{}, /*disabled_features=*/{
56*6777b538SAndroid Build Coastguard Worker GetDohProviderEntry("CleanBrowsingFamily").feature});
57*6777b538SAndroid Build Coastguard Worker doh_servers = GetDohUpgradeServersFromDotHostname(
58*6777b538SAndroid Build Coastguard Worker "family-filter-dns.cleanbrowsing.org");
59*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(0u, doh_servers.size());
60*6777b538SAndroid Build Coastguard Worker }
61*6777b538SAndroid Build Coastguard Worker
TEST_F(DNSUtilTest,GetDohUpgradeServersFromNameservers)62*6777b538SAndroid Build Coastguard Worker TEST_F(DNSUtilTest, GetDohUpgradeServersFromNameservers) {
63*6777b538SAndroid Build Coastguard Worker std::vector<IPEndPoint> nameservers;
64*6777b538SAndroid Build Coastguard Worker // Cloudflare upgradeable IPs
65*6777b538SAndroid Build Coastguard Worker IPAddress dns_ip0(1, 0, 0, 1);
66*6777b538SAndroid Build Coastguard Worker IPAddress dns_ip1;
67*6777b538SAndroid Build Coastguard Worker EXPECT_TRUE(dns_ip1.AssignFromIPLiteral("2606:4700:4700::1111"));
68*6777b538SAndroid Build Coastguard Worker // SafeBrowsing family filter upgradeable IP
69*6777b538SAndroid Build Coastguard Worker IPAddress dns_ip2;
70*6777b538SAndroid Build Coastguard Worker EXPECT_TRUE(dns_ip2.AssignFromIPLiteral("2a0d:2a00:2::"));
71*6777b538SAndroid Build Coastguard Worker // SafeBrowsing security filter upgradeable IP
72*6777b538SAndroid Build Coastguard Worker IPAddress dns_ip3(185, 228, 169, 9);
73*6777b538SAndroid Build Coastguard Worker // None-upgradeable IP
74*6777b538SAndroid Build Coastguard Worker IPAddress dns_ip4(1, 2, 3, 4);
75*6777b538SAndroid Build Coastguard Worker
76*6777b538SAndroid Build Coastguard Worker nameservers.emplace_back(dns_ip0, dns_protocol::kDefaultPort);
77*6777b538SAndroid Build Coastguard Worker nameservers.emplace_back(dns_ip1, dns_protocol::kDefaultPort);
78*6777b538SAndroid Build Coastguard Worker nameservers.emplace_back(dns_ip2, 54);
79*6777b538SAndroid Build Coastguard Worker nameservers.emplace_back(dns_ip3, dns_protocol::kDefaultPort);
80*6777b538SAndroid Build Coastguard Worker nameservers.emplace_back(dns_ip4, dns_protocol::kDefaultPort);
81*6777b538SAndroid Build Coastguard Worker
82*6777b538SAndroid Build Coastguard Worker std::vector<DnsOverHttpsServerConfig> doh_servers =
83*6777b538SAndroid Build Coastguard Worker GetDohUpgradeServersFromNameservers(std::vector<IPEndPoint>());
84*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(0u, doh_servers.size());
85*6777b538SAndroid Build Coastguard Worker
86*6777b538SAndroid Build Coastguard Worker doh_servers = GetDohUpgradeServersFromNameservers(nameservers);
87*6777b538SAndroid Build Coastguard Worker auto expected_config = *DnsOverHttpsConfig::FromTemplatesForTesting(
88*6777b538SAndroid Build Coastguard Worker {"https://chrome.cloudflare-dns.com/dns-query",
89*6777b538SAndroid Build Coastguard Worker "https://doh.cleanbrowsing.org/doh/family-filter{?dns}",
90*6777b538SAndroid Build Coastguard Worker "https://doh.cleanbrowsing.org/doh/security-filter{?dns}"});
91*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(expected_config.servers(), doh_servers);
92*6777b538SAndroid Build Coastguard Worker
93*6777b538SAndroid Build Coastguard Worker base::test::ScopedFeatureList scoped_feature_list;
94*6777b538SAndroid Build Coastguard Worker scoped_feature_list.InitWithFeatures(
95*6777b538SAndroid Build Coastguard Worker /*enabled_features=*/{},
96*6777b538SAndroid Build Coastguard Worker /*disabled_features=*/{GetDohProviderEntry("CleanBrowsingSecure").feature,
97*6777b538SAndroid Build Coastguard Worker GetDohProviderEntry("Cloudflare").feature});
98*6777b538SAndroid Build Coastguard Worker
99*6777b538SAndroid Build Coastguard Worker doh_servers = GetDohUpgradeServersFromNameservers(nameservers);
100*6777b538SAndroid Build Coastguard Worker EXPECT_THAT(doh_servers,
101*6777b538SAndroid Build Coastguard Worker testing::ElementsAre(*DnsOverHttpsServerConfig::FromString(
102*6777b538SAndroid Build Coastguard Worker "https://doh.cleanbrowsing.org/doh/family-filter{?dns}")));
103*6777b538SAndroid Build Coastguard Worker }
104*6777b538SAndroid Build Coastguard Worker
TEST_F(DNSUtilTest,GetDohProviderIdForHistogramFromServerConfig)105*6777b538SAndroid Build Coastguard Worker TEST_F(DNSUtilTest, GetDohProviderIdForHistogramFromServerConfig) {
106*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("Cloudflare",
107*6777b538SAndroid Build Coastguard Worker GetDohProviderIdForHistogramFromServerConfig(
108*6777b538SAndroid Build Coastguard Worker *DnsOverHttpsServerConfig::FromString(
109*6777b538SAndroid Build Coastguard Worker "https://chrome.cloudflare-dns.com/dns-query")));
110*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("Other", GetDohProviderIdForHistogramFromServerConfig(
111*6777b538SAndroid Build Coastguard Worker *DnsOverHttpsServerConfig::FromString(
112*6777b538SAndroid Build Coastguard Worker "https://unexpected.dohserver.com/dns-query")));
113*6777b538SAndroid Build Coastguard Worker }
114*6777b538SAndroid Build Coastguard Worker
TEST_F(DNSUtilTest,GetDohProviderIdForHistogramFromNameserver)115*6777b538SAndroid Build Coastguard Worker TEST_F(DNSUtilTest, GetDohProviderIdForHistogramFromNameserver) {
116*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("CleanBrowsingSecure",
117*6777b538SAndroid Build Coastguard Worker GetDohProviderIdForHistogramFromNameserver(IPEndPoint(
118*6777b538SAndroid Build Coastguard Worker IPAddress(185, 228, 169, 9), dns_protocol::kDefaultPort)));
119*6777b538SAndroid Build Coastguard Worker EXPECT_EQ("Other", GetDohProviderIdForHistogramFromNameserver(IPEndPoint(
120*6777b538SAndroid Build Coastguard Worker IPAddress(1, 2, 3, 4), dns_protocol::kDefaultPort)));
121*6777b538SAndroid Build Coastguard Worker }
122*6777b538SAndroid Build Coastguard Worker
123*6777b538SAndroid Build Coastguard Worker } // namespace net
124