Add OSC Plugin for openstack appcontainer run

This change implements the "openstack appcontainer run" command
 Based on existing zun command: zun run

Partially Implements:blueprint zun-osc-plugin
Co-Authored-By: Sheel Rana <ranasheel2000@gmail.com>

Depends-On: I2120e2ae9bda2eea84f1459f768405bd7c677849

Change-Id: I45afcb2b554f87fc019ec171a83bd7dfae14e5ba
This commit is contained in:
Namrata Sitlani 2017-01-09 20:23:16 +00:00 committed by Hongbin Lu
parent edb07a1be9
commit cf17711041
2 changed files with 75 additions and 0 deletions

View File

@ -44,6 +44,7 @@ openstack.container.v1 =
appcontainer_logs = zunclient.osc.v1.containers:LogsContainer appcontainer_logs = zunclient.osc.v1.containers:LogsContainer
appcontainer_kill = zunclient.osc.v1.containers:KillContainer appcontainer_kill = zunclient.osc.v1.containers:KillContainer
appcontainer_stop = zunclient.osc.v1.containers:StopContainer appcontainer_stop = zunclient.osc.v1.containers:StopContainer
appcontainer_run = zunclient.osc.v1.containers:RunContainer
[build_sphinx] [build_sphinx]
source-dir = doc/source source-dir = doc/source

View File

@ -403,3 +403,77 @@ class StopContainer(command.Command):
except Exception as e: except Exception as e:
print("Stop for container %(container)s failed: %(e)s" % print("Stop for container %(container)s failed: %(e)s" %
{'container': container, 'e': e}) {'container': container, 'e': e})
class RunContainer(command.ShowOne):
"""Creates and run a new container"""
log = logging.getLogger(__name__ + ".RunContainer")
def get_parser(self, prog_name):
parser = super(RunContainer, self).get_parser(prog_name)
parser.add_argument(
'--name',
metavar='<name>',
help='name of the container')
parser.add_argument(
'image',
metavar='<image>',
help='name or ID of the image')
parser.add_argument(
'--command',
metavar='<command>',
help='Send command to the container')
parser.add_argument(
'--cpu',
metavar='<cpu>',
help='The number of virtual cpus.')
parser.add_argument(
'--memory',
metavar='<memory>',
help='The container memory size in MiB')
parser.add_argument(
'--environment',
metavar='<KEY=VALUE>',
action='append', default=[],
help='The environment variables')
parser.add_argument(
'--workdir',
metavar='<workdir>',
help='The working directory for commands to run in')
parser.add_argument(
'--label',
metavar='<KEY=VALUE>',
action='append', default=[],
help='Adds a map of labels to a container. '
'May be used multiple times.')
parser.add_argument(
'--image-pull-policy',
dest='image_pull_policy',
metavar='<policy>',
choices=['never', 'always', 'ifnotpresent'],
help='The policy which determines if the image should '
'be pulled prior to starting the container. '
'It can have following values: '
'"ifnotpresent": only pull the image if it does not '
'already exist on the node. '
'"always": Always pull the image from repositery.'
'"never": never pull the image')
return parser
def take_action(self, parsed_args):
client = _get_client(self, parsed_args)
opts = {}
opts['name'] = parsed_args.name
opts['image'] = parsed_args.image
opts['command'] = parsed_args.command
opts['memory'] = parsed_args.memory
opts['cpu'] = parsed_args.cpu
opts['environment'] = zun_utils.format_args(parsed_args.environment)
opts['workdir'] = parsed_args.workdir
opts['labels'] = zun_utils.format_args(parsed_args.label)
opts['image_pull_policy'] = parsed_args.image_pull_policy
container = client.containers.run(**opts)
columns = _container_columns(container)
return columns, utils.get_item_properties(container, columns)