Chromium Code Reviews| Index: tools/find_runtime_symbols/tests/proc_maps_tests.py |
| diff --git a/tools/find_runtime_symbols/tests/proc_maps_tests.py b/tools/find_runtime_symbols/tests/proc_maps_tests.py |
| new file mode 100755 |
| index 0000000000000000000000000000000000000000..75d06bb5c1ea193a21b15b9ad0c7d56b5be14f17 |
| --- /dev/null |
| +++ b/tools/find_runtime_symbols/tests/proc_maps_tests.py |
| @@ -0,0 +1,70 @@ |
| +#!/usr/bin/env python |
| +# Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +# Use of this source code is governed by a BSD-style license that can be |
| +# found in the LICENSE file. |
| + |
| +import cStringIO |
| +import logging |
| +import os |
| +import sys |
| +import unittest |
| + |
| +ROOT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) |
| +sys.path.insert(0, ROOT_DIR) |
| + |
| +from proc_maps import ProcMaps |
| + |
| + |
| +class ProcMapsTest(unittest.TestCase): |
|
M-A Ruel
2012/11/20 14:30:00
It is still preferable to restrict to 80 cols. Spl
Dai Mikurube (NOT FULLTIME)
2012/11/21 05:51:45
Done.
|
| + _TEST_PROCMAPS = """00000000-00001000 r--p 00000000 fc:00 0 |
| +0080b000-0080c000 r--p 0020b000 fc:00 2231329 /usr/bin/some |
| +0237d000-02a9b000 rw-p 00000000 00:00 0 [heap] |
| +7fb920e6d000-7fb920e85000 r-xp 00000000 fc:00 263482 /lib/x86_64-linux-gnu/libpthread-2.15.so |
| +7fb920e85000-7fb921084000 ---p 00018000 fc:00 263482 /lib/x86_64-linux-gnu/libpthread-2.15.so |
| +7fb9225f4000-7fb922654000 rw-s 00000000 00:04 19660808 /SYSV00000000 (deleted) |
| +ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall] |
| +""" |
| + |
| + def test_load(self): |
| + maps = ProcMaps.load(cStringIO.StringIO(self._TEST_PROCMAPS)) |
| + entries = [] |
| + for entry in maps: |
| + entries.append(entry) |
| + self.assertEqual(len(entries), 7) |
| + self.assertEqual(entries[0].begin, 0x0) |
|
M-A Ruel
2012/11/20 14:30:00
If you had something like entries[0].as_dict(), it
Dai Mikurube (NOT FULLTIME)
2012/11/21 05:51:45
Thanks for the good suggestion. Done.
Also added
|
| + self.assertEqual(entries[0].name, '') |
| + self.assertEqual(entries[0].end, 0x1000) |
| + self.assertEqual(entries[1].begin, 0x80b000) |
| + self.assertEqual(entries[1].end, 0x80c000) |
| + self.assertEqual(entries[1].readable, 'r') |
| + self.assertEqual(entries[1].writable, '-') |
| + self.assertEqual(entries[1].executable, '-') |
| + self.assertEqual(entries[1].private, 'p') |
| + self.assertEqual(entries[1].offset, 0x20b000) |
| + self.assertEqual(entries[1].major, 'fc') |
| + self.assertEqual(entries[1].minor, '00') |
| + self.assertEqual(entries[1].inode, 2231329) |
| + self.assertEqual(entries[1].name, '/usr/bin/some') |
| + self.assertEqual(entries[2].begin, 0x237d000) |
| + self.assertEqual(entries[2].writable, 'w') |
| + self.assertEqual(entries[2].name, '[heap]') |
| + self.assertEqual(entries[3].begin, 0x7fb920e6d000) |
| + self.assertEqual(entries[3].executable, 'x') |
| + self.assertEqual(entries[4].begin, 0x7fb920e85000) |
| + self.assertEqual(entries[4].readable, '-') |
| + self.assertEqual(entries[5].begin, 0x7fb9225f4000) |
| + self.assertEqual(entries[5].private, 's') |
| + self.assertEqual(entries[5].major, '00') |
| + self.assertEqual(entries[5].minor, '04') |
| + self.assertEqual(entries[5].inode, 19660808) |
| + self.assertEqual(entries[5].name, '/SYSV00000000 (deleted)') |
| + self.assertEqual(entries[6].begin, 0xffffffffff600000) |
| + self.assertEqual(entries[6].end, 0xffffffffff601000) |
| + self.assertEqual(entries[6].name, '[vsyscall]') |
| + |
| + |
| +if __name__ == '__main__': |
| + logging.basicConfig( |
| + level=logging.DEBUG if '-v' in sys.argv else logging.ERROR, |
| + format='%(levelname)5s %(filename)15s(%(lineno)3d): %(message)s') |
| + unittest.main() |