Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(548)

Side by Side Diff: tools/chrome_proxy/integration_tests/chrome_proxy_metrics_unittest.py

Issue 397483002: Move chrome_proxy tests from under tools/perf to tools/chrome_proxy/integration_tests. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: addressed comments and sync'ed Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import base64 5 import base64
6 import unittest 6 import unittest
7 7
8 from metrics import chrome_proxy 8 from integration_tests import chrome_proxy_metrics as metrics
9 from metrics import network_unittest 9 from integration_tests import network_metrics_unittest as network_unittest
10 from metrics import test_page_measurement_results 10 from metrics import test_page_measurement_results
11 11
12 12
13 # Timeline events used in tests. 13 # Timeline events used in tests.
14 # An HTML not via proxy. 14 # An HTML not via proxy.
15 EVENT_HTML_PROXY = network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 15 EVENT_HTML_PROXY = network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
16 url='http://test.html1', 16 url='http://test.html1',
17 response_headers={ 17 response_headers={
18 'Content-Type': 'text/html', 18 'Content-Type': 'text/html',
19 'Content-Length': str(len(network_unittest.HTML_BODY)), 19 'Content-Length': str(len(network_unittest.HTML_BODY)),
20 }, 20 },
21 body=network_unittest.HTML_BODY) 21 body=network_unittest.HTML_BODY)
22 22
23 # An HTML via proxy with the deprecated Via header. 23 # An HTML via proxy with the deprecated Via header.
24 EVENT_HTML_PROXY_DEPRECATED_VIA = ( 24 EVENT_HTML_PROXY_DEPRECATED_VIA = (
25 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 25 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
26 url='http://test.html2', 26 url='http://test.html2',
27 response_headers={ 27 response_headers={
28 'Content-Type': 'text/html', 28 'Content-Type': 'text/html',
29 'Content-Encoding': 'gzip', 29 'Content-Encoding': 'gzip',
30 'X-Original-Content-Length': str(len(network_unittest.HTML_BODY)), 30 'X-Original-Content-Length': str(len(network_unittest.HTML_BODY)),
31 'Via': (chrome_proxy.CHROME_PROXY_VIA_HEADER_DEPRECATED + 31 'Via': (metrics.CHROME_PROXY_VIA_HEADER_DEPRECATED +
32 ',other-via'), 32 ',other-via'),
33 }, 33 },
34 body=network_unittest.HTML_BODY)) 34 body=network_unittest.HTML_BODY))
35 35
36 # An image via proxy with Via header and it is cached. 36 # An image via proxy with Via header and it is cached.
37 EVENT_IMAGE_PROXY_CACHED = ( 37 EVENT_IMAGE_PROXY_CACHED = (
38 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 38 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
39 url='http://test.image', 39 url='http://test.image',
40 response_headers={ 40 response_headers={
41 'Content-Type': 'image/jpeg', 41 'Content-Type': 'image/jpeg',
42 'Content-Encoding': 'gzip', 42 'Content-Encoding': 'gzip',
43 'X-Original-Content-Length': str(network_unittest.IMAGE_OCL), 43 'X-Original-Content-Length': str(network_unittest.IMAGE_OCL),
44 'Via': '1.1 ' + chrome_proxy.CHROME_PROXY_VIA_HEADER, 44 'Via': '1.1 ' + metrics.CHROME_PROXY_VIA_HEADER,
45 }, 45 },
46 body=base64.b64encode(network_unittest.IMAGE_BODY), 46 body=base64.b64encode(network_unittest.IMAGE_BODY),
47 base64_encoded_body=True, 47 base64_encoded_body=True,
48 served_from_cache=True)) 48 served_from_cache=True))
49 49
50 # An image fetched directly. 50 # An image fetched directly.
51 EVENT_IMAGE_DIRECT = ( 51 EVENT_IMAGE_DIRECT = (
52 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 52 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
53 url='http://test.image', 53 url='http://test.image',
54 response_headers={ 54 response_headers={
55 'Content-Type': 'image/jpeg', 55 'Content-Type': 'image/jpeg',
56 'Content-Encoding': 'gzip', 56 'Content-Encoding': 'gzip',
57 }, 57 },
58 body=base64.b64encode(network_unittest.IMAGE_BODY), 58 body=base64.b64encode(network_unittest.IMAGE_BODY),
59 base64_encoded_body=True)) 59 base64_encoded_body=True))
60 60
61 # A safe-browsing malware response. 61 # A safe-browsing malware response.
62 EVENT_MALWARE_PROXY = ( 62 EVENT_MALWARE_PROXY = (
63 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 63 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
64 url='http://test.malware', 64 url='http://test.malware',
65 response_headers={ 65 response_headers={
66 'X-Malware-Url': '1', 66 'X-Malware-Url': '1',
67 'Via': '1.1 ' + chrome_proxy.CHROME_PROXY_VIA_HEADER, 67 'Via': '1.1 ' + metrics.CHROME_PROXY_VIA_HEADER,
68 'Location': 'http://test.malware', 68 'Location': 'http://test.malware',
69 }, 69 },
70 status=307)) 70 status=307))
71 71
72 72
73 class ChromeProxyMetricTest(unittest.TestCase): 73 class ChromeProxyMetricTest(unittest.TestCase):
74 74
75 _test_proxy_info = {} 75 _test_proxy_info = {}
76 76
77 def _StubGetProxyInfo(self, info): 77 def _StubGetProxyInfo(self, info):
78 def stub(unused_tab, unused_url=''): # pylint: disable=W0613 78 def stub(unused_tab, unused_url=''): # pylint: disable=W0613
79 return ChromeProxyMetricTest._test_proxy_info 79 return ChromeProxyMetricTest._test_proxy_info
80 chrome_proxy.GetProxyInfoFromNetworkInternals = stub 80 metrics.GetProxyInfoFromNetworkInternals = stub
81 ChromeProxyMetricTest._test_proxy_info = info 81 ChromeProxyMetricTest._test_proxy_info = info
82 82
83 def testChromeProxyResponse(self): 83 def testChromeProxyResponse(self):
84 # An https non-proxy response. 84 # An https non-proxy response.
85 resp = chrome_proxy.ChromeProxyResponse( 85 resp = metrics.ChromeProxyResponse(
86 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 86 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
87 url='https://test.url', 87 url='https://test.url',
88 response_headers={ 88 response_headers={
89 'Content-Type': 'text/html', 89 'Content-Type': 'text/html',
90 'Content-Length': str(len(network_unittest.HTML_BODY)), 90 'Content-Length': str(len(network_unittest.HTML_BODY)),
91 'Via': 'some other via', 91 'Via': 'some other via',
92 }, 92 },
93 body=network_unittest.HTML_BODY)) 93 body=network_unittest.HTML_BODY))
94 self.assertFalse(resp.ShouldHaveChromeProxyViaHeader()) 94 self.assertFalse(resp.ShouldHaveChromeProxyViaHeader())
95 self.assertFalse(resp.HasChromeProxyViaHeader()) 95 self.assertFalse(resp.HasChromeProxyViaHeader())
96 self.assertTrue(resp.IsValidByViaHeader()) 96 self.assertTrue(resp.IsValidByViaHeader())
97 97
98 # A proxied JPEG image response 98 # A proxied JPEG image response
99 resp = chrome_proxy.ChromeProxyResponse( 99 resp = metrics.ChromeProxyResponse(
100 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent( 100 network_unittest.NetworkMetricTest.MakeNetworkTimelineEvent(
101 url='http://test.image', 101 url='http://test.image',
102 response_headers={ 102 response_headers={
103 'Content-Type': 'image/jpeg', 103 'Content-Type': 'image/jpeg',
104 'Content-Encoding': 'gzip', 104 'Content-Encoding': 'gzip',
105 'Via': '1.1 ' + chrome_proxy.CHROME_PROXY_VIA_HEADER, 105 'Via': '1.1 ' + metrics.CHROME_PROXY_VIA_HEADER,
106 'X-Original-Content-Length': str(network_unittest.IMAGE_OCL), 106 'X-Original-Content-Length': str(network_unittest.IMAGE_OCL),
107 }, 107 },
108 body=base64.b64encode(network_unittest.IMAGE_BODY), 108 body=base64.b64encode(network_unittest.IMAGE_BODY),
109 base64_encoded_body=True)) 109 base64_encoded_body=True))
110 self.assertTrue(resp.ShouldHaveChromeProxyViaHeader()) 110 self.assertTrue(resp.ShouldHaveChromeProxyViaHeader())
111 self.assertTrue(resp.HasChromeProxyViaHeader()) 111 self.assertTrue(resp.HasChromeProxyViaHeader())
112 self.assertTrue(resp.IsValidByViaHeader()) 112 self.assertTrue(resp.IsValidByViaHeader())
113 113
114 def testChromeProxyMetricForDataSaving(self): 114 def testChromeProxyMetricForDataSaving(self):
115 metric = chrome_proxy.ChromeProxyMetric() 115 metric = metrics.ChromeProxyMetric()
116 events = [ 116 events = [
117 EVENT_HTML_PROXY, 117 EVENT_HTML_PROXY,
118 EVENT_HTML_PROXY_DEPRECATED_VIA, 118 EVENT_HTML_PROXY_DEPRECATED_VIA,
119 EVENT_IMAGE_PROXY_CACHED, 119 EVENT_IMAGE_PROXY_CACHED,
120 EVENT_IMAGE_DIRECT] 120 EVENT_IMAGE_DIRECT]
121 metric.SetEvents(events) 121 metric.SetEvents(events)
122 122
123 self.assertTrue(len(events), len(list(metric.IterResponses(None)))) 123 self.assertTrue(len(events), len(list(metric.IterResponses(None))))
124 results = test_page_measurement_results.TestPageMeasurementResults(self) 124 results = test_page_measurement_results.TestPageMeasurementResults(self)
125 125
126 metric.AddResultsForDataSaving(None, results) 126 metric.AddResultsForDataSaving(None, results)
127 results.AssertHasPageSpecificScalarValue('resources_via_proxy', 'count', 2) 127 results.AssertHasPageSpecificScalarValue('resources_via_proxy', 'count', 2)
128 results.AssertHasPageSpecificScalarValue('resources_from_cache', 'count', 1) 128 results.AssertHasPageSpecificScalarValue('resources_from_cache', 'count', 1)
129 results.AssertHasPageSpecificScalarValue('resources_direct', 'count', 2) 129 results.AssertHasPageSpecificScalarValue('resources_direct', 'count', 2)
130 130
131 def testChromeProxyMetricForHeaderValidation(self): 131 def testChromeProxyMetricForHeaderValidation(self):
132 metric = chrome_proxy.ChromeProxyMetric() 132 metric = metrics.ChromeProxyMetric()
133 metric.SetEvents([ 133 metric.SetEvents([
134 EVENT_HTML_PROXY, 134 EVENT_HTML_PROXY,
135 EVENT_HTML_PROXY_DEPRECATED_VIA, 135 EVENT_HTML_PROXY_DEPRECATED_VIA,
136 EVENT_IMAGE_PROXY_CACHED, 136 EVENT_IMAGE_PROXY_CACHED,
137 EVENT_IMAGE_DIRECT]) 137 EVENT_IMAGE_DIRECT])
138 138
139 results = test_page_measurement_results.TestPageMeasurementResults(self) 139 results = test_page_measurement_results.TestPageMeasurementResults(self)
140 140
141 missing_via_exception = False 141 missing_via_exception = False
142 try: 142 try:
143 metric.AddResultsForHeaderValidation(None, results) 143 metric.AddResultsForHeaderValidation(None, results)
144 except chrome_proxy.ChromeProxyMetricException: 144 except metrics.ChromeProxyMetricException:
145 missing_via_exception = True 145 missing_via_exception = True
146 # Only the HTTP image response does not have a valid Via header. 146 # Only the HTTP image response does not have a valid Via header.
147 self.assertTrue(missing_via_exception) 147 self.assertTrue(missing_via_exception)
148 148
149 # Two events with valid Via headers. 149 # Two events with valid Via headers.
150 metric.SetEvents([ 150 metric.SetEvents([
151 EVENT_HTML_PROXY_DEPRECATED_VIA, 151 EVENT_HTML_PROXY_DEPRECATED_VIA,
152 EVENT_IMAGE_PROXY_CACHED]) 152 EVENT_IMAGE_PROXY_CACHED])
153 metric.AddResultsForHeaderValidation(None, results) 153 metric.AddResultsForHeaderValidation(None, results)
154 results.AssertHasPageSpecificScalarValue('checked_via_header', 'count', 2) 154 results.AssertHasPageSpecificScalarValue('checked_via_header', 'count', 2)
155 155
156 def testChromeProxyMetricForBypass(self): 156 def testChromeProxyMetricForBypass(self):
157 metric = chrome_proxy.ChromeProxyMetric() 157 metric = metrics.ChromeProxyMetric()
158 metric.SetEvents([ 158 metric.SetEvents([
159 EVENT_HTML_PROXY, 159 EVENT_HTML_PROXY,
160 EVENT_HTML_PROXY_DEPRECATED_VIA, 160 EVENT_HTML_PROXY_DEPRECATED_VIA,
161 EVENT_IMAGE_PROXY_CACHED, 161 EVENT_IMAGE_PROXY_CACHED,
162 EVENT_IMAGE_DIRECT]) 162 EVENT_IMAGE_DIRECT])
163 results = test_page_measurement_results.TestPageMeasurementResults(self) 163 results = test_page_measurement_results.TestPageMeasurementResults(self)
164 164
165 bypass_exception = False 165 bypass_exception = False
166 try: 166 try:
167 metric.AddResultsForBypass(None, results) 167 metric.AddResultsForBypass(None, results)
168 except chrome_proxy.ChromeProxyMetricException: 168 except metrics.ChromeProxyMetricException:
169 bypass_exception = True 169 bypass_exception = True
170 # Two of the first three events have Via headers. 170 # Two of the first three events have Via headers.
171 self.assertTrue(bypass_exception) 171 self.assertTrue(bypass_exception)
172 172
173 # Use directly fetched image only. It is treated as bypassed. 173 # Use directly fetched image only. It is treated as bypassed.
174 metric.SetEvents([EVENT_IMAGE_DIRECT]) 174 metric.SetEvents([EVENT_IMAGE_DIRECT])
175 metric.AddResultsForBypass(None, results) 175 metric.AddResultsForBypass(None, results)
176 results.AssertHasPageSpecificScalarValue('bypass', 'count', 1) 176 results.AssertHasPageSpecificScalarValue('bypass', 'count', 1)
177 177
178 def testChromeProxyMetricForHTTPFallback(self): 178 def testChromeProxyMetricForHTTPFallback(self):
179 metric = chrome_proxy.ChromeProxyMetric() 179 metric = metrics.ChromeProxyMetric()
180 metric.SetEvents([ 180 metric.SetEvents([
181 EVENT_HTML_PROXY, 181 EVENT_HTML_PROXY,
182 EVENT_HTML_PROXY_DEPRECATED_VIA]) 182 EVENT_HTML_PROXY_DEPRECATED_VIA])
183 results = test_page_measurement_results.TestPageMeasurementResults(self) 183 results = test_page_measurement_results.TestPageMeasurementResults(self)
184 184
185 fallback_exception = False 185 fallback_exception = False
186 info = {} 186 info = {}
187 info['enabled'] = False 187 info['enabled'] = False
188 self._StubGetProxyInfo(info) 188 self._StubGetProxyInfo(info)
189 try: 189 try:
190 metric.AddResultsForBypass(None, results) 190 metric.AddResultsForBypass(None, results)
191 except chrome_proxy.ChromeProxyMetricException: 191 except metrics.ChromeProxyMetricException:
192 fallback_exception = True 192 fallback_exception = True
193 self.assertTrue(fallback_exception) 193 self.assertTrue(fallback_exception)
194 194
195 fallback_exception = False 195 fallback_exception = False
196 info['enabled'] = True 196 info['enabled'] = True
197 info['proxies'] = [ 197 info['proxies'] = [
198 'something.else.com:80', 198 'something.else.com:80',
199 chrome_proxy.PROXY_SETTING_DIRECT 199 metrics.PROXY_SETTING_DIRECT
200 ] 200 ]
201 self._StubGetProxyInfo(info) 201 self._StubGetProxyInfo(info)
202 try: 202 try:
203 metric.AddResultsForBypass(None, results) 203 metric.AddResultsForBypass(None, results)
204 except chrome_proxy.ChromeProxyMetricException: 204 except metrics.ChromeProxyMetricException:
205 fallback_exception = True 205 fallback_exception = True
206 self.assertTrue(fallback_exception) 206 self.assertTrue(fallback_exception)
207 207
208 info['enabled'] = True 208 info['enabled'] = True
209 info['proxies'] = [ 209 info['proxies'] = [
210 chrome_proxy.PROXY_SETTING_HTTP, 210 metrics.PROXY_SETTING_HTTP,
211 chrome_proxy.PROXY_SETTING_DIRECT 211 metrics.PROXY_SETTING_DIRECT
212 ] 212 ]
213 self._StubGetProxyInfo(info) 213 self._StubGetProxyInfo(info)
214 metric.AddResultsForHTTPFallback(None, results) 214 metric.AddResultsForHTTPFallback(None, results)
215 215
216 def testChromeProxyMetricForSafebrowsing(self): 216 def testChromeProxyMetricForSafebrowsing(self):
217 metric = chrome_proxy.ChromeProxyMetric() 217 metric = metrics.ChromeProxyMetric()
218 metric.SetEvents([EVENT_MALWARE_PROXY]) 218 metric.SetEvents([EVENT_MALWARE_PROXY])
219 results = test_page_measurement_results.TestPageMeasurementResults(self) 219 results = test_page_measurement_results.TestPageMeasurementResults(self)
220 220
221 metric.AddResultsForSafebrowsing(None, results) 221 metric.AddResultsForSafebrowsing(None, results)
222 results.AssertHasPageSpecificScalarValue('safebrowsing', 'boolean', True) 222 results.AssertHasPageSpecificScalarValue('safebrowsing', 'boolean', True)
223 223
224 # Clear results and metrics to test no response for safebrowsing 224 # Clear results and metrics to test no response for safebrowsing
225 results = test_page_measurement_results.TestPageMeasurementResults(self) 225 results = test_page_measurement_results.TestPageMeasurementResults(self)
226 metric.SetEvents([]) 226 metric.SetEvents([])
227 metric.AddResultsForSafebrowsing(None, results) 227 metric.AddResultsForSafebrowsing(None, results)
228 results.AssertHasPageSpecificScalarValue('safebrowsing', 'boolean', True) 228 results.AssertHasPageSpecificScalarValue('safebrowsing', 'boolean', True)
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698