def upload_testcase_output(crash_result, testcase_path): """Upload the output into corresponding GCS logs bucket.""" fuzz_logs_bucket = environment.get_value('FUZZ_LOGS_BUCKET') if not fuzz_logs_bucket: return # Add revision information to the logs. app_revision = environment.get_value('APP_REVISION') job_name = environment.get_value('JOB_NAME') components = revisions.get_component_list(app_revision, job_name) component_revisions = (revisions.format_revision_list(components, use_html=False) or 'Not available.\n') revisions_header = ( 'Component revisions (build r{app_revision}):\n{component_revisions}\n' .format(app_revision=app_revision, component_revisions=component_revisions)) return_code_header = 'Return code: %s\n\n' % crash_result.return_code symbolized_output = crash_result.get_stacktrace() # To provide consistency between stats and logs, we use timestamp taken # when the log has been parsed. log_time = _get_testcase_time(testcase_path) fuzzer_logs.upload_to_logs(fuzz_logs_bucket, revisions_header + return_code_header + symbolized_output, time=log_time)
def prepare_log_for_upload(symbolized_output, return_code): """Prepare log for upload.""" # Add revision information to the logs. app_revision = environment.get_value("APP_REVISION") job_name = environment.get_value("JOB_NAME") components = revisions.get_component_list(app_revision, job_name) component_revisions = (revisions.format_revision_list(components, use_html=False) or "Not available.\n") revisions_header = "Component revisions (build r{app_revision}):\n{component_revisions}\n".format( app_revision=app_revision, component_revisions=component_revisions) return_code_header = "Return code: %s\n\n" % return_code return revisions_header + return_code_header + symbolized_output
def prepare_log_for_upload(symbolized_output, return_code): """Prepare log for upload.""" # Add revision information to the logs. app_revision = environment.get_value('APP_REVISION') job_name = environment.get_value('JOB_NAME') components = revisions.get_component_list(app_revision, job_name) component_revisions = (revisions.format_revision_list(components, use_html=False) or 'Not available.\n') revisions_header = ( 'Component revisions (build r{app_revision}):\n{component_revisions}\n' .format(app_revision=app_revision, component_revisions=component_revisions)) return_code_header = 'Return code: %s\n\n' % return_code result = revisions_header + return_code_header + symbolized_output return result.encode('utf-8')
def prepare_log_for_upload(symbolized_output, return_code): """Prepare log for upload.""" # Add revision information to the logs. app_revision = environment.get_value('APP_REVISION') job_name = environment.get_value('JOB_NAME') components = revisions.get_component_list(app_revision, job_name) component_revisions = (revisions.format_revision_list(components, use_html=False) or 'Not available.\n') revisions_header =\ f'Component revisions (build r{app_revision}):\n{component_revisions}\n' bot_name = environment.get_value('BOT_NAME') bot_header = f'Bot name: {bot_name}\n' if environment.is_android(): bot_header += f'Device serial: {environment.get_value("ANDROID_SERIAL")}\n' return_code_header = "Return code: %s\n\n" % return_code result = revisions_header + bot_header + return_code_header +\ symbolized_output return result.encode('utf-8')