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

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

Issue 12278015: [Telemetry] Reorganize everything. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Re-add shebangs. 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.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']])
OLDNEW
« no previous file with comments | « tools/telemetry/telemetry/csv_page_benchmark_results.py ('k') | tools/telemetry/telemetry/desktop_browser_backend.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698