1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
// 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.
#ifndef NET_PROXY_RESOLUTION_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_
#define NET_PROXY_RESOLUTION_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_
#include "net/proxy_resolution/proxy_config.h"
#include "testing/gtest/include/gtest/gtest.h"
// Helper functions to describe the expected value of a
// ProxyConfig::ProxyRules, and to check for a match.
namespace net {
// This structure contains our expectations on what values the ProxyRules
// should have.
struct ProxyRulesExpectation {
ProxyRulesExpectation(ProxyConfig::ProxyRules::Type type,
const char* single_proxy,
const char* proxy_for_http,
const char* proxy_for_https,
const char* proxy_for_ftp,
const char* fallback_proxy,
const char* flattened_bypass_rules,
bool reverse_bypass);
// Call this within an EXPECT_TRUE(), to assert that |rules| matches
// our expected values |*this|.
::testing::AssertionResult Matches(
const ProxyConfig::ProxyRules& rules) const;
// Creates an expectation that the ProxyRules has no rules.
static ProxyRulesExpectation Empty();
// Creates an expectation that the ProxyRules has nothing other than
// the specified bypass rules.
static ProxyRulesExpectation EmptyWithBypass(
const char* flattened_bypass_rules);
// Creates an expectation that the ProxyRules is for a single proxy
// server for all schemes.
static ProxyRulesExpectation Single(const char* single_proxy,
const char* flattened_bypass_rules);
// Creates an expectation that the ProxyRules specifies a different
// proxy server for each URL scheme.
static ProxyRulesExpectation PerScheme(const char* proxy_http,
const char* proxy_https,
const char* proxy_ftp,
const char* flattened_bypass_rules);
// Same as above, but additionally with a SOCKS fallback.
static ProxyRulesExpectation PerSchemeWithSocks(
const char* proxy_http,
const char* proxy_https,
const char* proxy_ftp,
const char* fallback_proxy,
const char* flattened_bypass_rules);
// Same as PerScheme, but with the bypass rules reversed
static ProxyRulesExpectation PerSchemeWithBypassReversed(
const char* proxy_http,
const char* proxy_https,
const char* proxy_ftp,
const char* flattened_bypass_rules);
ProxyConfig::ProxyRules::Type type;
const char* single_proxy;
const char* proxy_for_http;
const char* proxy_for_https;
const char* proxy_for_ftp;
const char* fallback_proxy;
const char* flattened_bypass_rules;
bool reverse_bypass;
};
} // namespace net
#endif // NET_PROXY_RESOLUTION_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_
|