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

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
OLDNEW
(Empty)
1 #!/usr/bin/python
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
4 # found in the LICENSE file.
5
6 import symbol_extractor
7 import unittest
8
9 class TestSymbolInfo(unittest.TestCase):
10 def testIgnoresBlankLine(self):
11 symbol_info = symbol_extractor._FromObjdumpLine('')
12 self.assertIsNone(symbol_info)
13
14 def testIgnoresMalformedLine(self):
15 # Too short
pasko 2015/01/29 12:24:43 All our styleguides strongly recommend the comment
Benoit L 2015/01/29 13:10:30 Done.
16 line = ('00c1b228 F .text 00000060 _ZN20trace_event')
17 symbol_info = symbol_extractor._FromObjdumpLine(line)
18 self.assertIsNone(symbol_info)
19 # Wrong marker
20 line = '00c1b228 l f .text 00000060 _ZN20trace_event'
21 symbol_info = symbol_extractor._FromObjdumpLine(line)
22 self.assertIsNone(symbol_info)
23
24 def testSymbolInfo(self):
25 line = ('00c1c05c l F .text 0000002c '
26 '_GLOBAL__sub_I_chrome_main_delegate.cc')
27 test_name = '_GLOBAL__sub_I_chrome_main_delegate.cc'
28 test_offset = 0x00c1c05c
29 test_size = 0x2c
30 test_section = '.text'
31 symbol_info = symbol_extractor._FromObjdumpLine(line)
32 self.assertIsNotNone(symbol_info)
33 self.assertEquals(test_offset, symbol_info.offset)
34 self.assertEquals(test_size, symbol_info.size)
35 self.assertEquals(test_name, symbol_info.name)
36 self.assertEquals(test_section, symbol_info.section)
37
38 def testHiddenSymbol(self):
39 line = ('00c1c05c l F .text 0000002c '
40 'hidden _GLOBAL__sub_I_chrome_main_delegate.cc')
pasko 2015/01/29 12:24:42 s/hidden/.hidden/ I <3 realism.
Benoit L 2015/01/29 13:10:30 Done.
41 test_name = '_GLOBAL__sub_I_chrome_main_delegate.cc'
42 test_offset = 0x00c1c05c
43 test_size = 0x2c
44 test_section = '.text'
45 symbol_info = symbol_extractor._FromObjdumpLine(line)
46 self.assertIsNotNone(symbol_info)
47 self.assertEquals(test_offset, symbol_info.offset)
48 self.assertEquals(test_size, symbol_info.size)
49 self.assertEquals(test_name, symbol_info.name)
50 self.assertEquals(test_section, symbol_info.section)
51
52 class TestSymbolInfosFromStream(unittest.TestCase):
pasko 2015/01/29 12:24:42 more whitespace is absolutely necessary, otherwise
Benoit L 2015/01/29 13:10:30 Done.
53 def testSymbolInfosFromStream(self):
54 lines = ['Garbage',
55 '',
56 '00c1c05c l F .text 0000002c first',
57 ''
58 'more garbage',
59 '00155 g F .text 00000012 second']
60 symbol_infos = symbol_extractor._SymbolInfosFromStream(lines)
61 self.assertEquals(len(symbol_infos), 2)
62 first = symbol_extractor.SymbolInfo('first', 0x00c1c05c, 0x2c, '.text')
63 self.assertEquals(first, symbol_infos[0])
64 second = symbol_extractor.SymbolInfo('second', 0x00155, 0x12, '.text')
65 self.assertEquals(second, symbol_infos[1])
66
67
68 class TestSymbolInfoMappings(unittest.TestCase):
69 def setUp(self):
70 self.symbol_infos = [
71 symbol_extractor.SymbolInfo('firstNameAtOffset', 0x42, 42, '.text'),
72 symbol_extractor.SymbolInfo('secondNameAtOffset', 0x42, 42, '.text'),
73 symbol_extractor.SymbolInfo('thirdSymbol', 0x64, 20, '.text')]
74
75 def testGroupSymbolInfosByOffset(self):
76 offset_to_symbol_info = symbol_extractor.GroupSymbolInfosByOffset(
77 self.symbol_infos)
78 self.assertEquals(len(offset_to_symbol_info), 2)
79 self.assertIn(0x42, offset_to_symbol_info)
80 self.assertEquals(offset_to_symbol_info[0x42][0], self.symbol_infos[0])
81 self.assertEquals(offset_to_symbol_info[0x42][1], self.symbol_infos[1])
82 self.assertIn(0x64, offset_to_symbol_info)
83 self.assertEquals(offset_to_symbol_info[0x64][0], self.symbol_infos[2])
84
85 def testCreateNameToSymbolInfos(self):
pasko 2015/01/29 12:24:43 nittish nit: if this test is to stay, probably sh
Benoit L 2015/01/29 13:10:30 Done.
86 name_to_symbol_info = symbol_extractor.CreateNameToSymbolInfo(
87 self.symbol_infos)
88 self.assertEquals(len(name_to_symbol_info), 3)
89 for i in range(3):
90 name = self.symbol_infos[i].name
91 self.assertIn(name, name_to_symbol_info)
92 self.assertEquals(self.symbol_infos[i], name_to_symbol_info[name])
93
94
95
96 if __name__ == '__main__':
97 unittest.main()
OLDNEW
« tools/cygprofile/symbol_extractor.py ('K') | « tools/cygprofile/symbol_extractor.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698