xref: /llvm-project/lldb/test/Shell/ScriptInterpreter/Python/Crashlog/parser_json.test (revision 13aa780f37e193d8c23a6c5ff98cc4c7febc1f95)
1c7cbf32fSJonas Devlieghere#                                                                 -*- python -*-
2c7cbf32fSJonas Devlieghere# RUN: cd %S/../../../../../examples/python && cat %s | %lldb 2>&1 > %t.out
3c7cbf32fSJonas Devlieghere# RUN: cat %t.out | FileCheck %S/Inputs/Assertion.check
4c7cbf32fSJonas Devliegherescript
5c7cbf32fSJonas Devlieghereimport crashlog
6c7cbf32fSJonas Devlieghereimport json
7c7cbf32fSJonas Devlieghere
8c7cbf32fSJonas Devlieghereparser = crashlog.JSONCrashLogParser("", "", False)
9c7cbf32fSJonas Devlieghere
10*13aa780fSMed Ismail Bennaniprocess_info_json = json.loads('{"pid" : 287, "procName" : "mediaserverd"}')
11c7cbf32fSJonas Devlieghereparser.parse_process_info(process_info_json)
12c7cbf32fSJonas Devlieghere
13c7cbf32fSJonas Devlieghereassert parser.crashlog.process_id == 287
14c7cbf32fSJonas Devlieghereassert parser.crashlog.process_identifier == "mediaserverd"
15c7cbf32fSJonas Devlieghere
16c7cbf32fSJonas Devliegherecrash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "subtype" : "KERN_INVALID_ADDRESS"}')
17c7cbf32fSJonas Devlieghereassert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (KERN_INVALID_ADDRESS)"
18c7cbf32fSJonas Devlieghere
19c7cbf32fSJonas Devliegherecrash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV"}')
20c7cbf32fSJonas Devlieghereassert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV)"
21c7cbf32fSJonas Devlieghere
22c7cbf32fSJonas Devliegherecrash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "codes" : "0x0000000000000000, 0x0000000000000000"}')
23c7cbf32fSJonas Devlieghereassert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (0x0000000000000000, 0x0000000000000000)"
24c7cbf32fSJonas Devlieghere
25c7cbf32fSJonas Devliegherethread_state_json = json.loads('{"x":[268451845,117442566],"lr":7309751904,"cpsr":1073741824,"fp":6093236784,"sp":6093236704,"esr":1442840704,"pc":7309755088}')
26c7cbf32fSJonas Devlieghereregisters = parser.parse_thread_registers(thread_state_json)
27c7cbf32fSJonas Devlieghereassert registers['x0'] == 268451845
28c7cbf32fSJonas Devlieghereassert registers['x1'] == 117442566
29c7cbf32fSJonas Devlieghereassert registers['lr'] == 7309751904
30c7cbf32fSJonas Devlieghereassert registers['cpsr'] ==1073741824
31c7cbf32fSJonas Devlieghereassert registers['fp'] == 6093236784
32c7cbf32fSJonas Devlieghereassert registers['sp'] == 6093236704
33c7cbf32fSJonas Devlieghereassert registers['esr'] == 1442840704
34c7cbf32fSJonas Devlieghereassert registers['pc'] == 7309755088
35c7cbf32fSJonas Devlieghere
36c7cbf32fSJonas Devlieghereparser.data = json.loads('{"usedImages":[["f4d85377-f215-3da3-921e-3fe870e622e9",7309737984,"P"]],"legacyInfo":{"imageExtraInfo":[{"size":204800,"arch":"arm64e","path":"/usr/lib/system/libsystem_kernel.dylib","name":"libsystem_kernel.dylib"}]}}')
37c7cbf32fSJonas Devliegherethread_json = json.loads('[{"triggered":true,"id":3835,"queue":"com.apple.bwgraph.devicevendor","frames":[[0,101472],[0,408892]]}]')
38c7cbf32fSJonas Devlieghereparser.parse_threads(thread_json)
39c7cbf32fSJonas Devlieghereassert len(parser.crashlog.threads) == 1
40c7cbf32fSJonas Devlieghereassert parser.crashlog.threads[0].queue == "com.apple.bwgraph.devicevendor"
41c7cbf32fSJonas Devlieghereassert len(parser.crashlog.threads[0].frames) == 2
42c7cbf32fSJonas Devlieghereassert parser.crashlog.threads[0].frames[0].pc == 7309839456
43c7cbf32fSJonas Devlieghereassert parser.crashlog.threads[0].frames[0].description == 101472
44c7cbf32fSJonas Devlieghereexit()
45