xref: /llvm-project/lldb/test/Shell/ScriptInterpreter/Python/Crashlog/parser_json.test (revision 13aa780f37e193d8c23a6c5ff98cc4c7febc1f95)
1#                                                                 -*- python -*-
2# RUN: cd %S/../../../../../examples/python && cat %s | %lldb 2>&1 > %t.out
3# RUN: cat %t.out | FileCheck %S/Inputs/Assertion.check
4script
5import crashlog
6import json
7
8parser = crashlog.JSONCrashLogParser("", "", False)
9
10process_info_json = json.loads('{"pid" : 287, "procName" : "mediaserverd"}')
11parser.parse_process_info(process_info_json)
12
13assert parser.crashlog.process_id == 287
14assert parser.crashlog.process_identifier == "mediaserverd"
15
16crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "subtype" : "KERN_INVALID_ADDRESS"}')
17assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (KERN_INVALID_ADDRESS)"
18
19crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV"}')
20assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV)"
21
22crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "codes" : "0x0000000000000000, 0x0000000000000000"}')
23assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (0x0000000000000000, 0x0000000000000000)"
24
25thread_state_json = json.loads('{"x":[268451845,117442566],"lr":7309751904,"cpsr":1073741824,"fp":6093236784,"sp":6093236704,"esr":1442840704,"pc":7309755088}')
26registers = parser.parse_thread_registers(thread_state_json)
27assert registers['x0'] == 268451845
28assert registers['x1'] == 117442566
29assert registers['lr'] == 7309751904
30assert registers['cpsr'] ==1073741824
31assert registers['fp'] == 6093236784
32assert registers['sp'] == 6093236704
33assert registers['esr'] == 1442840704
34assert registers['pc'] == 7309755088
35
36parser.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"}]}}')
37thread_json = json.loads('[{"triggered":true,"id":3835,"queue":"com.apple.bwgraph.devicevendor","frames":[[0,101472],[0,408892]]}]')
38parser.parse_threads(thread_json)
39assert len(parser.crashlog.threads) == 1
40assert parser.crashlog.threads[0].queue == "com.apple.bwgraph.devicevendor"
41assert len(parser.crashlog.threads[0].frames) == 2
42assert parser.crashlog.threads[0].frames[0].pc == 7309839456
43assert parser.crashlog.threads[0].frames[0].description == 101472
44exit()
45