Enable setting label and instance name separately

At the moment nodepools aws driver uses the label to set the instance
name in aws and fails to launch the instance if "Name" is supplied
as a tag.
This makes it possible to supply name as a tag.

Change-Id: I9585db8fe4b4ad6f5b588fb67a7201296c2fc954
This commit is contained in:
Albin Vass 2020-03-12 13:09:03 +01:00 committed by vass
parent d8f1118153
commit 2ce664ec14
4 changed files with 37 additions and 12 deletions

View File

@ -1789,6 +1789,8 @@ section of the configuration.
:required: :required:
Identifier to refer this label. Identifier to refer this label.
Nodepool will use this to set the name of the instance unless
the name is specified as a tag.
.. attr:: cloud-image .. attr:: cloud-image
:type: str :type: str

View File

@ -162,6 +162,11 @@ class AwsProvider(Provider):
def createInstance(self, label): def createInstance(self, label):
image_id = self.getImageId(label.cloud_image) image_id = self.getImageId(label.cloud_image)
tags = label.tags
if not [tag for tag in label.tags if tag["Key"] == "Name"]:
tags.append(
{"Key": "Name", "Value": str(label.name)}
)
args = dict( args = dict(
ImageId=image_id, ImageId=image_id,
MinCount=1, MinCount=1,
@ -174,8 +179,7 @@ class AwsProvider(Provider):
'DeviceIndex': 0}], 'DeviceIndex': 0}],
TagSpecifications=[{ TagSpecifications=[{
'ResourceType': 'instance', 'ResourceType': 'instance',
'Tags': [{"Key": "Name", 'Tags': tags
"Value": str(label.name)}] + label.tags
}] }]
) )

View File

@ -14,6 +14,7 @@ labels:
- name: ubuntu1404-private-ip - name: ubuntu1404-private-ip
- name: ubuntu1404-userdata - name: ubuntu1404-userdata
- name: ubuntu1404-with-tags - name: ubuntu1404-with-tags
- name: ubuntu1404-with-name-tag
providers: providers:
- name: ec2-us-west-2 - name: ec2-us-west-2
@ -117,3 +118,14 @@ providers:
key-name: zuul key-name: zuul
tags: tags:
has-tags: true has-tags: true
- name: name-tag
max-servers: 1
subnet-id: null
security-group-id: null
labels:
- name: ubuntu1404-with-name-tag
cloud-image: ubuntu1404
instance-type: t3.medium
key-name: zuul
tags:
Name: different-name

View File

@ -49,7 +49,7 @@ class TestDriverAws(tests.DBTestCase):
host_key_checking=True, host_key_checking=True,
userdata=None, userdata=None,
public_ip=True, public_ip=True,
tags=False): tags=[]):
aws_id = 'AK000000000000000000' aws_id = 'AK000000000000000000'
aws_key = '0123456789abcdef0123456789abcdef0123456789abcdef' aws_key = '0123456789abcdef0123456789abcdef0123456789abcdef'
self.useFixture( self.useFixture(
@ -90,6 +90,8 @@ class TestDriverAws(tests.DBTestCase):
raw_config['providers'][0]['pools'][3]['security-group-id'] = sg_id raw_config['providers'][0]['pools'][3]['security-group-id'] = sg_id
raw_config['providers'][0]['pools'][4]['subnet-id'] = subnet_id raw_config['providers'][0]['pools'][4]['subnet-id'] = subnet_id
raw_config['providers'][0]['pools'][4]['security-group-id'] = sg_id raw_config['providers'][0]['pools'][4]['security-group-id'] = sg_id
raw_config['providers'][0]['pools'][5]['subnet-id'] = subnet_id
raw_config['providers'][0]['pools'][5]['security-group-id'] = sg_id
with tempfile.NamedTemporaryFile() as tf: with tempfile.NamedTemporaryFile() as tf:
tf.write(yaml.safe_dump( tf.write(yaml.safe_dump(
@ -160,13 +162,8 @@ class TestDriverAws(tests.DBTestCase):
if tags: if tags:
instance = ec2_resource.Instance(node.external_id) instance = ec2_resource.Instance(node.external_id)
tag_list = instance.tags tag_list = instance.tags
for tag in tags:
self.assertIn({"Key": "has-tags", "Value": "true"}, self.assertIn(tag, tag_list)
tag_list)
self.assertIn({
"Key": "Name",
"Value": "ubuntu1404-with-tags"
}, tag_list)
# A new request will be paused and for lack of quota # A new request will be paused and for lack of quota
# until this one is deleted # until this one is deleted
@ -228,4 +225,14 @@ class TestDriverAws(tests.DBTestCase):
def test_ec2_machine_tags(self): def test_ec2_machine_tags(self):
self._test_ec2_machine('ubuntu1404-with-tags', self._test_ec2_machine('ubuntu1404-with-tags',
tags=True) tags=[
{"Key": "has-tags", "Value": "true"},
{"Key": "Name",
"Value": "ubuntu1404-with-tags"}
])
def test_ec2_machine_name_tag(self):
self._test_ec2_machine('ubuntu1404-with-name-tag',
tags=[
{"Key": "Name", "Value": "different-name"}
])