File: test_logparser.py

package info (click to toggle)
pypy 7.0.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 107,216 kB
  • sloc: python: 1,201,787; ansic: 62,419; asm: 5,169; cpp: 3,017; sh: 2,534; makefile: 545; xml: 243; lisp: 45; awk: 4
file content (62 lines) | stat: -rw-r--r-- 1,655 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
from rpython.tool.udir import udir
from rpython.tool.logparser import *


globalpath = udir.join('test_logparser.log')
globalpath.write("""\
test1
[12a0] {foo
test2a
test2b
[12b0] {bar
test3
[12e0] bar}
test4
[12e5] {bar
test5a
test5b
[12e6] bar}
test6
[12f0] foo}
test7
""")


def test_parse_log_file():
    log = parse_log_file(str(globalpath))
    assert log == [
        ('debug_print', 'test1'),
        ('foo', 0x12a0, 0x12f0, [
            ('debug_print', 'test2a'),
            ('debug_print', 'test2b'),
            ('bar', 0x12b0, 0x12e0, [
                ('debug_print', 'test3')]),
            ('debug_print', 'test4'),
            ('bar', 0x12e5, 0x12e6, [
                ('debug_print', 'test5a'),
                ('debug_print', 'test5b')]),
            ('debug_print', 'test6')]),
        ('debug_print', 'test7')]

def test_extract_category():
    log = parse_log_file(str(globalpath))
    catbar = list(extract_category(log, 'bar'))
    assert catbar == ["test3\n", "test5a\ntest5b\n"]
    assert catbar == list(extract_category(log, 'ba'))
    catfoo = list(extract_category(log, 'foo'))
    assert catfoo == ["test2a\ntest2b\ntest4\ntest6\n"]
    assert catfoo == list(extract_category(log, 'f'))
    catall = list(extract_category(log, ''))
    assert catall == catfoo + catbar

def test_gettotaltimes():
    result = gettotaltimes([
        ('foo', 2, 17, [
            ('bar', 4, 5, []),
            ('bar', 7, 9, []),
            ]),
        ('bar', 20, 30, []),
        ])
    assert result == {None: 3,              # the hole between 17 and 20
                      'foo': 15 - 1 - 2,
                      'bar': 1 + 2 + 10}