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

Side by Side Diff: tools/telemetry/telemetry/page/csv_page_benchmark_results_unittest.py

Issue 12294002: Revert 182991 (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 7 years, 10 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 | Annotate | Revision Log
OLDNEW
(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.page import csv_page_benchmark_results
10 from telemetry.page import page_set
11
12 def _MakePageSet():
13 return page_set.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(
22 csv_page_benchmark_results.CsvPageBenchmarkResults):
23 def __init__(self, *args):
24 super(NonPrintingCsvPageBenchmarkResults, self).__init__(*args)
25
26 def _PrintPerfResult(self, *args):
27 pass
28
29 class CsvPageBenchmarkResultsTest(unittest.TestCase):
30 def setUp(self):
31 self._output = StringIO.StringIO()
32 self._page_set = _MakePageSet()
33
34 @property
35 def lines(self):
36 lines = StringIO.StringIO(self._output.getvalue()).readlines()
37 return lines
38
39 @property
40 def output_header_row(self):
41 rows = list(csv.reader(self.lines))
42 return rows[0]
43
44 @property
45 def output_data_rows(self):
46 rows = list(csv.reader(self.lines))
47 return rows[1:]
48
49 def test_with_output_after_every_page(self):
50 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), True)
51 results.WillMeasurePage(self._page_set[0])
52 results.Add('foo', 'seconds', 3)
53 results.DidMeasurePage()
54 self.assertEquals(
55 self.output_header_row,
56 ['url', 'foo (seconds)'])
57 self.assertEquals(
58 self.output_data_rows[0],
59 [self._page_set[0].url, '3'])
60
61 results.WillMeasurePage(self._page_set[1])
62 results.Add('foo', 'seconds', 4)
63 results.DidMeasurePage()
64 self.assertEquals(
65 len(self.output_data_rows),
66 2)
67 self.assertEquals(
68 self.output_data_rows[1],
69 [self._page_set[1].url, '4'])
70
71 def test_with_output_after_every_page_and_inconsistency(self):
72 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output), True)
73 results.WillMeasurePage(self._page_set[0])
74 results.Add('foo', 'seconds', 3)
75 results.DidMeasurePage()
76
77 # We printed foo, now change to bar
78 results.WillMeasurePage(self._page_set[1])
79 results.Add('bar', 'seconds', 4)
80
81 self.assertRaises(
82 Exception,
83 lambda: results.DidMeasurePage()) # pylint: disable=W0108
84
85 def test_with_output_at_print_summary_time(self):
86 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output),
87 False)
88 results.WillMeasurePage(self._page_set[0])
89 results.Add('foo', 'seconds', 3)
90 results.DidMeasurePage()
91
92 results.WillMeasurePage(self._page_set[1])
93 results.Add('bar', 'seconds', 4)
94 results.DidMeasurePage()
95
96 results.PrintSummary('tag')
97
98 self.assertEquals(
99 self.output_header_row,
100 ['url', 'bar (seconds)', 'foo (seconds)'])
101 self.assertEquals(
102 self.output_data_rows,
103 [[self._page_set[0].url, '-', '3'],
104 [self._page_set[1].url, '4', '-']])
105
106 def test_histogram(self):
107 results = NonPrintingCsvPageBenchmarkResults(csv.writer(self._output),
108 False)
109 results.WillMeasurePage(self._page_set[0])
110 results.Add('a', '',
111 '{"buckets": [{"low": 1, "high": 2, "count": 1}]}',
112 data_type='histogram')
113 results.DidMeasurePage()
114
115 results.WillMeasurePage(self._page_set[1])
116 results.Add('a', '',
117 '{"buckets": [{"low": 2, "high": 3, "count": 1}]}',
118 data_type='histogram')
119 results.DidMeasurePage()
120
121 results.PrintSummary('tag')
122
123 self.assertEquals(
124 self.output_header_row,
125 ['url', 'a ()'])
126 self.assertEquals(
127 self.output_data_rows,
128 [[self._page_set[0].url, '1.5'],
129 [self._page_set[1].url, '2.5']])
OLDNEW
« no previous file with comments | « tools/telemetry/telemetry/page/csv_page_benchmark_results.py ('k') | tools/telemetry/telemetry/page/multi_page_benchmark.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698