|
|
@@ -42,11 +42,30 @@ class ProjectTest(DockerClientTestCase):
|
|
|
project = Project('test', [web], self.client)
|
|
|
self.assertEqual(project.get_service('web'), web)
|
|
|
|
|
|
- def test_up(self):
|
|
|
+ def test_create_containers(self):
|
|
|
web = self.create_service('web')
|
|
|
db = self.create_service('db')
|
|
|
project = Project('test', [web, db], self.client)
|
|
|
|
|
|
+ unstarted = project.create_containers(service_names=['web'])
|
|
|
+ self.assertEqual(len(unstarted), 1)
|
|
|
+ self.assertEqual(unstarted[0][0], web)
|
|
|
+ self.assertEqual(len(web.containers(stopped=True)), 1)
|
|
|
+ self.assertEqual(len(db.containers(stopped=True)), 0)
|
|
|
+
|
|
|
+ unstarted = project.create_containers()
|
|
|
+ self.assertEqual(len(unstarted), 2)
|
|
|
+ self.assertEqual(unstarted[0][0], web)
|
|
|
+ self.assertEqual(unstarted[1][0], db)
|
|
|
+ self.assertEqual(len(web.containers(stopped=True)), 2)
|
|
|
+ self.assertEqual(len(db.containers(stopped=True)), 1)
|
|
|
+
|
|
|
+ def test_up(self):
|
|
|
+ web = self.create_service('web')
|
|
|
+ db = self.create_service('db')
|
|
|
+ other = self.create_service('other')
|
|
|
+ project = Project('test', [web, db, other], self.client)
|
|
|
+
|
|
|
web.create_container()
|
|
|
|
|
|
self.assertEqual(len(web.containers()), 0)
|
|
|
@@ -54,7 +73,7 @@ class ProjectTest(DockerClientTestCase):
|
|
|
self.assertEqual(len(web.containers(stopped=True)), 1)
|
|
|
self.assertEqual(len(db.containers(stopped=True)), 0)
|
|
|
|
|
|
- unstarted = project.create_containers()
|
|
|
+ unstarted = project.create_containers(service_names=['web', 'db'])
|
|
|
self.assertEqual(len(unstarted), 2)
|
|
|
self.assertEqual(unstarted[0][0], web)
|
|
|
self.assertEqual(unstarted[1][0], db)
|
|
|
@@ -71,7 +90,7 @@ class ProjectTest(DockerClientTestCase):
|
|
|
self.assertEqual(len(web.containers(stopped=True)), 1)
|
|
|
self.assertEqual(len(db.containers(stopped=True)), 0)
|
|
|
|
|
|
- def test_start_stop(self):
|
|
|
+ def test_start_stop_kill_remove(self):
|
|
|
web = self.create_service('web')
|
|
|
db = self.create_service('db')
|
|
|
project = Project('test', [web, db], self.client)
|
|
|
@@ -81,13 +100,25 @@ class ProjectTest(DockerClientTestCase):
|
|
|
self.assertEqual(len(web.containers()), 0)
|
|
|
self.assertEqual(len(db.containers()), 0)
|
|
|
|
|
|
- web.create_container()
|
|
|
+ web_container_1 = web.create_container()
|
|
|
+ web_container_2 = web.create_container()
|
|
|
+ db_container = db.create_container()
|
|
|
+
|
|
|
+ project.start(service_names=['web'])
|
|
|
+ self.assertEqual(set(c.name for c in project.containers()), set([web_container_1.name, web_container_2.name]))
|
|
|
+
|
|
|
project.start()
|
|
|
+ self.assertEqual(set(c.name for c in project.containers()), set([web_container_1.name, web_container_2.name, db_container.name]))
|
|
|
|
|
|
- self.assertEqual(len(web.containers()), 1)
|
|
|
- self.assertEqual(len(db.containers()), 0)
|
|
|
+ project.stop(service_names=['web'], timeout=1)
|
|
|
+ self.assertEqual(set(c.name for c in project.containers()), set([db_container.name]))
|
|
|
|
|
|
- project.stop(timeout=1)
|
|
|
+ project.kill(service_names=['db'])
|
|
|
+ self.assertEqual(len(project.containers()), 0)
|
|
|
+ self.assertEqual(len(project.containers(stopped=True)), 3)
|
|
|
|
|
|
- self.assertEqual(len(web.containers()), 0)
|
|
|
- self.assertEqual(len(db.containers()), 0)
|
|
|
+ project.remove_stopped(service_names=['web'])
|
|
|
+ self.assertEqual(len(project.containers(stopped=True)), 1)
|
|
|
+
|
|
|
+ project.remove_stopped()
|
|
|
+ self.assertEqual(len(project.containers(stopped=True)), 0)
|