blob: f71922e7545ac01cef87c388e15c80fb94a77542 [file] [log] [blame] [edit]
# Copyright (c) 2012 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.
"""
The job module contains the objects and methods used to
manage jobs in Autotest.
The valid actions are:
list: lists job(s)
create: create a job
abort: abort job(s)
stat: detailed listing of job(s)
The common options are:
See topic_common.py for a High Level Design and Algorithm.
"""
import warnings
from cli import topic_common, action_common
class suite(topic_common.atest):
"""Suite class
atest suite [create] [options]"""
usage_action = '[create]'
topic = msg_topic = 'suite'
msg_items = ''
class suite_help(suite):
"""Just here to get the atest logic working.
Usage is set by its parent"""
pass
class suite_create(action_common.atest_create, suite):
"""Class containing the code for creating a suite."""
msg_items = 'suite_id'
def __init__(self):
super(suite_create, self).__init__()
self.parser.add_option('-b', '--board', help='Board to test. Required.',
metavar='BOARD')
self.parser.add_option('-i', '--build',
help='OS image to install before running the '
'test, e.g. '
'x86-alex-release/R17-1412.144.0-a1-b115.'
' Required.',
metavar='BUILD')
self.parser.add_option('-c', '--check_hosts',
default=False,
help='Check that enough live hosts exist to '\
'run this suite. Default False.',
action='store_true',
metavar='CHECK_HOSTS')
self.parser.add_option('-f', '--file_bugs', default=False,
help='File bugs on test failures.',
action='store_true', metavar='FILE_BUGS')
self.parser.add_option('-n', '--num', type=int,
help='Number of machines to schedule across.',
metavar='NUM')
self.parser.add_option('-p', '--pool', help='Pool of machines to use.',
metavar='POOL')
self.parser.add_option('-w', '--wait_for_results',
default=True,
help=('Set to False for suite job to exit '
'without waiting for test jobs to finish. '
'Default is True.'),
metavar='WAIT_FOR_RESULTS')
self.parser.add_option('-d', '--delay_minutes', type=int, default=0,
help=('Delay the creation of test jobs for a '
'given number of minutes. This argument '
'can be used to force provision jobs '
'being delayed, which helps to distribute '
'loads across devservers.'),
metavar='DELAY_MINUTES')
def parse(self):
board_info = topic_common.item_parse_info(attribute_name='board',
inline_option='board')
build_info = topic_common.item_parse_info(attribute_name='build',
inline_option='build')
pool_info = topic_common.item_parse_info(attribute_name='pool',
inline_option='pool')
num_info = topic_common.item_parse_info(attribute_name='num',
inline_option='num')
check_info = topic_common.item_parse_info(attribute_name='check_hosts',
inline_option='check_hosts')
bugs_info = topic_common.item_parse_info(attribute_name='file_bugs',
inline_option='file_bugs')
suite_info = topic_common.item_parse_info(attribute_name='name',
use_leftover=True)
wait_for_results_info = topic_common.item_parse_info(
attribute_name='wait_for_results',
inline_option='wait_for_results')
delay_minutes_info = topic_common.item_parse_info(
attribute_name='delay_minutes',
inline_option='delay_minutes')
options, leftover = suite.parse(
self,
[suite_info, board_info, build_info, pool_info, num_info,
check_info, bugs_info, wait_for_results_info, delay_minutes_info],
req_items='name')
self.data = {}
name = getattr(self, 'name')
if len(name) > 1:
self.invalid_syntax('Too many arguments specified, only expected '
'to receive suite name: %s' % name)
self.data['suite_name'] = name[0]
self.data['pool'] = options.pool # None is OK.
if options.num is not None:
warnings.warn('num is deprecated')
del options.num
self.data['check_hosts'] = options.check_hosts
self.data['file_bugs'] = options.file_bugs
self.data['wait_for_results'] = options.wait_for_results
self.data['delay_minutes'] = options.delay_minutes
if options.board:
self.data['board'] = options.board
else:
self.invalid_syntax('--board is required.')
if options.build:
self.data['build'] = options.build
else:
self.invalid_syntax('--build is required.')
return options, leftover
def execute(self):
return [self.execute_rpc(op='create_suite_job', **self.data)]