2013-10-09 20:13:01 +00:00
|
|
|
import yaml
|
|
|
|
|
2014-04-15 00:28:54 +00:00
|
|
|
import teuthology.beanstalk
|
2013-10-11 17:09:40 +00:00
|
|
|
from teuthology.misc import get_user
|
|
|
|
from teuthology.misc import read_config
|
2014-04-15 00:46:07 +00:00
|
|
|
from teuthology import report
|
2013-10-09 20:13:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
def main(ctx):
|
|
|
|
if ctx.owner is None:
|
|
|
|
ctx.owner = 'scheduled_{user}'.format(user=get_user())
|
|
|
|
read_config(ctx)
|
|
|
|
|
2014-04-15 00:28:54 +00:00
|
|
|
beanstalk = teuthology.beanstalk.connect()
|
2013-10-09 20:13:01 +00:00
|
|
|
|
|
|
|
tube = ctx.worker
|
|
|
|
beanstalk.use(tube)
|
|
|
|
|
|
|
|
# strip out targets; the worker will allocate new ones when we run
|
|
|
|
# the job with --lock.
|
|
|
|
if ctx.config.get('targets'):
|
|
|
|
del ctx.config['targets']
|
|
|
|
|
|
|
|
job_config = dict(
|
|
|
|
name=ctx.name,
|
|
|
|
last_in_suite=ctx.last_in_suite,
|
|
|
|
email=ctx.email,
|
|
|
|
description=ctx.description,
|
|
|
|
owner=ctx.owner,
|
|
|
|
verbose=ctx.verbose,
|
2013-10-11 22:41:22 +00:00
|
|
|
machine_type=ctx.worker,
|
2013-10-09 20:13:01 +00:00
|
|
|
)
|
|
|
|
# Merge job_config and ctx.config
|
|
|
|
job_config.update(ctx.config)
|
|
|
|
if ctx.timeout is not None:
|
|
|
|
job_config['results_timeout'] = ctx.timeout
|
|
|
|
|
|
|
|
job = yaml.safe_dump(job_config)
|
|
|
|
num = ctx.num
|
|
|
|
while num > 0:
|
|
|
|
jid = beanstalk.put(
|
|
|
|
job,
|
|
|
|
ttr=60 * 60 * 24,
|
|
|
|
priority=ctx.priority,
|
|
|
|
)
|
|
|
|
print 'Job scheduled with name {name} and ID {jid}'.format(
|
|
|
|
name=ctx.name, jid=jid)
|
2014-04-15 00:46:07 +00:00
|
|
|
job_config['job_id'] = str(jid)
|
2014-04-25 20:22:30 +00:00
|
|
|
report.try_push_job_info(job_config, dict(status='queued'))
|
2013-10-09 20:13:01 +00:00
|
|
|
num -= 1
|