#!/usr/bin/env python2 # Copyright 2016 The Chromium OS Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. """Generate a report on a given suite run.""" from __future__ import print_function import common import argparse import logging import sys from autotest_lib.server.cros.dynamic_suite import frontend_wrappers from autotest_lib.server.lib import suite_report from chromite.lib import ts_mon_config def GetParser(): """Creates the argparse parser.""" parser = argparse.ArgumentParser(description=__doc__) parser.add_argument('job_ids', type=int, nargs='+', help='Suite job ids to dump') # As a provision suite may exit before its all provision jobs finish, the # provision suite report may not contain all the provision jobs. This hack # helps to dump report for all provision jobs under the given provision # suite (provision-job-id). See more details in crbug.com/794346 parser.add_argument('--provision-job-id', type=int, help='Provision suite job id to dump report.') parser.add_argument('--output', '-o', type=str, action='store', help='Path to write JSON file to') parser.add_argument('--afe', type=str, action='store', help='AFE server to connect to') return parser def main(argv): """Standard main() for command line processing. @param argv Command line arguments (normally sys.argv). """ parser = GetParser() options = parser.parse_args(argv[1:]) with ts_mon_config.SetupTsMonGlobalState('dump_suite_report'): afe = frontend_wrappers.RetryingAFE(timeout_min=5, delay_sec=10, server=options.afe) tko = frontend_wrappers.RetryingTKO(timeout_min=5, delay_sec=10) job_ids = set(options.job_ids) if options.provision_job_id: job_ids.add(options.provision_job_id) # Look up and generate entries for all jobs. entries = [] for suite_job_id in job_ids: reset_finish_time = (suite_job_id == options.provision_job_id) logging.debug('Suite job %s:' % suite_job_id) suite_entries = suite_report.generate_suite_report( suite_job_id, afe=afe, tko=tko, reset_finish_time=reset_finish_time) logging.debug('... generated %d entries' % len(suite_entries)) entries.extend(suite_entries) # Write all entries as JSON. if options.output: with open(options.output, 'w') as f: suite_report.dump_entries_as_json(entries, f) else: suite_report.dump_entries_as_json(entries, sys.stdout) if __name__ == '__main__': main(sys.argv)