| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | #!/usr/bin/env python3import jsonimport osimport sysif sys.version_info[0] >= 3:    unicode = strtrace_file = Noneexpand = Falsefor i in sys.argv[1:]:    if trace_file is None and not i.startswith('-'):        trace_file = i        continue    if i in ['-e', '--expand']:        expand = Trueassert trace_file is not Noneassert os.path.exists(trace_file)if expand:    msg_args = ['STATUS', 'fff', 'fff;sss;  SPACES !!!  ', ' 42  space in string!', '  SPACES !!!  ']else:    msg_args = ['STATUS', 'fff', '${ASDF}', ' ${FOO} ${BAR}', '  SPACES !!!  ']required_traces = [    {        'args': ['STATUS', 'JSON-V1 str', 'spaces'],        'cmd': 'message',    },    {        'args': ['ASDF', 'fff', 'sss', '  SPACES !!!  '],        'cmd': 'set',    },    {        'args': ['FOO', '42'],        'cmd': 'set',    },    {        'args': ['BAR', ' space in string!'],        'cmd': 'set',    },    {        'args': msg_args,        'cmd': 'message',        'frame': 3 if expand else 2,        'global_frame': 3 if expand else 2    },    {        'args': ['STATUS', 'nested global_frame'],        'cmd': 'message',        'frame': 3,        'global_frame': 6 if expand else 5    }]with open(trace_file, 'r') as fp:    # Check for version (must be the first document)    vers = json.loads(fp.readline())    assert sorted(vers.keys()) == ['version']    assert sorted(vers['version'].keys()) == ['major', 'minor']    assert vers['version']['major'] == 1    assert vers['version']['minor'] == 2    for i in fp.readlines():        line = json.loads(i)        assert sorted(line.keys()) == ['args', 'cmd', 'file', 'frame', 'global_frame','line', 'time']        assert isinstance(line['args'], list)        assert isinstance(line['cmd'], unicode)        assert isinstance(line['file'], unicode)        assert isinstance(line['frame'], int)        assert isinstance(line['global_frame'], int)        assert isinstance(line['line'], int)        assert isinstance(line['time'], float)        for j in required_traces:            # Compare the subset of required keys with line            if {k: line[k] for k in j} == j:                required_traces.remove(j)assert not required_traces
 |