test_network_service.py 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. import test.helpers as helpers
  2. import uuid
  3. from test.helpers import ProviderTestBase
  4. from cloudbridge.cloud.interfaces.resources import RouterState
  5. class CloudNetworkServiceTestCase(ProviderTestBase):
  6. def __init__(self, methodName, provider):
  7. super(CloudNetworkServiceTestCase, self).__init__(
  8. methodName=methodName, provider=provider)
  9. def test_crud_network_service(self):
  10. name = 'cbtestnetworkservice-{0}'.format(uuid.uuid4())
  11. subnet_name = 'cbtestsubnetservice-{0}'.format(uuid.uuid4())
  12. net = self.provider.network.create(name=name)
  13. with helpers.cleanup_action(
  14. lambda:
  15. self.provider.network.delete(network_id=net.id)
  16. ):
  17. # test list method
  18. netl = self.provider.network.list()
  19. list_netl = [n for n in netl if n.name == name]
  20. self.assertTrue(
  21. len(list_netl) == 1,
  22. "List networks does not return the expected network %s" %
  23. name)
  24. # check get
  25. get_net = self.provider.network.get(network_id=net.id)
  26. self.assertTrue(
  27. get_net == net,
  28. "Get network did not return the expected network {0}."
  29. .format(name))
  30. # check subnet
  31. subnet = self.provider.network.subnets.create(
  32. network=net, cidr_block="10.0.0.1/24", name=subnet_name)
  33. with helpers.cleanup_action(
  34. lambda:
  35. self.provider.network.subnets.delete(subnet=subnet)
  36. ):
  37. # test list method
  38. subnetl = self.provider.network.subnets.list(network=net)
  39. list_subnetl = [n for n in subnetl if n.name == subnet_name]
  40. self.assertTrue(
  41. len(list_subnetl) == 1,
  42. "List subnets does not return the expected subnet %s" %
  43. subnet_name)
  44. # test get method
  45. sn = self.provider.network.subnets.get(subnet.id)
  46. self.assertTrue(
  47. subnet.id == sn.id,
  48. "GETting subnet should return the same subnet")
  49. subnetl = self.provider.network.subnets.list()
  50. found_subnet = [n for n in subnetl if n.name == subnet_name]
  51. self.assertTrue(
  52. len(found_subnet) == 0,
  53. "Subnet {0} should have been deleted but still exists."
  54. .format(subnet_name))
  55. # Check floating IP address
  56. ip = self.provider.network.create_floating_ip()
  57. ip_id = ip.id
  58. with helpers.cleanup_action(lambda: ip.delete()):
  59. ipl = self.provider.network.floating_ips()
  60. self.assertTrue(
  61. ip in ipl,
  62. "Floating IP address {0} should exist in the list {1}"
  63. .format(ip.id, ipl))
  64. # 2016-08: address filtering not implemented in moto
  65. # empty_ipl = self.provider.network.floating_ips('dummy-net')
  66. # self.assertFalse(
  67. # empty_ipl,
  68. # "Bogus network should not have any floating IPs: {0}"
  69. # .format(empty_ipl))
  70. self.assertIn(
  71. ip.public_ip, repr(ip),
  72. "repr(obj) should contain the address public IP value.")
  73. self.assertFalse(
  74. ip.private_ip,
  75. "Floating IP should not have a private IP value ({0})."
  76. .format(ip.private_ip))
  77. self.assertFalse(
  78. ip.in_use(),
  79. "Newly created floating IP address should not be in use.")
  80. ipl = self.provider.network.floating_ips()
  81. found_ip = [a for a in ipl if a.id == ip_id]
  82. self.assertTrue(
  83. len(found_ip) == 0,
  84. "Floating IP {0} should have been deleted but still exists."
  85. .format(ip_id))
  86. netl = self.provider.network.list()
  87. found_net = [n for n in netl if n.name == name]
  88. self.assertEqual(
  89. len(found_net), 0,
  90. "Network {0} should have been deleted but still exists."
  91. .format(name))
  92. def test_crud_network(self):
  93. name = 'cbtestnetwork-{0}'.format(uuid.uuid4())
  94. subnet_name = 'cbtestsubnet-{0}'.format(uuid.uuid4())
  95. net = self.provider.network.create(name=name)
  96. with helpers.cleanup_action(
  97. lambda: net.delete()
  98. ):
  99. net.wait_till_ready()
  100. self.assertEqual(
  101. net.refresh(), 'available',
  102. "Network in state %s , yet should be 'available'" % net.state)
  103. self.assertIn(
  104. net.id, repr(net),
  105. "repr(obj) should contain the object id so that the object"
  106. " can be reconstructed, but does not.")
  107. self.assertIn(
  108. net.cidr_block, ['', '10.0.0.0/16'],
  109. "Network CIDR %s does not contain the expected value."
  110. % net.cidr_block)
  111. cidr = '10.0.1.0/24'
  112. sn = net.create_subnet(cidr_block=cidr, name=subnet_name)
  113. with helpers.cleanup_action(lambda: sn.delete()):
  114. self.assertTrue(
  115. sn.id in [s.id for s in net.subnets()],
  116. "Subnet ID %s should be listed in network subnets %s."
  117. % (sn.id, net.subnets()))
  118. self.assertIn(
  119. net.id, sn.network_id,
  120. "Network ID %s should be specified in the subnet's network"
  121. " id %s." % (net.id, sn.network_id))
  122. self.assertEqual(
  123. cidr, sn.cidr_block,
  124. "Subnet's CIDR %s should match the specified one %s." % (
  125. sn.cidr_block, cidr))
  126. def test_crud_router(self):
  127. def _cleanup(net, subnet, router):
  128. router.remove_route(subnet.id)
  129. router.detach_network()
  130. router.delete()
  131. subnet.delete()
  132. net.delete()
  133. name = 'cbtestrouter-{0}'.format(uuid.uuid4())
  134. router = self.provider.network.create_router(name=name)
  135. net = self.provider.network.create(name=name)
  136. cidr = '10.0.1.0/24'
  137. sn = net.create_subnet(cidr_block=cidr, name=name)
  138. with helpers.cleanup_action(lambda: _cleanup(net, sn, router)):
  139. # Check basic router properties
  140. self.assertIn(
  141. router, self.provider.network.routers(),
  142. "Router {0} should exist in the router list {1}.".format(
  143. router.id, self.provider.network.routers()))
  144. self.assertIn(
  145. router.id, repr(router),
  146. "repr(obj) should contain the object id so that the object"
  147. " can be reconstructed, but does not.")
  148. self.assertEqual(
  149. router.name, name,
  150. "Router {0} name should be {1}.".format(router.name, name))
  151. self.assertEqual(
  152. router.state, RouterState.DETACHED,
  153. "Router {0} state {1} should be {2}.".format(
  154. router.id, router.state, RouterState.DETACHED))
  155. self.assertFalse(
  156. router.network_id,
  157. "Router {0} should not be assoc. with a network {1}".format(
  158. router.id, router.network_id))
  159. # Check router connectivity
  160. # On OpenStack only one network is external and on AWS every
  161. # network is external, yet we need to use the one we've created?!
  162. if self.provider.PROVIDER_ID == 'openstack':
  163. for n in self.provider.network.list():
  164. if n.external:
  165. external_net = n
  166. break
  167. else:
  168. external_net = net
  169. router.attach_network(external_net.id)
  170. router.refresh()
  171. self.assertEqual(
  172. router.network_id, external_net.id,
  173. "Router should be attached to network {0}, not {1}".format(
  174. external_net.id, router.network_id))
  175. router.add_route(sn.id)
  176. # TODO: add a check for routes after that's been implemented
  177. routerl = self.provider.network.routers()
  178. found_router = [r for r in routerl if r.name == name]
  179. self.assertEqual(
  180. len(found_router), 0,
  181. "Router {0} should have been deleted but still exists."
  182. .format(name))