OLD | NEW |
| (Empty) |
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
2 # Use of this source code is governed by a BSD-style license that can be | |
3 # found in the LICENSE file. | |
4 import StringIO | |
5 import csv | |
6 import os | |
7 import unittest | |
8 | |
9 from telemetry.csv_page_benchmark_results import CsvPageBenchmarkResults | |
10 from telemetry.page_set import PageSet | |
11 | |
12 def _MakePageSet(): | |
13 return PageSet.FromDict({ | |
14 "description": "hello", | |
15 "pages": [ | |
16 {"url": "http://www.foo.com/"}, | |
17 {"url": "http://www.bar.com/"} | |
18 ] | |
19 }, os.path.dirname(__file__)) | |
20 | |
21 class NonPrintingCsvPageBenchmarkResults(CsvPageBenchmarkResults): | |
22 def __init__(self, *args): | |
23 super(NonPrintingCsvPageBenchmarkResults, self).__init__(*args) | |
24 | |
25 def _PrintPerfResult(self, *args): | |
26 pass | |
27 | |
28 class CsvPageBenchmarkResultsTest(unittest.TestCase): | |
29 def setUp(self): | |
30 self._output = StringIO.StringIO() | |
31 self._page_set = _MakePageSet() | |
32 | |
33 @property | |
34 def lines(self): | |
35 lines = StringIO.StringIO(self._output.getvalue()).readlines() | |
36 return lines | |
37 | |
38 @property | |
39 def output_header_row(self): | |
40 rows = list(csv.reader(self.lines)) | |
41 return rows[0] | |
42 | |
43 @property | |
44 def output_data_rows(self): | |
45 rows = list(csv.reader(self.lines)) | |
46 return rows[1:] | |
47 | |
48 def test_with_output_after_every_page(self): | |
49 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), True) | |
50 results.WillMeasurePage(self._page_set[0]) | |
51 results.Add('foo', 'seconds', 3) | |
52 results.DidMeasurePage() | |
53 self.assertEquals( | |
54 self.output_header_row, | |
55 ['url', 'foo (seconds)']) | |
56 self.assertEquals( | |
57 self.output_data_rows[0], | |
58 [self._page_set[0].url, '3']) | |
59 | |
60 results.WillMeasurePage(self._page_set[1]) | |
61 results.Add('foo', 'seconds', 4) | |
62 results.DidMeasurePage() | |
63 self.assertEquals( | |
64 len(self.output_data_rows), | |
65 2) | |
66 self.assertEquals( | |
67 self.output_data_rows[1], | |
68 [self._page_set[1].url, '4']) | |
69 | |
70 def test_with_output_after_every_page_and_inconsistency(self): | |
71 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), True) | |
72 results.WillMeasurePage(self._page_set[0]) | |
73 results.Add('foo', 'seconds', 3) | |
74 results.DidMeasurePage() | |
75 | |
76 # We printed foo, now change to bar | |
77 results.WillMeasurePage(self._page_set[1]) | |
78 results.Add('bar', 'seconds', 4) | |
79 | |
80 self.assertRaises( | |
81 Exception, | |
82 lambda: results.DidMeasurePage()) # pylint: disable=W0108 | |
83 | |
84 def test_with_output_at_print_summary_time(self): | |
85 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), | |
86 False) | |
87 results.WillMeasurePage(self._page_set[0]) | |
88 results.Add('foo', 'seconds', 3) | |
89 results.DidMeasurePage() | |
90 | |
91 results.WillMeasurePage(self._page_set[1]) | |
92 results.Add('bar', 'seconds', 4) | |
93 results.DidMeasurePage() | |
94 | |
95 results.PrintSummary('tag') | |
96 | |
97 self.assertEquals( | |
98 self.output_header_row, | |
99 ['url', 'bar (seconds)', 'foo (seconds)']) | |
100 self.assertEquals( | |
101 self.output_data_rows, | |
102 [[self._page_set[0].url, '-', '3'], | |
103 [self._page_set[1].url, '4', '-']]) | |
104 | |
105 def test_histogram(self): | |
106 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), | |
107 False) | |
108 results.WillMeasurePage(self._page_set[0]) | |
109 results.Add('a', '', | |
110 '{"buckets": [{"low": 1, "high": 2, "count": 1}]}', | |
111 data_type='histogram') | |
112 results.DidMeasurePage() | |
113 | |
114 results.WillMeasurePage(self._page_set[1]) | |
115 results.Add('a', '', | |
116 '{"buckets": [{"low": 2, "high": 3, "count": 1}]}', | |
117 data_type='histogram') | |
118 results.DidMeasurePage() | |
119 | |
120 results.PrintSummary('tag') | |
121 | |
122 self.assertEquals( | |
123 self.output_header_row, | |
124 ['url', 'a ()']) | |
125 self.assertEquals( | |
126 self.output_data_rows, | |
127 [[self._page_set[0].url, '1.5'], | |
128 [self._page_set[1].url, '2.5']]) | |
OLD | NEW |