1
0

volume_test.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. from docker.errors import DockerException
  2. from .testcases import DockerClientTestCase
  3. from .testcases import no_cluster
  4. from compose.const import LABEL_PROJECT
  5. from compose.const import LABEL_VOLUME
  6. from compose.volume import Volume
  7. class VolumeTest(DockerClientTestCase):
  8. def setUp(self):
  9. self.tmp_volumes = []
  10. def tearDown(self):
  11. for volume in self.tmp_volumes:
  12. try:
  13. self.client.remove_volume(volume.full_name)
  14. except DockerException:
  15. pass
  16. del self.tmp_volumes
  17. super(VolumeTest, self).tearDown()
  18. def create_volume(self, name, driver=None, opts=None, external=None, custom_name=False):
  19. if external:
  20. custom_name = True
  21. if isinstance(external, str):
  22. name = external
  23. vol = Volume(
  24. self.client, 'composetest', name, driver=driver, driver_opts=opts,
  25. external=bool(external), custom_name=custom_name
  26. )
  27. self.tmp_volumes.append(vol)
  28. return vol
  29. def test_create_volume(self):
  30. vol = self.create_volume('volume01')
  31. vol.create()
  32. info = self.get_volume_data(vol.full_name)
  33. assert info['Name'].split('/')[-1] == vol.full_name
  34. def test_create_volume_custom_name(self):
  35. vol = self.create_volume('volume01', custom_name=True)
  36. assert vol.name == vol.full_name
  37. vol.create()
  38. info = self.get_volume_data(vol.full_name)
  39. assert info['Name'].split('/')[-1] == vol.name
  40. def test_recreate_existing_volume(self):
  41. vol = self.create_volume('volume01')
  42. vol.create()
  43. info = self.get_volume_data(vol.full_name)
  44. assert info['Name'].split('/')[-1] == vol.full_name
  45. vol.create()
  46. info = self.get_volume_data(vol.full_name)
  47. assert info['Name'].split('/')[-1] == vol.full_name
  48. @no_cluster('inspect volume by name defect on Swarm Classic')
  49. def test_inspect_volume(self):
  50. vol = self.create_volume('volume01')
  51. vol.create()
  52. info = vol.inspect()
  53. assert info['Name'] == vol.full_name
  54. @no_cluster('remove volume by name defect on Swarm Classic')
  55. def test_remove_volume(self):
  56. vol = Volume(self.client, 'composetest', 'volume01')
  57. vol.create()
  58. vol.remove()
  59. volumes = self.client.volumes()['Volumes']
  60. assert len([v for v in volumes if v['Name'] == vol.full_name]) == 0
  61. @no_cluster('inspect volume by name defect on Swarm Classic')
  62. def test_external_volume(self):
  63. vol = self.create_volume('composetest_volume_ext', external=True)
  64. assert vol.external is True
  65. assert vol.full_name == vol.name
  66. vol.create()
  67. info = vol.inspect()
  68. assert info['Name'] == vol.name
  69. @no_cluster('inspect volume by name defect on Swarm Classic')
  70. def test_external_aliased_volume(self):
  71. alias_name = 'composetest_alias01'
  72. vol = self.create_volume('volume01', external=alias_name)
  73. assert vol.external is True
  74. assert vol.full_name == alias_name
  75. vol.create()
  76. info = vol.inspect()
  77. assert info['Name'] == alias_name
  78. @no_cluster('inspect volume by name defect on Swarm Classic')
  79. def test_exists(self):
  80. vol = self.create_volume('volume01')
  81. assert vol.exists() is False
  82. vol.create()
  83. assert vol.exists() is True
  84. @no_cluster('inspect volume by name defect on Swarm Classic')
  85. def test_exists_external(self):
  86. vol = self.create_volume('volume01', external=True)
  87. assert vol.exists() is False
  88. vol.create()
  89. assert vol.exists() is True
  90. @no_cluster('inspect volume by name defect on Swarm Classic')
  91. def test_exists_external_aliased(self):
  92. vol = self.create_volume('volume01', external='composetest_alias01')
  93. assert vol.exists() is False
  94. vol.create()
  95. assert vol.exists() is True
  96. @no_cluster('inspect volume by name defect on Swarm Classic')
  97. def test_volume_default_labels(self):
  98. vol = self.create_volume('volume01')
  99. vol.create()
  100. vol_data = vol.inspect()
  101. labels = vol_data['Labels']
  102. assert labels[LABEL_VOLUME] == vol.name
  103. assert labels[LABEL_PROJECT] == vol.project