Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Unified Diff: third_party/gsutil/third_party/boto/tests/integration/ec2/vpc/test_connection.py

Issue 1377933002: [catapult] - Copy Telemetry's gsutilz over to third_party. (Closed) Base URL: https://github.com/catapult-project/catapult.git@master
Patch Set: Rename to gsutil. Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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()

Powered by Google App Engine
This is Rietveld 408576698