test_network_service.py 8.3 KB

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