Merge pull request #316 from aaltepet/master
Support tag-key, tag-value and instance_type filters (second try)
This commit is contained in:
commit
580d78a168
@ -310,7 +310,9 @@ def get_object_value(obj, attr):
|
|||||||
|
|
||||||
|
|
||||||
def is_tag_filter(filter_name):
|
def is_tag_filter(filter_name):
|
||||||
return filter_name.startswith('tag:')
|
return (filter_name.startswith('tag:') or
|
||||||
|
filter_name.startswith('tag-value') or
|
||||||
|
filter_name.startswith('tag-key'))
|
||||||
|
|
||||||
|
|
||||||
def get_obj_tag(obj, filter_name):
|
def get_obj_tag(obj, filter_name):
|
||||||
@ -318,10 +320,24 @@ def get_obj_tag(obj, filter_name):
|
|||||||
tags = dict((tag['key'], tag['value']) for tag in obj.get_tags())
|
tags = dict((tag['key'], tag['value']) for tag in obj.get_tags())
|
||||||
return tags.get(tag_name)
|
return tags.get(tag_name)
|
||||||
|
|
||||||
|
def get_obj_tag_names(obj):
|
||||||
|
tags = set((tag['key'] for tag in obj.get_tags()))
|
||||||
|
return tags
|
||||||
|
|
||||||
|
def get_obj_tag_values(obj):
|
||||||
|
tags = set((tag['value'] for tag in obj.get_tags()))
|
||||||
|
return tags
|
||||||
|
|
||||||
def tag_filter_matches(obj, filter_name, filter_values):
|
def tag_filter_matches(obj, filter_name, filter_values):
|
||||||
tag_value = get_obj_tag(obj, filter_name)
|
if filter_name == 'tag-key':
|
||||||
return tag_value in filter_values
|
tag_names = get_obj_tag_names(obj)
|
||||||
|
return len(set(filter_values).intersection(tag_names)) > 0
|
||||||
|
elif filter_name == 'tag-value':
|
||||||
|
tag_values = get_obj_tag_values(obj)
|
||||||
|
return len(set(filter_values).intersection(tag_values)) > 0
|
||||||
|
else:
|
||||||
|
tag_value = get_obj_tag(obj, filter_name)
|
||||||
|
return tag_value in filter_values
|
||||||
|
|
||||||
|
|
||||||
filter_dict_attribute_mapping = {
|
filter_dict_attribute_mapping = {
|
||||||
@ -331,7 +347,8 @@ filter_dict_attribute_mapping = {
|
|||||||
'source-dest-check': 'source_dest_check',
|
'source-dest-check': 'source_dest_check',
|
||||||
'vpc-id': 'vpc_id',
|
'vpc-id': 'vpc_id',
|
||||||
'group-id': 'security_groups',
|
'group-id': 'security_groups',
|
||||||
'instance.group-id': 'security_groups'
|
'instance.group-id': 'security_groups',
|
||||||
|
'instance-type': 'instance_type'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -139,6 +139,48 @@ def test_get_instances_filtering_by_instance_id():
|
|||||||
reservations = conn.get_all_instances(filters={'instance-id': 'non-existing-id'})
|
reservations = conn.get_all_instances(filters={'instance-id': 'non-existing-id'})
|
||||||
reservations.should.have.length_of(0)
|
reservations.should.have.length_of(0)
|
||||||
|
|
||||||
|
|
||||||
|
@mock_ec2
|
||||||
|
def test_get_instances_filtering_by_instance_type():
|
||||||
|
conn = boto.connect_ec2()
|
||||||
|
reservation1 = conn.run_instances('ami-1234abcd', instance_type='m1.small')
|
||||||
|
instance1 = reservation1.instances[0]
|
||||||
|
reservation2 = conn.run_instances('ami-1234abcd', instance_type='m1.small')
|
||||||
|
instance2 = reservation2.instances[0]
|
||||||
|
reservation3 = conn.run_instances('ami-1234abcd', instance_type='t1.micro')
|
||||||
|
instance3 = reservation3.instances[0]
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'instance-type': 'm1.small'})
|
||||||
|
# get_all_instances should return instance1,2
|
||||||
|
reservations.should.have.length_of(2)
|
||||||
|
reservations[0].instances.should.have.length_of(1)
|
||||||
|
reservations[1].instances.should.have.length_of(1)
|
||||||
|
instance_ids = [ reservations[0].instances[0].id,
|
||||||
|
reservations[1].instances[0].id ]
|
||||||
|
set(instance_ids).should.equal(set([instance1.id, instance2.id]))
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'instance-type': 't1.micro'})
|
||||||
|
# get_all_instances should return one
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(1)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance3.id)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'instance-type': ['t1.micro', 'm1.small']})
|
||||||
|
reservations.should.have.length_of(3)
|
||||||
|
reservations[0].instances.should.have.length_of(1)
|
||||||
|
reservations[1].instances.should.have.length_of(1)
|
||||||
|
reservations[2].instances.should.have.length_of(1)
|
||||||
|
instance_ids = [
|
||||||
|
reservations[0].instances[0].id,
|
||||||
|
reservations[1].instances[0].id,
|
||||||
|
reservations[2].instances[0].id,
|
||||||
|
]
|
||||||
|
set(instance_ids).should.equal(set([instance1.id, instance2.id, instance3.id]))
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'instance-type': 'bogus'})
|
||||||
|
#bogus instance-type should return none
|
||||||
|
reservations.should.have.length_of(0)
|
||||||
|
|
||||||
@mock_ec2
|
@mock_ec2
|
||||||
def test_get_instances_filtering_by_reason_code():
|
def test_get_instances_filtering_by_reason_code():
|
||||||
conn = boto.connect_ec2()
|
conn = boto.connect_ec2()
|
||||||
@ -240,6 +282,73 @@ def test_get_instances_filtering_by_tag():
|
|||||||
reservations[0].instances[0].id.should.equal(instance1.id)
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
reservations[0].instances[1].id.should.equal(instance3.id)
|
reservations[0].instances[1].id.should.equal(instance3.id)
|
||||||
|
|
||||||
|
@mock_ec2
|
||||||
|
def test_get_instances_filtering_by_tag_value():
|
||||||
|
conn = boto.connect_ec2()
|
||||||
|
reservation = conn.run_instances('ami-1234abcd', min_count=3)
|
||||||
|
instance1, instance2, instance3 = reservation.instances
|
||||||
|
instance1.add_tag('tag1', 'value1')
|
||||||
|
instance1.add_tag('tag2', 'value2')
|
||||||
|
instance2.add_tag('tag1', 'value1')
|
||||||
|
instance2.add_tag('tag2', 'wrong value')
|
||||||
|
instance3.add_tag('tag2', 'value2')
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-value' : 'value0'})
|
||||||
|
# get_all_instances should return no instances
|
||||||
|
reservations.should.have.length_of(0)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-value' : 'value1'})
|
||||||
|
# get_all_instances should return both instances with this tag value
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(2)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
|
reservations[0].instances[1].id.should.equal(instance2.id)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-value' : ['value2', 'value1']})
|
||||||
|
# get_all_instances should return both instances with one of the acceptable tag values
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(3)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
|
reservations[0].instances[1].id.should.equal(instance2.id)
|
||||||
|
reservations[0].instances[2].id.should.equal(instance3.id)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-value' : ['value2', 'bogus']})
|
||||||
|
# get_all_instances should return both instances with one of the acceptable tag values
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(2)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
|
reservations[0].instances[1].id.should.equal(instance3.id)
|
||||||
|
|
||||||
|
@mock_ec2
|
||||||
|
def test_get_instances_filtering_by_tag_name():
|
||||||
|
conn = boto.connect_ec2()
|
||||||
|
reservation = conn.run_instances('ami-1234abcd', min_count=3)
|
||||||
|
instance1, instance2, instance3 = reservation.instances
|
||||||
|
instance1.add_tag('tag1')
|
||||||
|
instance1.add_tag('tag2')
|
||||||
|
instance2.add_tag('tag1')
|
||||||
|
instance2.add_tag('tag2X')
|
||||||
|
instance3.add_tag('tag3')
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-key' : 'tagX'})
|
||||||
|
# get_all_instances should return no instances
|
||||||
|
reservations.should.have.length_of(0)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-key' : 'tag1'})
|
||||||
|
# get_all_instances should return both instances with this tag value
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(2)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
|
reservations[0].instances[1].id.should.equal(instance2.id)
|
||||||
|
|
||||||
|
reservations = conn.get_all_instances(filters={'tag-key' : ['tag1', 'tag3']})
|
||||||
|
# get_all_instances should return both instances with one of the acceptable tag values
|
||||||
|
reservations.should.have.length_of(1)
|
||||||
|
reservations[0].instances.should.have.length_of(3)
|
||||||
|
reservations[0].instances[0].id.should.equal(instance1.id)
|
||||||
|
reservations[0].instances[1].id.should.equal(instance2.id)
|
||||||
|
reservations[0].instances[2].id.should.equal(instance3.id)
|
||||||
|
|
||||||
@mock_ec2
|
@mock_ec2
|
||||||
def test_instance_start_and_stop():
|
def test_instance_start_and_stop():
|
||||||
conn = boto.connect_ec2('the_key', 'the_secret')
|
conn = boto.connect_ec2('the_key', 'the_secret')
|
||||||
|
Loading…
Reference in New Issue
Block a user