File: test_logparser.py

package info (click to toggle)
pypy3 7.3.19%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 212,236 kB
  • sloc: python: 2,098,316; ansic: 540,565; sh: 21,462; asm: 14,419; cpp: 4,451; makefile: 4,209; objc: 761; xml: 530; exp: 499; javascript: 314; pascal: 244; lisp: 45; csh: 12; 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}