summaryrefslogtreecommitdiffstats
path: root/net/proxy/proxy_config_service_common_unittest.h
blob: 3b70ef0af34f020843bf003ec2babef93bc2b096 (plain)
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// Copyright (c) 2009 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.

#ifndef NET_PROXY_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_
#define NET_PROXY_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_

#include <string>
#include <vector>

#include "net/proxy/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 {

class ProxyBypassRules;

// 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* socks_proxy,
                        const char* flattened_bypass_rules,
                        bool reverse_bypass)
    : type(type),
      single_proxy(single_proxy),
      proxy_for_http(proxy_for_http),
      proxy_for_https(proxy_for_https),
      proxy_for_ftp(proxy_for_ftp),
      socks_proxy(socks_proxy),
      flattened_bypass_rules(flattened_bypass_rules),
      reverse_bypass(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* socks_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* socks_proxy;
  const char* flattened_bypass_rules;
  bool reverse_bypass;
};

}  // namespace net

#endif  // NET_PROXY_PROXY_CONFIG_SERVICE_COMMON_UNITTEST_H_