From 6faf14667202e23bc38738fb12929a038186cf01 Mon Sep 17 00:00:00 2001 From: obastemur Date: Tue, 13 Feb 2018 03:08:58 -0800 Subject: [PATCH] deps: update ChakraCore to Microsoft/ChakraCore@db6afe6a8f [1.8>1.9] [MERGE #4671 @obastemur] lldb-out: improve testing with lldb debugger attached Merge pull request #4671 from obastemur:easier_flaky_detect Trying to get the stack trace for a flaky test. Having the output corrupted for each test run is making things a lot complicated Reviewed-By: chakrabot --- deps/chakrashim/core/test/runtests.py | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/deps/chakrashim/core/test/runtests.py b/deps/chakrashim/core/test/runtests.py index f10d94bf9f8..145d02b4299 100644 --- a/deps/chakrashim/core/test/runtests.py +++ b/deps/chakrashim/core/test/runtests.py @@ -71,7 +71,7 @@ parser.add_argument('--swb', action='store_true', help='use binary from VcBuild.SWB to run the test') parser.add_argument('--lldb', default=None, - help='run a single test in lldb batch mode to get call stack and crash logs', action='store_true') + help='run test suit with lldb batch mode to get call stack for crashing processes (ignores baseline matching)', action='store_true') parser.add_argument('-l', '--logfile', metavar='logfile', help='file to log results to', default=None) parser.add_argument('--x86', action='store_true', @@ -469,17 +469,28 @@ def timeout_func(timeout_data): timeout_data[1] = True timeout = test.get('timeout', args.timeout) # test override or default timer = Timer(timeout, timeout_func, [timeout_data]) + skip_baseline_match = False try: timer.start() js_output = normalize_new_line(proc.communicate()[0]) exit_code = proc.wait() + # if -lldb was set; check if test was crashed before corrupting the output + search_for = " exited with status = 0 (0x00000000)" + if args.lldb != None and exit_code == 0 and js_output.index(search_for) > 0: + js_output = js_output[0:js_output.index(search_for)] + exit_pos = js_output.rfind('\nProcess ') + if exit_pos > len(js_output) - 20: # if [Process ????? ] + if 'baseline' not in test: + js_output = "pass" + else: + skip_baseline_match = True finally: timer.cancel() test.done() # shared _show_failed args fail_args = { 'test': test, 'flags': flags, - 'exit_code': exit_code, 'output': js_output }; + 'exit_code': exit_code, 'output': js_output } # check timed out if (timeout_data[1]): @@ -498,7 +509,7 @@ def timeout_func(timeout_data): return self._show_failed(**fail_args) else: baseline = test.get('baseline') - if baseline: + if not skip_baseline_match and baseline: # perform baseline comparison baseline = self._check_file(folder, baseline) with open(baseline, 'rb') as bs_file: