Esempio n. 1
0
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)
Esempio n. 2
0
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
Esempio n. 3
0
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')
Esempio n. 4
0
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')