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

Side by Side Diff: tools/cygprofile/symbol_extractor_unittest.py

Issue 886563002: Switch from nm to objdump for the cygprofile tools. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comments. Created 5 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
« no previous file with comments | « tools/cygprofile/symbol_extractor.py ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/python 1 #!/usr/bin/python
2 # Copyright 2015 The Chromium Authors. All rights reserved. 2 # Copyright 2015 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be 3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file. 4 # found in the LICENSE file.
5 5
6 import symbol_extractor 6 import symbol_extractor
7 import unittest 7 import unittest
8 8
9 class TestSymbolInfo(unittest.TestCase): 9 class TestSymbolInfo(unittest.TestCase):
10 def testIgnoresBlankLine(self): 10 def testIgnoresBlankLine(self):
11 symbol_info = symbol_extractor.FromNmLine('') 11 symbol_info = symbol_extractor._FromObjdumpLine('')
12 self.assertIsNone(symbol_info) 12 self.assertIsNone(symbol_info)
13 13
14 def testIgnoresMalformedLine(self): 14 def testIgnoresMalformedLine(self):
15 line = ('00210d59 00000002 t _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev ' 15 # This line is too short.
16 'too many fields') 16 line = ('00c1b228 F .text 00000060 _ZN20trace_event')
17 symbol_info = symbol_extractor.FromNmLine(line) 17 symbol_info = symbol_extractor._FromObjdumpLine(line)
18 self.assertIsNone(symbol_info) 18 self.assertIsNone(symbol_info)
19 # Wrong marker 19 # This line has the wrong marker.
20 line = '00210d59 00000002 A _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev' 20 line = '00c1b228 l f .text 00000060 _ZN20trace_event'
21 symbol_info = symbol_extractor.FromNmLine(line) 21 symbol_info = symbol_extractor._FromObjdumpLine(line)
22 self.assertIsNone(symbol_info)
23 # Too short
24 line = '00210d59 t'
25 symbol_info = symbol_extractor.FromNmLine(line)
26 self.assertIsNone(symbol_info) 22 self.assertIsNone(symbol_info)
27 23
28 def testSymbolInfoWithSize(self): 24 def testAssertionErrorOnInvalidLines(self):
29 line = '00210d59 00000002 t _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev' 25 # This line has an invalid scope
pasko 2015/01/29 15:22:11 period? here and below please, if you will
Benoit L 2015/01/29 15:26:00 Done.
30 test_name = '_ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev' 26 line = ('00c1b228 z F .text 00000060 _ZN20trace_event')
31 test_offset = 0x210d59 27 self.assertRaises(AssertionError, symbol_extractor._FromObjdumpLine, line)
pasko 2015/01/29 15:22:11 omg this is so cool! I did not know about it, and
Benoit L 2015/01/29 15:26:00 Acknowledged.
32 test_size = 2 28 # This line has too many fields
33 symbol_info = symbol_extractor.FromNmLine(line) 29 line = ('00c1b228 z F .text 00000060 _ZN20trace_event too many')
pasko 2015/01/29 15:22:11 this asserts for the same reason as the previous o
Benoit L 2015/01/29 15:26:00 Done.
30 self.assertRaises(AssertionError, symbol_extractor._FromObjdumpLine, line)
31 # This line has invalid characters int the symbol
32 line = ('00c1b228 z F .text 00000060 _ZN20trace_$bad')
33 self.assertRaises(AssertionError, symbol_extractor._FromObjdumpLine, line)
34
35 def testSymbolInfo(self):
36 line = ('00c1c05c l F .text 0000002c '
37 '_GLOBAL__sub_I_chrome_main_delegate.cc')
38 test_name = '_GLOBAL__sub_I_chrome_main_delegate.cc'
39 test_offset = 0x00c1c05c
40 test_size = 0x2c
41 test_section = '.text'
42 symbol_info = symbol_extractor._FromObjdumpLine(line)
34 self.assertIsNotNone(symbol_info) 43 self.assertIsNotNone(symbol_info)
35 self.assertEquals(test_offset, symbol_info.offset) 44 self.assertEquals(test_offset, symbol_info.offset)
36 self.assertEquals(test_size, symbol_info.size) 45 self.assertEquals(test_size, symbol_info.size)
37 self.assertEquals(test_name, symbol_info.name) 46 self.assertEquals(test_name, symbol_info.name)
47 self.assertEquals(test_section, symbol_info.section)
38 48
39 def testSymbolInfoWithoutSize(self): 49 def testHiddenSymbol(self):
40 line = '0070ee8c T WebRtcSpl_ComplexBitReverse' 50 line = ('00c1c05c l F .text 0000002c '
41 test_name = 'WebRtcSpl_ComplexBitReverse' 51 '.hidden _GLOBAL__sub_I_chrome_main_delegate.cc')
42 test_offset = 0x70ee8c 52 test_name = '_GLOBAL__sub_I_chrome_main_delegate.cc'
43 symbol_info = symbol_extractor.FromNmLine(line) 53 test_offset = 0x00c1c05c
54 test_size = 0x2c
55 test_section = '.text'
56 symbol_info = symbol_extractor._FromObjdumpLine(line)
44 self.assertIsNotNone(symbol_info) 57 self.assertIsNotNone(symbol_info)
45 self.assertEquals(test_offset, symbol_info.offset) 58 self.assertEquals(test_offset, symbol_info.offset)
46 self.assertEquals(-1, symbol_info.size) 59 self.assertEquals(test_size, symbol_info.size)
47 self.assertEquals(test_name, symbol_info.name) 60 self.assertEquals(test_name, symbol_info.name)
61 self.assertEquals(test_section, symbol_info.section)
48 62
49 63
50 class TestSymbolInfosFromStream(unittest.TestCase): 64 class TestSymbolInfosFromStream(unittest.TestCase):
51 def testSymbolInfosFromStream(self): 65 def testSymbolInfosFromStream(self):
52 lines = ['Garbage', 66 lines = ['Garbage',
53 '', 67 '',
54 ('00210d59 00000002 t _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev ' 68 '00c1c05c l F .text 0000002c first',
55 'too many fields'), 69 ''
56 '00210d59 00000002 t _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev', 70 'more garbage',
57 '00210d59 00000002 A _ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev', 71 '00155 g F .text 00000012 second']
58 '0070ee8c T WebRtcSpl_ComplexBitReverse'] 72 symbol_infos = symbol_extractor._SymbolInfosFromStream(lines)
59 symbol_infos = symbol_extractor.SymbolInfosFromStream(lines)
60 self.assertEquals(len(symbol_infos), 2) 73 self.assertEquals(len(symbol_infos), 2)
61 first = symbol_extractor.SymbolInfo( 74 first = symbol_extractor.SymbolInfo('first', 0x00c1c05c, 0x2c, '.text')
62 '_ZN34BrowserPluginHostMsg_Attach_ParamsD2Ev', 0x00210d59, 2)
63 self.assertEquals(first, symbol_infos[0]) 75 self.assertEquals(first, symbol_infos[0])
64 second = symbol_extractor.SymbolInfo( 76 second = symbol_extractor.SymbolInfo('second', 0x00155, 0x12, '.text')
65 'WebRtcSpl_ComplexBitReverse', 0x0070ee8c, -1)
66 self.assertEquals(second, symbol_infos[1]) 77 self.assertEquals(second, symbol_infos[1])
67 78
68 79
69 class TestSymbolInfoMappings(unittest.TestCase): 80 class TestSymbolInfoMappings(unittest.TestCase):
70 def setUp(self): 81 def setUp(self):
71 self.symbol_infos = [ 82 self.symbol_infos = [
72 symbol_extractor.SymbolInfo('firstNameAtOffset', 0x42, 42), 83 symbol_extractor.SymbolInfo('firstNameAtOffset', 0x42, 42, '.text'),
73 symbol_extractor.SymbolInfo('secondNameAtOffset', 0x42, 42), 84 symbol_extractor.SymbolInfo('secondNameAtOffset', 0x42, 42, '.text'),
74 symbol_extractor.SymbolInfo('thirdSymbol', 0x64, 20)] 85 symbol_extractor.SymbolInfo('thirdSymbol', 0x64, 20, '.text')]
75 86
76 def testGroupSymbolInfosByOffset(self): 87 def testGroupSymbolInfosByOffset(self):
77 offset_to_symbol_info = symbol_extractor.GroupSymbolInfosByOffset( 88 offset_to_symbol_info = symbol_extractor.GroupSymbolInfosByOffset(
78 self.symbol_infos) 89 self.symbol_infos)
79 self.assertEquals(len(offset_to_symbol_info), 2) 90 self.assertEquals(len(offset_to_symbol_info), 2)
80 self.assertIn(0x42, offset_to_symbol_info) 91 self.assertIn(0x42, offset_to_symbol_info)
81 self.assertEquals(offset_to_symbol_info[0x42][0], self.symbol_infos[0]) 92 self.assertEquals(offset_to_symbol_info[0x42][0], self.symbol_infos[0])
82 self.assertEquals(offset_to_symbol_info[0x42][1], self.symbol_infos[1]) 93 self.assertEquals(offset_to_symbol_info[0x42][1], self.symbol_infos[1])
83 self.assertIn(0x64, offset_to_symbol_info) 94 self.assertIn(0x64, offset_to_symbol_info)
84 self.assertEquals(offset_to_symbol_info[0x64][0], self.symbol_infos[2]) 95 self.assertEquals(offset_to_symbol_info[0x64][0], self.symbol_infos[2])
85 96
86 def testCreateNameToSymbolInfos(self): 97 def testCreateNameToSymbolInfo(self):
87 name_to_symbol_info = symbol_extractor.CreateNameToSymbolInfo( 98 name_to_symbol_info = symbol_extractor.CreateNameToSymbolInfo(
88 self.symbol_infos) 99 self.symbol_infos)
89 self.assertEquals(len(name_to_symbol_info), 3) 100 self.assertEquals(len(name_to_symbol_info), 3)
90 for i in range(3): 101 for i in range(3):
91 name = self.symbol_infos[i].name 102 name = self.symbol_infos[i].name
92 self.assertIn(name, name_to_symbol_info) 103 self.assertIn(name, name_to_symbol_info)
93 self.assertEquals(self.symbol_infos[i], name_to_symbol_info[name]) 104 self.assertEquals(self.symbol_infos[i], name_to_symbol_info[name])
94 105
95 106
96
97 if __name__ == '__main__': 107 if __name__ == '__main__':
98 unittest.main() 108 unittest.main()
OLDNEW
« no previous file with comments | « tools/cygprofile/symbol_extractor.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698