OLD | NEW |
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 os | 5 import os |
6 import tempfile | 6 import tempfile |
7 import unittest | 7 import unittest |
8 import zipfile | 8 import zipfile |
9 | 9 |
10 from profile_chrome import profiler | 10 from profile_chrome import profiler |
11 from profile_chrome import ui | 11 from profile_chrome import ui |
12 from systrace import trace_result | 12 from systrace import trace_result |
13 | 13 |
14 | 14 |
15 class FakeAgent(object): | 15 class FakeAgent(object): |
16 def __init__(self, contents='fake-contents'): | 16 def __init__(self, contents='fake-contents'): |
17 self.contents = contents | 17 self.contents = contents |
18 self.stopped = False | 18 self.stopped = False |
19 self.filename = None | 19 self.filename = None |
20 self.options = None | 20 self.config = None |
21 self.categories = None | |
22 self.timeout = None | 21 self.timeout = None |
23 | 22 |
24 def StartAgentTracing(self, options, categories, timeout=None): | 23 def StartAgentTracing(self, config, timeout=None): |
25 self.options = options | 24 self.config = config |
26 self.categories = categories | |
27 self.timeout = timeout | 25 self.timeout = timeout |
28 | 26 |
29 # pylint: disable=unused-argument | 27 # pylint: disable=unused-argument |
30 def StopAgentTracing(self, timeout=None): | 28 def StopAgentTracing(self, timeout=None): |
31 self.stopped = True | 29 self.stopped = True |
32 | 30 |
33 # pylint: disable=unused-argument | 31 # pylint: disable=unused-argument |
34 def GetResults(self, timeout=None): | 32 def GetResults(self, timeout=None): |
35 trace_data = open(self.PullTrace()).read() | 33 trace_data = open(self.PullTrace()).read() |
36 return trace_result.TraceResult('fakeData', trace_data) | 34 return trace_result.TraceResult('fakeData', trace_data) |
(...skipping 16 matching lines...) Expand all Loading... |
53 def __repr__(self): | 51 def __repr__(self): |
54 return 'faketrace' | 52 return 'faketrace' |
55 | 53 |
56 | 54 |
57 class ProfilerTest(unittest.TestCase): | 55 class ProfilerTest(unittest.TestCase): |
58 def setUp(self): | 56 def setUp(self): |
59 ui.EnableTestMode() | 57 ui.EnableTestMode() |
60 | 58 |
61 def testCaptureBasicProfile(self): | 59 def testCaptureBasicProfile(self): |
62 agent = FakeAgent() | 60 agent = FakeAgent() |
63 result = profiler.CaptureProfile([agent], 1) | 61 result = profiler.CaptureProfile(None, [agent], 1) |
64 | 62 |
65 try: | 63 try: |
66 self.assertTrue(agent.stopped) | 64 self.assertTrue(agent.stopped) |
67 self.assertTrue(os.path.exists(result)) | 65 self.assertTrue(os.path.exists(result)) |
68 self.assertTrue(result.endswith('.html')) | 66 self.assertTrue(result.endswith('.html')) |
69 finally: | 67 finally: |
70 if os.path.exists(result): | 68 if os.path.exists(result): |
71 os.remove(result) | 69 os.remove(result) |
72 | 70 |
73 def testCaptureJsonProfile(self): | 71 def testCaptureJsonProfile(self): |
74 agent = FakeAgent() | 72 agent = FakeAgent() |
75 result = profiler.CaptureProfile([agent], 1, write_json=True) | 73 result = profiler.CaptureProfile(None, [agent], 1, write_json=True) |
76 | 74 |
77 try: | 75 try: |
78 self.assertFalse(result.endswith('.html')) | 76 self.assertFalse(result.endswith('.html')) |
79 with open(result) as f: | 77 with open(result) as f: |
80 self.assertEquals(f.read(), agent.contents) | 78 self.assertEquals(f.read(), agent.contents) |
81 finally: | 79 finally: |
82 if os.path.exists(result): | 80 if os.path.exists(result): |
83 os.remove(result) | 81 os.remove(result) |
84 | 82 |
85 def testCaptureMultipleProfiles(self): | 83 def testCaptureMultipleProfiles(self): |
86 agents = [FakeAgent('c1'), FakeAgent('c2')] | 84 agents = [FakeAgent('c1'), FakeAgent('c2')] |
87 result = profiler.CaptureProfile(agents, 1, write_json=True) | 85 result = profiler.CaptureProfile(None, agents, 1, write_json=True) |
88 | 86 |
89 try: | 87 try: |
90 self.assertTrue(result.endswith('.zip')) | 88 self.assertTrue(result.endswith('.zip')) |
91 self.assertTrue(zipfile.is_zipfile(result)) | 89 self.assertTrue(zipfile.is_zipfile(result)) |
92 finally: | 90 finally: |
93 if os.path.exists(result): | 91 if os.path.exists(result): |
94 os.remove(result) | 92 os.remove(result) |
OLD | NEW |