Merge "zun: add hostname, hints and security_groups"

This commit is contained in:
Zuul 2018-02-07 04:01:56 +00:00 committed by Gerrit Code Review
commit d947f2fbb9
3 changed files with 50 additions and 3 deletions

View File

@ -33,11 +33,13 @@ class Container(resource.Resource):
PROPERTIES = ( PROPERTIES = (
NAME, IMAGE, COMMAND, CPU, MEMORY, NAME, IMAGE, COMMAND, CPU, MEMORY,
ENVIRONMENT, WORKDIR, LABELS, IMAGE_PULL_POLICY, ENVIRONMENT, WORKDIR, LABELS, IMAGE_PULL_POLICY,
RESTART_POLICY, INTERACTIVE, IMAGE_DRIVER RESTART_POLICY, INTERACTIVE, IMAGE_DRIVER, HINTS,
HOSTNAME, SECURITY_GROUPS,
) = ( ) = (
'name', 'image', 'command', 'cpu', 'memory', 'name', 'image', 'command', 'cpu', 'memory',
'environment', 'workdir', 'labels', 'image_pull_policy', 'environment', 'workdir', 'labels', 'image_pull_policy',
'restart_policy', 'interactive', 'image_driver' 'restart_policy', 'interactive', 'image_driver', 'hints',
'hostname', 'security_groups',
) )
ATTRIBUTES = ( ATTRIBUTES = (
@ -110,6 +112,22 @@ class Container(resource.Resource):
constraints.AllowedValues(['docker', 'glance']), constraints.AllowedValues(['docker', 'glance']),
] ]
), ),
HINTS: properties.Schema(
properties.Schema.MAP,
_('Arbitrary key-value pairs for scheduler to select host.'),
support_status=support.SupportStatus(version='10.0.0'),
),
HOSTNAME: properties.Schema(
properties.Schema.STRING,
_('The hostname of the container.'),
support_status=support.SupportStatus(version='10.0.0'),
),
SECURITY_GROUPS: properties.Schema(
properties.Schema.LIST,
_('List of security group names or IDs.'),
support_status=support.SupportStatus(version='10.0.0'),
default=[]
),
} }
attributes_schema = { attributes_schema = {

View File

@ -47,6 +47,11 @@ resources:
restart_policy: on-failure:2 restart_policy: on-failure:2
interactive: false interactive: false
image_driver: docker image_driver: docker
hints:
hintkey: hintval
hostname: myhost
security_groups:
- my_seg
''' '''
@ -69,6 +74,10 @@ class ZunContainerTest(common.HeatTestCase):
'Name': 'on-failure'} 'Name': 'on-failure'}
self.fake_interactive = False self.fake_interactive = False
self.fake_image_driver = 'docker' self.fake_image_driver = 'docker'
self.fake_hints = {'hintkey': 'hintval'}
self.fake_hostname = 'myhost'
self.fake_security_groups = ['my_seg']
self.fake_network_id = '9c11d847-99ce-4a83-82da-9827362a68e8' self.fake_network_id = '9c11d847-99ce-4a83-82da-9827362a68e8'
self.fake_network_name = 'private' self.fake_network_name = 'private'
self.fake_networks = { self.fake_networks = {
@ -117,6 +126,9 @@ class ZunContainerTest(common.HeatTestCase):
value.restart_policy = self.fake_restart_policy value.restart_policy = self.fake_restart_policy
value.interactive = self.fake_interactive value.interactive = self.fake_interactive
value.image_driver = self.fake_image_driver value.image_driver = self.fake_image_driver
value.hints = self.fake_hints
value.hostname = self.fake_hostname
value.security_groups = self.fake_security_groups
value.addresses = self.fake_addresses value.addresses = self.fake_addresses
value.to_dict.return_value = value.__dict__ value.to_dict.return_value = value.__dict__
@ -170,6 +182,15 @@ class ZunContainerTest(common.HeatTestCase):
self.assertEqual( self.assertEqual(
self.fake_image_driver, self.fake_image_driver,
c.properties.get(container.Container.IMAGE_DRIVER)) c.properties.get(container.Container.IMAGE_DRIVER))
self.assertEqual(
self.fake_hints,
c.properties.get(container.Container.HINTS))
self.assertEqual(
self.fake_hostname,
c.properties.get(container.Container.HOSTNAME))
self.assertEqual(
self.fake_security_groups,
c.properties.get(container.Container.SECURITY_GROUPS))
scheduler.TaskRunner(c.create)() scheduler.TaskRunner(c.create)()
self.assertEqual(self.resource_id, c.resource_id) self.assertEqual(self.resource_id, c.resource_id)
@ -187,7 +208,10 @@ class ZunContainerTest(common.HeatTestCase):
image_pull_policy=self.fake_image_policy, image_pull_policy=self.fake_image_policy,
restart_policy=self.fake_restart_policy, restart_policy=self.fake_restart_policy,
interactive=self.fake_interactive, interactive=self.fake_interactive,
image_driver=self.fake_image_driver image_driver=self.fake_image_driver,
hints=self.fake_hints,
hostname=self.fake_hostname,
security_groups=self.fake_security_groups,
) )
def test_container_create_failed(self): def test_container_create_failed(self):

View File

@ -0,0 +1,5 @@
---
features:
- |
Add properties hostname, hints, security_groups to Zun's container
resource.