mirror of
https://github.com/docker/compose.git
synced 2025-07-27 07:34:10 +02:00
Namespace tests inside a project
So it doesn't delete all your containers for every test. Cool.
This commit is contained in:
parent
17c6ae067a
commit
853d8ad280
@ -4,7 +4,7 @@ from .testcases import DockerClientTestCase
|
|||||||
|
|
||||||
class ProjectTest(DockerClientTestCase):
|
class ProjectTest(DockerClientTestCase):
|
||||||
def test_from_dict(self):
|
def test_from_dict(self):
|
||||||
project = Project.from_dicts('test', [
|
project = Project.from_dicts('figtest', [
|
||||||
{
|
{
|
||||||
'name': 'web',
|
'name': 'web',
|
||||||
'image': 'ubuntu'
|
'image': 'ubuntu'
|
||||||
@ -21,7 +21,7 @@ class ProjectTest(DockerClientTestCase):
|
|||||||
self.assertEqual(project.get_service('db').options['image'], 'ubuntu')
|
self.assertEqual(project.get_service('db').options['image'], 'ubuntu')
|
||||||
|
|
||||||
def test_from_dict_sorts_in_dependency_order(self):
|
def test_from_dict_sorts_in_dependency_order(self):
|
||||||
project = Project.from_dicts('test', [
|
project = Project.from_dicts('figtest', [
|
||||||
{
|
{
|
||||||
'name': 'web',
|
'name': 'web',
|
||||||
'image': 'ubuntu',
|
'image': 'ubuntu',
|
||||||
@ -57,7 +57,7 @@ class ProjectTest(DockerClientTestCase):
|
|||||||
def test_start_stop_kill_remove(self):
|
def test_start_stop_kill_remove(self):
|
||||||
web = self.create_service('web')
|
web = self.create_service('web')
|
||||||
db = self.create_service('db')
|
db = self.create_service('db')
|
||||||
project = Project('test', [web, db], self.client)
|
project = Project('figtest', [web, db], self.client)
|
||||||
|
|
||||||
project.start()
|
project.start()
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
foo.start_container()
|
foo.start_container()
|
||||||
|
|
||||||
self.assertEqual(len(foo.containers()), 1)
|
self.assertEqual(len(foo.containers()), 1)
|
||||||
self.assertEqual(foo.containers()[0].name, 'default_foo_1')
|
self.assertEqual(foo.containers()[0].name, 'figtest_foo_1')
|
||||||
self.assertEqual(len(bar.containers()), 0)
|
self.assertEqual(len(bar.containers()), 0)
|
||||||
|
|
||||||
bar.start_container()
|
bar.start_container()
|
||||||
@ -39,8 +39,8 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
self.assertEqual(len(bar.containers()), 2)
|
self.assertEqual(len(bar.containers()), 2)
|
||||||
|
|
||||||
names = [c.name for c in bar.containers()]
|
names = [c.name for c in bar.containers()]
|
||||||
self.assertIn('default_bar_1', names)
|
self.assertIn('figtest_bar_1', names)
|
||||||
self.assertIn('default_bar_2', names)
|
self.assertIn('figtest_bar_2', names)
|
||||||
|
|
||||||
def test_containers_one_off(self):
|
def test_containers_one_off(self):
|
||||||
db = self.create_service('db')
|
db = self.create_service('db')
|
||||||
@ -49,9 +49,9 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
self.assertEqual(db.containers(one_off=True, stopped=True), [container])
|
self.assertEqual(db.containers(one_off=True, stopped=True), [container])
|
||||||
|
|
||||||
def test_project_is_added_to_container_name(self):
|
def test_project_is_added_to_container_name(self):
|
||||||
service = self.create_service('web', project='myproject')
|
service = self.create_service('web')
|
||||||
service.start_container()
|
service.start_container()
|
||||||
self.assertEqual(service.containers()[0].name, 'myproject_web_1')
|
self.assertEqual(service.containers()[0].name, 'figtest_web_1')
|
||||||
|
|
||||||
def test_start_stop(self):
|
def test_start_stop(self):
|
||||||
service = self.create_service('scalingtest')
|
service = self.create_service('scalingtest')
|
||||||
@ -92,13 +92,13 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
def test_create_container_with_one_off(self):
|
def test_create_container_with_one_off(self):
|
||||||
db = self.create_service('db')
|
db = self.create_service('db')
|
||||||
container = db.create_container(one_off=True)
|
container = db.create_container(one_off=True)
|
||||||
self.assertEqual(container.name, 'default_db_run_1')
|
self.assertEqual(container.name, 'figtest_db_run_1')
|
||||||
|
|
||||||
def test_create_container_with_one_off_when_existing_container_is_running(self):
|
def test_create_container_with_one_off_when_existing_container_is_running(self):
|
||||||
db = self.create_service('db')
|
db = self.create_service('db')
|
||||||
db.start()
|
db.start()
|
||||||
container = db.create_container(one_off=True)
|
container = db.create_container(one_off=True)
|
||||||
self.assertEqual(container.name, 'default_db_run_1')
|
self.assertEqual(container.name, 'figtest_db_run_1')
|
||||||
|
|
||||||
def test_start_container_passes_through_options(self):
|
def test_start_container_passes_through_options(self):
|
||||||
db = self.create_service('db')
|
db = self.create_service('db')
|
||||||
@ -115,7 +115,7 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
web = self.create_service('web', links=[db])
|
web = self.create_service('web', links=[db])
|
||||||
db.start_container()
|
db.start_container()
|
||||||
web.start_container()
|
web.start_container()
|
||||||
self.assertIn('default_db_1', web.containers()[0].links())
|
self.assertIn('figtest_db_1', web.containers()[0].links())
|
||||||
db.stop(timeout=1)
|
db.stop(timeout=1)
|
||||||
web.stop(timeout=1)
|
web.stop(timeout=1)
|
||||||
|
|
||||||
@ -124,18 +124,20 @@ class ServiceTest(DockerClientTestCase):
|
|||||||
name='test',
|
name='test',
|
||||||
client=self.client,
|
client=self.client,
|
||||||
build='tests/fixtures/simple-dockerfile',
|
build='tests/fixtures/simple-dockerfile',
|
||||||
|
project='figtest',
|
||||||
)
|
)
|
||||||
container = service.start_container()
|
container = service.start_container()
|
||||||
container.wait()
|
container.wait()
|
||||||
self.assertIn('success', container.logs())
|
self.assertIn('success', container.logs())
|
||||||
self.assertEqual(len(self.client.images(name='default_test')), 1)
|
self.assertEqual(len(self.client.images(name='figtest_test')), 1)
|
||||||
|
|
||||||
def test_start_container_uses_tagged_image_if_it_exists(self):
|
def test_start_container_uses_tagged_image_if_it_exists(self):
|
||||||
self.client.build('tests/fixtures/simple-dockerfile', tag='default_test')
|
self.client.build('tests/fixtures/simple-dockerfile', tag='figtest_test')
|
||||||
service = Service(
|
service = Service(
|
||||||
name='test',
|
name='test',
|
||||||
client=self.client,
|
client=self.client,
|
||||||
build='this/does/not/exist/and/will/throw/error',
|
build='this/does/not/exist/and/will/throw/error',
|
||||||
|
project='figtest',
|
||||||
)
|
)
|
||||||
container = service.start_container()
|
container = service.start_container()
|
||||||
container.wait()
|
container.wait()
|
||||||
|
@ -12,11 +12,13 @@ class DockerClientTestCase(TestCase):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
for c in self.client.containers(all=True):
|
for c in self.client.containers(all=True):
|
||||||
self.client.kill(c['Id'])
|
if c['Names'] and 'figtest' in c['Names'][0]:
|
||||||
self.client.remove_container(c['Id'])
|
self.client.kill(c['Id'])
|
||||||
|
self.client.remove_container(c['Id'])
|
||||||
|
|
||||||
def create_service(self, name, **kwargs):
|
def create_service(self, name, **kwargs):
|
||||||
return Service(
|
return Service(
|
||||||
|
project='figtest',
|
||||||
name=name,
|
name=name,
|
||||||
client=self.client,
|
client=self.client,
|
||||||
image="ubuntu",
|
image="ubuntu",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user