test_provider_block_store_service.py 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. import uuid
  2. from cloudbridge.cloud.interfaces import SnapshotState
  3. from cloudbridge.cloud.interfaces import VolumeState
  4. from test.helpers import ProviderTestBase
  5. import test.helpers as helpers
  6. class ProviderBlockStoreServiceTestCase(ProviderTestBase):
  7. def __init__(self, methodName, provider):
  8. super(ProviderBlockStoreServiceTestCase, self).__init__(
  9. methodName=methodName, provider=provider)
  10. def test_crud_volume(self):
  11. """
  12. Create a new volume, check whether the expected values are set,
  13. and delete it
  14. """
  15. name = "CBUnitTestCreateVol-{0}".format(uuid.uuid4())
  16. test_vol = self.provider.block_store.volumes.create(
  17. name,
  18. 1,
  19. helpers.get_provider_test_data(self.provider, "placement"))
  20. def cleanup_vol(vol):
  21. vol.delete()
  22. vol.wait_for(
  23. [VolumeState.DELETED, VolumeState.UNKNOWN],
  24. terminal_states=[VolumeState.ERROR],
  25. interval=self.get_test_wait_interval())
  26. with helpers.cleanup_action(lambda: cleanup_vol(test_vol)):
  27. test_vol.wait_till_ready(interval=self.get_test_wait_interval())
  28. volumes = self.provider.block_store.volumes.list()
  29. found_volumes = [vol for vol in volumes if vol.name == name]
  30. self.assertTrue(
  31. len(found_volumes) == 1,
  32. "List volumes does not return the expected volume %s" %
  33. name)
  34. get_vol = self.provider.block_store.volumes.get(
  35. test_vol.id)
  36. self.assertTrue(
  37. found_volumes[0].id ==
  38. get_vol.id == test_vol.id,
  39. "Ids returned by list: {0} and get: {1} are not as "
  40. " expected: {2}" .format(found_volumes[0].id,
  41. get_vol.id,
  42. test_vol.id))
  43. self.assertTrue(
  44. found_volumes[0].name ==
  45. get_vol.name == test_vol.name,
  46. "Names returned by list: {0} and get: {1} are not as "
  47. " expected: {2}" .format(found_volumes[0].name,
  48. get_vol.name,
  49. test_vol.name))
  50. volumes = self.provider.block_store.volumes.list()
  51. found_volumes = [vol for vol in volumes if vol.name == name]
  52. self.assertTrue(
  53. len(found_volumes) == 0,
  54. "Volume %s should have been deleted but still exists." %
  55. name)
  56. def test_attach_detach_volume(self):
  57. """
  58. Create a new volume, and attempt to attach it to an instance
  59. """
  60. instance_name = "CBVolOps-{0}-{1}".format(
  61. self.provider.name,
  62. uuid.uuid4())
  63. test_instance = helpers.get_test_instance(self.provider, instance_name)
  64. with helpers.cleanup_action(lambda: test_instance.terminate()):
  65. name = "CBUnitTestAttachVol-{0}".format(uuid.uuid4())
  66. test_vol = self.provider.block_store.volumes.create(
  67. name, 1, test_instance.placement_zone)
  68. with helpers.cleanup_action(lambda: test_vol.delete()):
  69. test_vol.wait_till_ready(
  70. interval=self.get_test_wait_interval())
  71. test_vol.attach(test_instance, '/dev/sda2')
  72. test_vol.wait_for(
  73. [VolumeState.IN_USE],
  74. terminal_states=[VolumeState.ERROR, VolumeState.DELETED],
  75. interval=self.get_test_wait_interval())
  76. test_vol.detach()
  77. test_vol.wait_for(
  78. [VolumeState.AVAILABLE],
  79. terminal_states=[VolumeState.ERROR, VolumeState.DELETED],
  80. interval=self.get_test_wait_interval())
  81. def test_crud_snapshot(self):
  82. """
  83. Create a new volume, create a snapshot of the volume, and check
  84. whether list_snapshots properly detects the new snapshot.
  85. Delete everything afterwards.
  86. """
  87. name = "CBUnitTestCreateSnap-{0}".format(uuid.uuid4())
  88. test_vol = self.provider.block_store.volumes.create(
  89. name,
  90. 1,
  91. helpers.get_provider_test_data(self.provider, "placement"))
  92. with helpers.cleanup_action(lambda: test_vol.delete()):
  93. test_vol.wait_till_ready(interval=self.get_test_wait_interval())
  94. snap_name = "CBSnapshot-{0}".format(name)
  95. test_snap = test_vol.create_snapshot(name=snap_name,
  96. description=snap_name)
  97. def cleanup_snap(snap):
  98. snap.delete()
  99. snap.wait_for(
  100. [SnapshotState.UNKNOWN],
  101. terminal_states=[SnapshotState.ERROR],
  102. interval=self.get_test_wait_interval())
  103. with helpers.cleanup_action(lambda: cleanup_snap(test_snap)):
  104. test_snap.wait_till_ready(
  105. interval=self.get_test_wait_interval())
  106. snaps = self.provider.block_store.snapshots.list()
  107. found_snaps = [snap for snap in snaps
  108. if snap.name == snap_name]
  109. self.assertTrue(
  110. len(found_snaps) == 1,
  111. "List snapshots does not return the expected volume %s" %
  112. name)
  113. get_snap = self.provider.block_store.snapshots.get(
  114. test_snap.id)
  115. self.assertTrue(
  116. found_snaps[0].id ==
  117. get_snap.id == test_snap.id,
  118. "Ids returned by list: {0} and get: {1} are not as "
  119. " expected: {2}" .format(found_snaps[0].id,
  120. get_snap.id,
  121. test_snap.id))
  122. self.assertTrue(
  123. found_snaps[0].name ==
  124. get_snap.name == test_snap.name,
  125. "Names returned by list: {0} and get: {1} are not as "
  126. " expected: {2}" .format(found_snaps[0].name,
  127. get_snap.name,
  128. test_snap.name))
  129. snaps = self.provider.block_store.snapshots.list()
  130. found_snaps = [snap for snap in snaps
  131. if snap.name == snap_name]
  132. self.assertTrue(
  133. len(found_snaps) == 0,
  134. "Snapshot %s should have been deleted but still exists." %
  135. snap_name)