فهرست منبع

Merge pull request #3756 from nkovacs/2419-run-rm-volumes

Remove anonymous volumes when using run --rm.
Joffrey F 8 سال پیش
والد
کامیت
1a77a7fd44
3فایلهای تغییر یافته به همراه42 افزوده شده و 1 حذف شده
  1. 1 1
      compose/cli/main.py
  2. 30 0
      tests/acceptance/cli_test.py
  3. 11 0
      tests/fixtures/volume/docker-compose.yml

+ 1 - 1
compose/cli/main.py

@@ -1014,7 +1014,7 @@ def run_one_off_container(container_options, project, service, options):
 
 
     def remove_container(force=False):
     def remove_container(force=False):
         if options['--rm']:
         if options['--rm']:
-            project.client.remove_container(container.id, force=True)
+            project.client.remove_container(container.id, force=True, v=True)
 
 
     signals.set_signal_handler_to_shutdown()
     signals.set_signal_handler_to_shutdown()
     try:
     try:

+ 30 - 0
tests/acceptance/cli_test.py

@@ -1178,6 +1178,36 @@ class CLITestCase(DockerClientTestCase):
             [u'/bin/true'],
             [u'/bin/true'],
         )
         )
 
 
+    def test_run_rm(self):
+        self.base_dir = 'tests/fixtures/volume'
+        proc = start_process(self.base_dir, ['run', '--rm', 'test'])
+        wait_on_condition(ContainerStateCondition(
+            self.project.client,
+            'volume_test_run_1',
+            'running'))
+        service = self.project.get_service('test')
+        containers = service.containers(one_off=OneOffFilter.only)
+        self.assertEqual(len(containers), 1)
+        mounts = containers[0].get('Mounts')
+        for mount in mounts:
+            if mount['Destination'] == '/container-path':
+                anonymousName = mount['Name']
+                break
+        os.kill(proc.pid, signal.SIGINT)
+        wait_on_process(proc, 1)
+
+        self.assertEqual(len(service.containers(stopped=True, one_off=OneOffFilter.only)), 0)
+
+        volumes = self.client.volumes()['Volumes']
+        assert volumes is not None
+        for volume in service.options.get('volumes'):
+            if volume.internal == '/container-named-path':
+                name = volume.external
+                break
+        volumeNames = [v['Name'] for v in volumes]
+        assert name in volumeNames
+        assert anonymousName not in volumeNames
+
     def test_run_service_with_dockerfile_entrypoint(self):
     def test_run_service_with_dockerfile_entrypoint(self):
         self.base_dir = 'tests/fixtures/entrypoint-dockerfile'
         self.base_dir = 'tests/fixtures/entrypoint-dockerfile'
         self.dispatch(['run', 'test'])
         self.dispatch(['run', 'test'])

+ 11 - 0
tests/fixtures/volume/docker-compose.yml

@@ -0,0 +1,11 @@
+version: '2'
+services:
+  test:
+    image: busybox
+    command: top
+    volumes:
+      - /container-path
+      - testvolume:/container-named-path
+
+volumes:
+  testvolume: {}