
This PS implements the following changes: - switches freeze approach to requirements-direct.txt and requirements-frozen.txt files - adjusts code tabulation style according to yapf recommendations - replaces deprecated usage of responce.body attribute with responce.text - fixes integration tests in controlled by Makefile + tox - uplifts Helm to v3.9.4 Change-Id: I751db72eb8f670825382f11a36657112faeb169a
148 lines
4.8 KiB
Python
148 lines
4.8 KiB
Python
# Copyright 2017 AT&T Intellectual Property. All other rights reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
"""Contains commands related to tasks against designs."""
|
|
import click
|
|
import json
|
|
import yaml
|
|
|
|
from drydock_provisioner.cli.task.actions import TaskList
|
|
from drydock_provisioner.cli.task.actions import TaskShow
|
|
from drydock_provisioner.cli.task.actions import TaskCreate
|
|
from drydock_provisioner.cli.task.actions import TaskBuildData
|
|
from drydock_provisioner.cli.task.actions import TasksDelete
|
|
|
|
|
|
@click.group()
|
|
def task():
|
|
"""Drydock task commands."""
|
|
|
|
|
|
@task.command(name='create')
|
|
@click.option('--design-ref',
|
|
'-d',
|
|
help='The design reference for this action')
|
|
@click.option('--action', '-a', help='The action to perform')
|
|
@click.option('--node-names',
|
|
'-n',
|
|
help='The nodes targeted by this action, comma separated')
|
|
@click.option('--rack-names',
|
|
'-r',
|
|
help='The racks targeted by this action, comma separated')
|
|
@click.option(
|
|
'--node-tags',
|
|
'-t',
|
|
help='The nodes by tag name targeted by this action, comma separated')
|
|
@click.option(
|
|
'--block/--no-block',
|
|
'-b',
|
|
help='The CLI will wait until the created completes before exitting',
|
|
default=False)
|
|
@click.option('--poll-interval',
|
|
help='Polling interval to check task status in blocking mode.',
|
|
default=15)
|
|
@click.pass_context
|
|
def task_create(ctx,
|
|
design_ref=None,
|
|
action=None,
|
|
node_names=None,
|
|
rack_names=None,
|
|
node_tags=None,
|
|
block=False,
|
|
poll_interval=15):
|
|
"""Create a task."""
|
|
if not design_ref:
|
|
ctx.fail(
|
|
'Error: Design reference must be specified using --design-ref')
|
|
|
|
if not action:
|
|
ctx.fail('Error: Action must be specified using --action')
|
|
|
|
click.echo(
|
|
json.dumps(
|
|
TaskCreate(
|
|
ctx.obj['CLIENT'],
|
|
design_ref=design_ref,
|
|
action_name=action,
|
|
node_names=[x.strip() for x in node_names.split(',')]
|
|
if node_names else [],
|
|
rack_names=[x.strip() for x in rack_names.split(',')]
|
|
if rack_names else [],
|
|
node_tags=[x.strip()
|
|
for x in node_tags.split(',')] if node_tags else [],
|
|
block=block,
|
|
poll_interval=poll_interval).invoke()))
|
|
|
|
|
|
@task.command(name='list')
|
|
@click.pass_context
|
|
def task_list(ctx):
|
|
"""List tasks."""
|
|
click.echo(json.dumps(TaskList(ctx.obj['CLIENT']).invoke()))
|
|
|
|
|
|
@task.command(name='show')
|
|
@click.option('--task-id', '-t', help='The required task id')
|
|
@click.option(
|
|
'--block/--no-block',
|
|
'-b',
|
|
help='The CLI will wait until the created completes before exitting',
|
|
default=False)
|
|
@click.pass_context
|
|
def task_show(ctx, task_id=None, block=False):
|
|
"""show a task's details."""
|
|
if not task_id:
|
|
ctx.fail('The task id must be specified by --task-id')
|
|
|
|
click.echo(
|
|
json.dumps(TaskShow(ctx.obj['CLIENT'], task_id=task_id).invoke()))
|
|
|
|
|
|
@task.command(name='builddata')
|
|
@click.option('--task-id', '-t', help='The required task id')
|
|
@click.option('--output',
|
|
'-o',
|
|
help='The output format (yaml|json)',
|
|
default='yaml')
|
|
@click.pass_context
|
|
def task_builddata(ctx, task_id=None, output='yaml'):
|
|
"""Show builddata assoicated with ``task_id``."""
|
|
if not task_id:
|
|
ctx.fail('The task id must be specified by --task-id')
|
|
|
|
task_bd = TaskBuildData(ctx.obj['CLIENT'], task_id=task_id).invoke()
|
|
|
|
if output == 'json':
|
|
click.echo(json.dumps(task_bd))
|
|
else:
|
|
if output != 'yaml':
|
|
click.echo(
|
|
'Invalid output format {}, defaulting to YAML.'.format(output))
|
|
click.echo(
|
|
yaml.safe_dump(task_bd,
|
|
allow_unicode=True,
|
|
default_flow_style=False))
|
|
|
|
|
|
@task.command(name='delete')
|
|
@click.option('--days',
|
|
'-d',
|
|
help='The required number of days to retain tasks')
|
|
@click.pass_context
|
|
def task_delete(ctx, days=None):
|
|
"""Delete tasks from database"""
|
|
if not days:
|
|
ctx.fail('The number of days must be specified using --days or -d')
|
|
|
|
click.echo(TasksDelete(ctx.obj['CLIENT'], days=days).invoke())
|