| Index: third_party/gsutil/third_party/boto/tests/integration/ec2/vpc/test_connection.py
|
| diff --git a/third_party/gsutil/third_party/boto/tests/integration/ec2/vpc/test_connection.py b/third_party/gsutil/third_party/boto/tests/integration/ec2/vpc/test_connection.py
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..6e7b28896bf779c894a9a7cefdec9e5ff8f85bf8
|
| --- /dev/null
|
| +++ b/third_party/gsutil/third_party/boto/tests/integration/ec2/vpc/test_connection.py
|
| @@ -0,0 +1,213 @@
|
| +#!/usr/bin/env python
|
| +# Copyright (c) 2012 Amazon.com, Inc. or its affiliates. All Rights Reserved
|
| +#
|
| +# Permission is hereby granted, free of charge, to any person obtaining a
|
| +# copy of this software and associated documentation files (the
|
| +# "Software"), to deal in the Software without restriction, including
|
| +# without limitation the rights to use, copy, modify, merge, publish, dis-
|
| +# tribute, sublicense, and/or sell copies of the Software, and to permit
|
| +# persons to whom the Software is furnished to do so, subject to the fol-
|
| +# lowing conditions:
|
| +#
|
| +# The above copyright notice and this permission notice shall be included
|
| +# in all copies or substantial portions of the Software.
|
| +#
|
| +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
| +# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
|
| +# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
| +# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
| +# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
| +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
| +# IN THE SOFTWARE.
|
| +#
|
| +import time
|
| +
|
| +import boto
|
| +from boto.compat import six
|
| +from tests.compat import unittest
|
| +from boto.ec2.networkinterface import NetworkInterfaceCollection
|
| +from boto.ec2.networkinterface import NetworkInterfaceSpecification
|
| +from boto.ec2.networkinterface import PrivateIPAddress
|
| +
|
| +
|
| +class TestVPCConnection(unittest.TestCase):
|
| +
|
| + def setUp(self):
|
| + # Registry of instances to be removed
|
| + self.instances = []
|
| + # Registry for cleaning up the vpc after all instances are terminated
|
| + # in the format [ ( func, (arg1, ... argn) ) ]
|
| + self.post_terminate_cleanups = []
|
| +
|
| + self.api = boto.connect_vpc()
|
| + self.vpc = self.api.create_vpc('10.0.0.0/16')
|
| +
|
| + # Need time for the VPC to be in place. :/
|
| + time.sleep(5)
|
| + self.subnet = self.api.create_subnet(self.vpc.id, '10.0.0.0/24')
|
| + # Register the subnet to be deleted after instance termination
|
| + self.post_terminate_cleanups.append((self.api.delete_subnet, (self.subnet.id,)))
|
| +
|
| + # Need time for the subnet to be in place.
|
| + time.sleep(10)
|
| +
|
| + def post_terminate_cleanup(self):
|
| + """Helper to run clean up tasks after instances are removed."""
|
| + for fn, args in self.post_terminate_cleanups:
|
| + fn(*args)
|
| + # Give things time to catch up each time
|
| + time.sleep(10)
|
| +
|
| + # Now finally delete the vpc
|
| + if self.vpc:
|
| + self.api.delete_vpc(self.vpc.id)
|
| +
|
| + def terminate_instances(self):
|
| + """Helper to remove all instances and kick off additional cleanup
|
| + once they are terminated.
|
| + """
|
| + for instance in self.instances:
|
| + self.terminate_instance(instance)
|
| + self.post_terminate_cleanup()
|
| +
|
| + def terminate_instance(self, instance):
|
| + instance.terminate()
|
| + for i in six.moves.range(300):
|
| + instance.update()
|
| + if instance.state == 'terminated':
|
| + # Give it a litle more time to settle.
|
| + time.sleep(30)
|
| + return
|
| + else:
|
| + time.sleep(10)
|
| +
|
| + def delete_elastic_ip(self, eip):
|
| + # Fetch a new copy of the eip so we're up to date
|
| + new_eip = self.api.get_all_addresses([eip.public_ip])[0]
|
| + if new_eip.association_id:
|
| + new_eip.disassociate()
|
| + new_eip.release()
|
| + time.sleep(10)
|
| +
|
| + def test_multi_ip_create(self):
|
| + interface = NetworkInterfaceSpecification(
|
| + device_index=0, subnet_id=self.subnet.id,
|
| + private_ip_address='10.0.0.21',
|
| + description="This is a test interface using boto.",
|
| + delete_on_termination=True, private_ip_addresses=[
|
| + PrivateIPAddress(private_ip_address='10.0.0.22',
|
| + primary=False),
|
| + PrivateIPAddress(private_ip_address='10.0.0.23',
|
| + primary=False),
|
| + PrivateIPAddress(private_ip_address='10.0.0.24',
|
| + primary=False)])
|
| + interfaces = NetworkInterfaceCollection(interface)
|
| +
|
| + reservation = self.api.run_instances(image_id='ami-a0cd60c9', instance_type='m1.small',
|
| + network_interfaces=interfaces)
|
| + # Give it a few seconds to start up.
|
| + time.sleep(10)
|
| + instance = reservation.instances[0]
|
| + self.addCleanup(self.terminate_instance, instance)
|
| + retrieved = self.api.get_all_reservations(instance_ids=[instance.id])
|
| + self.assertEqual(len(retrieved), 1)
|
| + retrieved_instances = retrieved[0].instances
|
| + self.assertEqual(len(retrieved_instances), 1)
|
| + retrieved_instance = retrieved_instances[0]
|
| +
|
| + self.assertEqual(len(retrieved_instance.interfaces), 1)
|
| + interface = retrieved_instance.interfaces[0]
|
| +
|
| + private_ip_addresses = interface.private_ip_addresses
|
| + self.assertEqual(len(private_ip_addresses), 4)
|
| + self.assertEqual(private_ip_addresses[0].private_ip_address,
|
| + '10.0.0.21')
|
| + self.assertEqual(private_ip_addresses[0].primary, True)
|
| + self.assertEqual(private_ip_addresses[1].private_ip_address,
|
| + '10.0.0.22')
|
| + self.assertEqual(private_ip_addresses[2].private_ip_address,
|
| + '10.0.0.23')
|
| + self.assertEqual(private_ip_addresses[3].private_ip_address,
|
| + '10.0.0.24')
|
| +
|
| + def test_associate_public_ip(self):
|
| + # Supplying basically nothing ought to work.
|
| + interface = NetworkInterfaceSpecification(
|
| + associate_public_ip_address=True,
|
| + subnet_id=self.subnet.id,
|
| + # Just for testing.
|
| + delete_on_termination=True
|
| + )
|
| + interfaces = NetworkInterfaceCollection(interface)
|
| +
|
| + reservation = self.api.run_instances(
|
| + image_id='ami-a0cd60c9',
|
| + instance_type='m1.small',
|
| + network_interfaces=interfaces
|
| + )
|
| + instance = reservation.instances[0]
|
| + self.instances.append(instance)
|
| + self.addCleanup(self.terminate_instances)
|
| +
|
| + # Give it a **LONG** time to start up.
|
| + # Because the public IP won't be there right away.
|
| + time.sleep(60)
|
| +
|
| + retrieved = self.api.get_all_reservations(
|
| + instance_ids=[
|
| + instance.id
|
| + ]
|
| + )
|
| + self.assertEqual(len(retrieved), 1)
|
| + retrieved_instances = retrieved[0].instances
|
| + self.assertEqual(len(retrieved_instances), 1)
|
| + retrieved_instance = retrieved_instances[0]
|
| +
|
| + self.assertEqual(len(retrieved_instance.interfaces), 1)
|
| + interface = retrieved_instance.interfaces[0]
|
| +
|
| + # There ought to be a public IP there.
|
| + # We can't reason about the IP itself, so just make sure it vaguely
|
| + # resembles an IP (& isn't empty/``None``)...
|
| + self.assertTrue(interface.publicIp.count('.') >= 3)
|
| +
|
| + def test_associate_elastic_ip(self):
|
| + interface = NetworkInterfaceSpecification(
|
| + associate_public_ip_address=False,
|
| + subnet_id=self.subnet.id,
|
| + # Just for testing.
|
| + delete_on_termination=True
|
| + )
|
| + interfaces = NetworkInterfaceCollection(interface)
|
| +
|
| + reservation = self.api.run_instances(
|
| + image_id='ami-a0cd60c9',
|
| + instance_type='m1.small',
|
| + network_interfaces=interfaces
|
| + )
|
| + instance = reservation.instances[0]
|
| + # Register instance to be removed
|
| + self.instances.append(instance)
|
| + # Add terminate instances helper as cleanup command
|
| + self.addCleanup(self.terminate_instances)
|
| +
|
| + # Create an internet gateway so we can attach an eip
|
| + igw = self.api.create_internet_gateway()
|
| + # Wait on gateway before attaching
|
| + time.sleep(5)
|
| + # Attach and register clean up tasks
|
| + self.api.attach_internet_gateway(igw.id, self.vpc.id)
|
| + self.post_terminate_cleanups.append((self.api.detach_internet_gateway, (igw.id, self.vpc.id)))
|
| + self.post_terminate_cleanups.append((self.api.delete_internet_gateway, (igw.id,)))
|
| +
|
| + # Allocate an elastic ip to this vpc
|
| + eip = self.api.allocate_address('vpc')
|
| + self.post_terminate_cleanups.append((self.delete_elastic_ip, (eip,)))
|
| +
|
| + # Wait on instance and eip then try to associate directly to instance
|
| + time.sleep(60)
|
| + eip.associate(instance.id)
|
| +
|
| +
|
| +if __name__ == '__main__':
|
| + unittest.main()
|
|
|