test_network_service.py 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. import test.helpers as helpers
  2. from test.helpers import ProviderTestBase
  3. from test.helpers import get_provider_test_data
  4. from test.helpers import standard_interface_tests as sit
  5. from cloudbridge.cloud.interfaces.resources import FloatingIP
  6. from cloudbridge.cloud.interfaces.resources import Network
  7. from cloudbridge.cloud.interfaces.resources import RouterState
  8. from cloudbridge.cloud.interfaces.resources import Subnet
  9. class CloudNetworkServiceTestCase(ProviderTestBase):
  10. _multiprocess_can_split_ = True
  11. @helpers.skipIfNoService(['networking.networks'])
  12. def test_crud_network(self):
  13. def create_net(name):
  14. return self.provider.networking.networks.create(
  15. name=name, cidr_block='10.0.0.0/16')
  16. def cleanup_net(net):
  17. self.provider.networking.networks.delete(network_id=net.id)
  18. sit.check_crud(self, self.provider.networking.networks, Network,
  19. "cb_crudnetwork", create_net, cleanup_net)
  20. @helpers.skipIfNoService(['networking.networks'])
  21. def test_network_properties(self):
  22. name = 'cb_propnetwork-{0}'.format(helpers.get_uuid())
  23. subnet_name = 'cb_propsubnet-{0}'.format(helpers.get_uuid())
  24. net = self.provider.networking.networks.create(
  25. name=name, cidr_block='10.0.0.0/16')
  26. with helpers.cleanup_action(
  27. lambda: net.delete()
  28. ):
  29. net.wait_till_ready()
  30. self.assertEqual(
  31. net.state, 'available',
  32. "Network in state '%s', yet should be 'available'" % net.state)
  33. sit.check_repr(self, net)
  34. self.assertIn(
  35. net.cidr_block, ['', '10.0.0.0/16'],
  36. "Network CIDR %s does not contain the expected value."
  37. % net.cidr_block)
  38. cidr = '10.0.1.0/24'
  39. sn = net.create_subnet(
  40. name=subnet_name, cidr_block=cidr,
  41. zone=helpers.get_provider_test_data(self.provider,
  42. 'placement'))
  43. with helpers.cleanup_action(lambda: sn.delete()):
  44. self.assertTrue(
  45. sn in net.subnets,
  46. "Subnet ID %s should be listed in network subnets %s."
  47. % (sn.id, net.subnets))
  48. self.assertTrue(
  49. sn in self.provider.networking.subnets.list(network=net),
  50. "Subnet ID %s should be included in the subnets list %s."
  51. % (sn.id, self.provider.networking.subnets.list(net))
  52. )
  53. self.assertListEqual(
  54. net.subnets, [sn],
  55. "Network should have exactly one subnet: %s." % sn.id)
  56. self.assertIn(
  57. net.id, sn.network_id,
  58. "Network ID %s should be specified in the subnet's network"
  59. " id %s." % (net.id, sn.network_id))
  60. self.assertEqual(
  61. cidr, sn.cidr_block,
  62. "Subnet's CIDR %s should match the specified one %s." % (
  63. sn.cidr_block, cidr))
  64. def test_crud_subnet(self):
  65. # Late binding will make sure that create_subnet gets the
  66. # correct value
  67. net = None
  68. def create_subnet(name):
  69. return self.provider.networking.subnets.create(
  70. network=net, cidr_block="10.0.0.1/24", name=name,
  71. zone=helpers.get_provider_test_data(
  72. self.provider, 'placement'))
  73. def cleanup_subnet(subnet):
  74. self.provider.networking.subnets.delete(subnet=subnet)
  75. net_name = 'cb_crudsubnet-{0}'.format(helpers.get_uuid())
  76. net = self.provider.networking.networks.create(
  77. name=net_name, cidr_block='10.0.0.0/16')
  78. with helpers.cleanup_action(
  79. lambda:
  80. self.provider.networking.networks.delete(network_id=net.id)
  81. ):
  82. sit.check_crud(self, self.provider.networking.subnets, Subnet,
  83. "cb_crudsubnet", create_subnet, cleanup_subnet)
  84. def test_crud_floating_ip(self):
  85. net, gw = helpers.get_test_gateway(
  86. self.provider, 'cb_crudfipgw-{0}'.format(helpers.get_uuid()))
  87. def create_fip(name):
  88. fip = gw.floating_ips.create()
  89. return fip
  90. def cleanup_fip(fip):
  91. gw.floating_ips.delete(fip.id)
  92. with helpers.cleanup_action(
  93. lambda: helpers.delete_test_gateway(net, gw)):
  94. sit.check_crud(self, gw.floating_ips, FloatingIP,
  95. "cb_crudfip", create_fip, cleanup_fip,
  96. skip_name_check=True)
  97. def test_floating_ip_properties(self):
  98. # Check floating IP address
  99. net, gw = helpers.get_test_gateway(
  100. self.provider, 'cb_crudfipgw-{0}'.format(helpers.get_uuid()))
  101. fip = gw.floating_ips.create()
  102. with helpers.cleanup_action(
  103. lambda: helpers.delete_test_gateway(net, gw)):
  104. with helpers.cleanup_action(lambda: fip.delete()):
  105. fipl = list(gw.floating_ips)
  106. self.assertIn(fip, fipl)
  107. # 2016-08: address filtering not implemented in moto
  108. # empty_ipl = self.provider.network.floating_ips('dummy-net')
  109. # self.assertFalse(
  110. # empty_ipl,
  111. # "Bogus network should not have any floating IPs: {0}"
  112. # .format(empty_ipl))
  113. self.assertFalse(
  114. fip.private_ip,
  115. "Floating IP should not have a private IP value ({0})."
  116. .format(fip.private_ip))
  117. self.assertFalse(
  118. fip.in_use,
  119. "Newly created floating IP address should not be in use.")
  120. @helpers.skipIfNoService(['networking.routers'])
  121. def test_crud_router(self):
  122. def _cleanup(net, subnet, router, gateway):
  123. with helpers.cleanup_action(lambda: net.delete()):
  124. with helpers.cleanup_action(lambda: subnet.delete()):
  125. with helpers.cleanup_action(lambda: gateway.delete()):
  126. with helpers.cleanup_action(lambda: router.delete()):
  127. router.detach_subnet(subnet)
  128. router.detach_gateway(gateway)
  129. name = 'cb_crudrouter-{0}'.format(helpers.get_uuid())
  130. # Declare these variables and late binding will allow
  131. # the cleanup method access to the most current values
  132. net = None
  133. sn = None
  134. router = None
  135. gteway = None
  136. with helpers.cleanup_action(lambda: _cleanup(net, sn, router, gteway)):
  137. net = self.provider.networking.networks.create(
  138. name=name, cidr_block='10.0.0.0/16')
  139. router = self.provider.networking.routers.create(network=net,
  140. name=name)
  141. cidr = '10.0.1.0/24'
  142. sn = net.create_subnet(name=name, cidr_block=cidr,
  143. zone=helpers.get_provider_test_data(
  144. self.provider, 'placement'))
  145. # Check basic router properties
  146. sit.check_standard_behaviour(
  147. self, self.provider.networking.routers, router)
  148. self.assertEqual(
  149. router.state, RouterState.DETACHED,
  150. "Router {0} state {1} should be {2}.".format(
  151. router.id, router.state, RouterState.DETACHED))
  152. # self.assertFalse(
  153. # router.network_id,
  154. # "Router {0} should not be assoc. with a network {1}".format(
  155. # router.id, router.network_id))
  156. router.attach_subnet(sn)
  157. gteway = net.gateways.get_or_create_inet_gateway(name)
  158. router.attach_gateway(gteway)
  159. # TODO: add a check for routes after that's been implemented
  160. sit.check_delete(self, self.provider.networking.routers, router)
  161. @helpers.skipIfNoService(['networking.networks'])
  162. def test_default_network(self):
  163. subnet = self.provider.networking.subnets.get_or_create_default(
  164. zone=get_provider_test_data(self.provider, 'placement'))
  165. self.assertIsInstance(subnet, Subnet)