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", "procPath" : "\/usr\/sbin\/mediaserverd"}') 11parser.parse_process_info(process_info_json) 12 13assert parser.crashlog.process_id == 287 14assert parser.crashlog.process_identifier == "mediaserverd" 15assert parser.crashlog.process_path == "/usr/sbin/mediaserverd" 16 17crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "subtype" : "KERN_INVALID_ADDRESS"}') 18assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (KERN_INVALID_ADDRESS)" 19 20crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV"}') 21assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV)" 22 23crash_reason_json = json.loads('{"type" : "EXC_BAD_ACCESS", "signal" : "SIGSEGV", "codes" : "0x0000000000000000, 0x0000000000000000"}') 24assert parser.parse_crash_reason(crash_reason_json) == "EXC_BAD_ACCESS (SIGSEGV) (0x0000000000000000, 0x0000000000000000)" 25 26thread_state_json = json.loads('{"x":[268451845,117442566],"lr":7309751904,"cpsr":1073741824,"fp":6093236784,"sp":6093236704,"esr":1442840704,"pc":7309755088}') 27registers = parser.parse_thread_registers(thread_state_json) 28assert registers['x0'] == 268451845 29assert registers['x1'] == 117442566 30assert registers['lr'] == 7309751904 31assert registers['cpsr'] ==1073741824 32assert registers['fp'] == 6093236784 33assert registers['sp'] == 6093236704 34assert registers['esr'] == 1442840704 35assert registers['pc'] == 7309755088 36 37parser.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"}]}}') 38thread_json = json.loads('[{"triggered":true,"id":3835,"queue":"com.apple.bwgraph.devicevendor","frames":[[0,101472],[0,408892]]}]') 39parser.parse_threads(thread_json) 40assert len(parser.crashlog.threads) == 1 41assert parser.crashlog.threads[0].queue == "com.apple.bwgraph.devicevendor" 42assert len(parser.crashlog.threads[0].frames) == 2 43assert parser.crashlog.threads[0].frames[0].pc == 7309839456 44assert parser.crashlog.threads[0].frames[0].description == 101472 45exit() 46