2015-07-03 14:35:54 +02:00
|
|
|
import unittest
|
|
|
|
|
2015-05-30 22:17:21 +02:00
|
|
|
from docker.errors import APIError
|
|
|
|
|
2015-05-21 12:25:06 +02:00
|
|
|
from compose import legacy
|
|
|
|
from compose.project import Project
|
|
|
|
from .testcases import DockerClientTestCase
|
|
|
|
|
|
|
|
|
2015-07-03 14:35:54 +02:00
|
|
|
class UtilitiesTestCase(unittest.TestCase):
|
|
|
|
def test_has_container(self):
|
|
|
|
self.assertTrue(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_web_1", one_off=False),
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_web_run_1", one_off=False),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_has_container_one_off(self):
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_web_1", one_off=True),
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_web_run_1", one_off=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_has_container_different_project(self):
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "otherapp_web_1", one_off=False),
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "otherapp_web_run_1", one_off=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_has_container_different_service(self):
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_db_1", one_off=False),
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.has_container("composetest", "web", "composetest_db_run_1", one_off=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_is_valid_name(self):
|
|
|
|
self.assertTrue(
|
|
|
|
legacy.is_valid_name("composetest_web_1", one_off=False),
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.is_valid_name("composetest_web_run_1", one_off=False),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_is_valid_name_one_off(self):
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.is_valid_name("composetest_web_1", one_off=True),
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
legacy.is_valid_name("composetest_web_run_1", one_off=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_is_valid_name_invalid(self):
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.is_valid_name("foo"),
|
|
|
|
)
|
|
|
|
self.assertFalse(
|
|
|
|
legacy.is_valid_name("composetest_web_lol_1", one_off=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2015-05-30 22:17:21 +02:00
|
|
|
class LegacyTestCase(DockerClientTestCase):
|
2015-05-21 12:25:06 +02:00
|
|
|
|
2015-05-21 13:12:02 +02:00
|
|
|
def setUp(self):
|
2015-05-30 22:17:21 +02:00
|
|
|
super(LegacyTestCase, self).setUp()
|
|
|
|
self.containers = []
|
2015-05-21 13:12:02 +02:00
|
|
|
|
2015-05-21 17:09:06 +02:00
|
|
|
db = self.create_service('db')
|
|
|
|
web = self.create_service('web', links=[(db, 'db')])
|
|
|
|
nginx = self.create_service('nginx', links=[(web, 'web')])
|
2015-05-21 12:25:06 +02:00
|
|
|
|
2015-05-21 17:09:06 +02:00
|
|
|
self.services = [db, web, nginx]
|
2015-05-21 13:12:02 +02:00
|
|
|
self.project = Project('composetest', self.services, self.client)
|
2015-05-21 12:25:06 +02:00
|
|
|
|
2015-05-21 13:12:30 +02:00
|
|
|
# Create a legacy container for each service
|
2015-05-21 13:12:02 +02:00
|
|
|
for service in self.services:
|
2015-05-21 12:25:06 +02:00
|
|
|
service.ensure_image_exists()
|
2015-05-21 17:09:06 +02:00
|
|
|
container = self.client.create_container(
|
2015-05-21 13:12:02 +02:00
|
|
|
name='{}_{}_1'.format(self.project.name, service.name),
|
2015-05-21 12:25:06 +02:00
|
|
|
**service.options
|
|
|
|
)
|
2015-05-21 17:09:06 +02:00
|
|
|
self.client.start(container)
|
2015-05-30 22:17:21 +02:00
|
|
|
self.containers.append(container)
|
2015-05-21 12:25:06 +02:00
|
|
|
|
2015-05-21 13:12:30 +02:00
|
|
|
# Create a single one-off legacy container
|
2015-05-30 22:17:21 +02:00
|
|
|
self.containers.append(self.client.create_container(
|
2015-07-03 14:35:54 +02:00
|
|
|
name='{}_{}_run_1'.format(self.project.name, db.name),
|
2015-05-21 13:12:30 +02:00
|
|
|
**self.services[0].options
|
2015-05-30 22:17:21 +02:00
|
|
|
))
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
super(LegacyTestCase, self).tearDown()
|
|
|
|
for container in self.containers:
|
|
|
|
try:
|
|
|
|
self.client.kill(container)
|
|
|
|
except APIError:
|
|
|
|
pass
|
|
|
|
try:
|
|
|
|
self.client.remove_container(container)
|
|
|
|
except APIError:
|
|
|
|
pass
|
2015-05-21 13:12:30 +02:00
|
|
|
|
2015-05-21 17:09:06 +02:00
|
|
|
def get_legacy_containers(self, **kwargs):
|
2015-07-03 14:35:54 +02:00
|
|
|
return legacy.get_legacy_containers(
|
2015-05-21 13:12:02 +02:00
|
|
|
self.client,
|
|
|
|
self.project.name,
|
|
|
|
[s.name for s in self.services],
|
|
|
|
**kwargs
|
2015-07-03 14:35:54 +02:00
|
|
|
)
|
2015-05-21 13:12:02 +02:00
|
|
|
|
|
|
|
def test_get_legacy_container_names(self):
|
2015-05-21 17:09:06 +02:00
|
|
|
self.assertEqual(len(self.get_legacy_containers()), len(self.services))
|
2015-05-21 13:12:02 +02:00
|
|
|
|
2015-05-21 13:12:30 +02:00
|
|
|
def test_get_legacy_container_names_one_off(self):
|
2015-07-03 14:35:54 +02:00
|
|
|
self.assertEqual(len(self.get_legacy_containers(one_off=True)), 1)
|
2015-05-21 13:12:30 +02:00
|
|
|
|
2015-05-21 13:12:02 +02:00
|
|
|
def test_migration_to_labels(self):
|
2015-07-03 14:35:54 +02:00
|
|
|
# Trying to get the container list raises an exception
|
|
|
|
|
2015-05-21 13:41:36 +02:00
|
|
|
with self.assertRaises(legacy.LegacyContainersError) as cm:
|
2015-07-03 14:35:54 +02:00
|
|
|
self.project.containers(stopped=True)
|
2015-05-21 13:41:36 +02:00
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
set(cm.exception.names),
|
2015-05-21 17:09:06 +02:00
|
|
|
set(['composetest_db_1', 'composetest_web_1', 'composetest_nginx_1']),
|
2015-05-21 13:41:36 +02:00
|
|
|
)
|
2015-05-21 12:25:06 +02:00
|
|
|
|
2015-07-03 14:35:54 +02:00
|
|
|
self.assertEqual(
|
|
|
|
set(cm.exception.one_off_names),
|
|
|
|
set(['composetest_db_run_1']),
|
|
|
|
)
|
|
|
|
|
|
|
|
# Migrate the containers
|
|
|
|
|
2015-05-21 13:12:02 +02:00
|
|
|
legacy.migrate_project_to_labels(self.project)
|
2015-07-03 14:35:54 +02:00
|
|
|
|
|
|
|
# Getting the list no longer raises an exception
|
|
|
|
|
|
|
|
containers = self.project.containers(stopped=True)
|
|
|
|
self.assertEqual(len(containers), len(self.services))
|
|
|
|
|
|
|
|
def test_migration_one_off(self):
|
|
|
|
# We've already migrated
|
|
|
|
|
|
|
|
legacy.migrate_project_to_labels(self.project)
|
|
|
|
|
|
|
|
# Trying to create a one-off container results in a Docker API error
|
|
|
|
|
|
|
|
with self.assertRaises(APIError) as cm:
|
|
|
|
self.project.get_service('db').create_container(one_off=True)
|
|
|
|
|
|
|
|
# Checking for legacy one-off containers raises an exception
|
|
|
|
|
|
|
|
with self.assertRaises(legacy.LegacyOneOffContainersError) as cm:
|
|
|
|
legacy.check_for_legacy_containers(
|
|
|
|
self.client,
|
|
|
|
self.project.name,
|
|
|
|
['db'],
|
|
|
|
allow_one_off=False,
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
set(cm.exception.one_off_names),
|
|
|
|
set(['composetest_db_run_1']),
|
|
|
|
)
|
|
|
|
|
|
|
|
# Remove the old one-off container
|
|
|
|
|
|
|
|
c = self.client.inspect_container('composetest_db_run_1')
|
|
|
|
self.client.remove_container(c)
|
|
|
|
|
|
|
|
# Checking no longer raises an exception
|
|
|
|
|
|
|
|
legacy.check_for_legacy_containers(
|
|
|
|
self.client,
|
|
|
|
self.project.name,
|
|
|
|
['db'],
|
|
|
|
allow_one_off=False,
|
|
|
|
)
|
|
|
|
|
|
|
|
# Creating a one-off container no longer results in an API error
|
|
|
|
|
|
|
|
self.project.get_service('db').create_container(one_off=True)
|
|
|
|
self.assertIsInstance(self.client.inspect_container('composetest_db_run_1'), dict)
|