Tag v2-only tests

- Don't run them against Engine < 1.10
- Set the API version appropriately for the Engine version, so all tests
  use API version 1.22 against Engine 1.10

Signed-off-by: Aanand Prasad <aanand.prasad@gmail.com>
This commit is contained in:
Aanand Prasad 2016-01-15 00:10:57 +00:00
parent abd031cb3d
commit 406b6b28f4
3 changed files with 49 additions and 1 deletions

View File

@ -20,6 +20,7 @@ from compose.container import Container
from tests.integration.testcases import DockerClientTestCase from tests.integration.testcases import DockerClientTestCase
from tests.integration.testcases import get_links from tests.integration.testcases import get_links
from tests.integration.testcases import pull_busybox from tests.integration.testcases import pull_busybox
from tests.integration.testcases import v2_only
ProcessResult = namedtuple('ProcessResult', 'stdout stderr') ProcessResult = namedtuple('ProcessResult', 'stdout stderr')
@ -388,6 +389,7 @@ class CLITestCase(DockerClientTestCase):
assert 'simple_1 | simple' in result.stdout assert 'simple_1 | simple' in result.stdout
assert 'another_1 | another' in result.stdout assert 'another_1 | another' in result.stdout
@v2_only()
def test_up(self): def test_up(self):
self.base_dir = 'tests/fixtures/v2-simple' self.base_dir = 'tests/fixtures/v2-simple'
self.dispatch(['up', '-d'], None) self.dispatch(['up', '-d'], None)
@ -413,6 +415,7 @@ class CLITestCase(DockerClientTestCase):
for service in services: for service in services:
assert self.lookup(container, service.name) assert self.lookup(container, service.name)
@v2_only()
def test_up_with_networks(self): def test_up_with_networks(self):
self.base_dir = 'tests/fixtures/networks' self.base_dir = 'tests/fixtures/networks'
self.dispatch(['up', '-d'], None) self.dispatch(['up', '-d'], None)
@ -448,6 +451,7 @@ class CLITestCase(DockerClientTestCase):
# app can see db # app can see db
assert self.lookup(app_container, "db") assert self.lookup(app_container, "db")
@v2_only()
def test_up_missing_network(self): def test_up_missing_network(self):
self.base_dir = 'tests/fixtures/networks' self.base_dir = 'tests/fixtures/networks'
@ -457,6 +461,7 @@ class CLITestCase(DockerClientTestCase):
assert 'Service "web" uses an undefined network "foo"' in result.stderr assert 'Service "web" uses an undefined network "foo"' in result.stderr
@v2_only()
def test_up_predefined_networks(self): def test_up_predefined_networks(self):
filename = 'predefined-networks.yml' filename = 'predefined-networks.yml'
@ -476,6 +481,7 @@ class CLITestCase(DockerClientTestCase):
assert list(container.get('NetworkSettings.Networks')) == [name] assert list(container.get('NetworkSettings.Networks')) == [name]
assert container.get('HostConfig.NetworkMode') == name assert container.get('HostConfig.NetworkMode') == name
@v2_only()
def test_up_external_networks(self): def test_up_external_networks(self):
filename = 'external-networks.yml' filename = 'external-networks.yml'
@ -499,6 +505,7 @@ class CLITestCase(DockerClientTestCase):
container = self.project.containers()[0] container = self.project.containers()[0]
assert sorted(list(container.get('NetworkSettings.Networks'))) == sorted(network_names) assert sorted(list(container.get('NetworkSettings.Networks'))) == sorted(network_names)
@v2_only()
def test_up_no_services(self): def test_up_no_services(self):
self.base_dir = 'tests/fixtures/no-services' self.base_dir = 'tests/fixtures/no-services'
self.dispatch(['up', '-d'], None) self.dispatch(['up', '-d'], None)
@ -513,6 +520,7 @@ class CLITestCase(DockerClientTestCase):
for name in ['bar', 'foo'] for name in ['bar', 'foo']
] ]
@v2_only()
def test_up_with_links_is_invalid(self): def test_up_with_links_is_invalid(self):
self.base_dir = 'tests/fixtures/v2-simple' self.base_dir = 'tests/fixtures/v2-simple'
@ -853,6 +861,7 @@ class CLITestCase(DockerClientTestCase):
container, = service.containers(stopped=True, one_off=True) container, = service.containers(stopped=True, one_off=True)
self.assertEqual(container.name, name) self.assertEqual(container.name, name)
@v2_only()
def test_run_with_networking(self): def test_run_with_networking(self):
self.base_dir = 'tests/fixtures/v2-simple' self.base_dir = 'tests/fixtures/v2-simple'
self.dispatch(['run', 'simple', 'true'], None) self.dispatch(['run', 'simple', 'true'], None)

View File

@ -14,6 +14,7 @@ from compose.const import LABEL_PROJECT
from compose.container import Container from compose.container import Container
from compose.project import Project from compose.project import Project
from compose.service import ConvergenceStrategy from compose.service import ConvergenceStrategy
from tests.integration.testcases import v2_only
def build_service_dicts(service_config): def build_service_dicts(service_config):
@ -482,6 +483,7 @@ class ProjectTest(DockerClientTestCase):
service = project.get_service('web') service = project.get_service('web')
self.assertEqual(len(service.containers()), 1) self.assertEqual(len(service.containers()), 1)
@v2_only()
def test_project_up_networks(self): def test_project_up_networks(self):
config_data = config.Config( config_data = config.Config(
version=2, version=2,
@ -514,6 +516,7 @@ class ProjectTest(DockerClientTestCase):
foo_data = self.client.inspect_network('composetest_foo') foo_data = self.client.inspect_network('composetest_foo')
self.assertEqual(foo_data['Driver'], 'bridge') self.assertEqual(foo_data['Driver'], 'bridge')
@v2_only()
def test_project_up_volumes(self): def test_project_up_volumes(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))
full_vol_name = 'composetest_{0}'.format(vol_name) full_vol_name = 'composetest_{0}'.format(vol_name)
@ -539,6 +542,7 @@ class ProjectTest(DockerClientTestCase):
self.assertEqual(volume_data['Name'], full_vol_name) self.assertEqual(volume_data['Name'], full_vol_name)
self.assertEqual(volume_data['Driver'], 'local') self.assertEqual(volume_data['Driver'], 'local')
@v2_only()
def test_project_up_logging_with_multiple_files(self): def test_project_up_logging_with_multiple_files(self):
base_file = config.ConfigFile( base_file = config.ConfigFile(
'base.yml', 'base.yml',
@ -590,6 +594,7 @@ class ProjectTest(DockerClientTestCase):
self.assertTrue(log_config) self.assertTrue(log_config)
self.assertEqual(log_config.get('Type'), 'none') self.assertEqual(log_config.get('Type'), 'none')
@v2_only()
def test_initialize_volumes(self): def test_initialize_volumes(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))
full_vol_name = 'composetest_{0}'.format(vol_name) full_vol_name = 'composetest_{0}'.format(vol_name)
@ -614,6 +619,7 @@ class ProjectTest(DockerClientTestCase):
self.assertEqual(volume_data['Name'], full_vol_name) self.assertEqual(volume_data['Name'], full_vol_name)
self.assertEqual(volume_data['Driver'], 'local') self.assertEqual(volume_data['Driver'], 'local')
@v2_only()
def test_project_up_implicit_volume_driver(self): def test_project_up_implicit_volume_driver(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))
full_vol_name = 'composetest_{0}'.format(vol_name) full_vol_name = 'composetest_{0}'.format(vol_name)
@ -638,6 +644,7 @@ class ProjectTest(DockerClientTestCase):
self.assertEqual(volume_data['Name'], full_vol_name) self.assertEqual(volume_data['Name'], full_vol_name)
self.assertEqual(volume_data['Driver'], 'local') self.assertEqual(volume_data['Driver'], 'local')
@v2_only()
def test_initialize_volumes_invalid_volume_driver(self): def test_initialize_volumes_invalid_volume_driver(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))
@ -659,6 +666,7 @@ class ProjectTest(DockerClientTestCase):
with self.assertRaises(config.ConfigurationError): with self.assertRaises(config.ConfigurationError):
project.initialize_volumes() project.initialize_volumes()
@v2_only()
def test_initialize_volumes_updated_driver(self): def test_initialize_volumes_updated_driver(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))
full_vol_name = 'composetest_{0}'.format(vol_name) full_vol_name = 'composetest_{0}'.format(vol_name)
@ -696,6 +704,7 @@ class ProjectTest(DockerClientTestCase):
vol_name vol_name
) in str(e.exception) ) in str(e.exception)
@v2_only()
def test_initialize_volumes_external_volumes(self): def test_initialize_volumes_external_volumes(self):
# Use composetest_ prefix so it gets garbage-collected in tearDown() # Use composetest_ prefix so it gets garbage-collected in tearDown()
vol_name = 'composetest_{0:x}'.format(random.getrandbits(32)) vol_name = 'composetest_{0:x}'.format(random.getrandbits(32))
@ -722,6 +731,7 @@ class ProjectTest(DockerClientTestCase):
with self.assertRaises(NotFound): with self.assertRaises(NotFound):
self.client.inspect_volume(full_vol_name) self.client.inspect_volume(full_vol_name)
@v2_only()
def test_initialize_volumes_inexistent_external_volume(self): def test_initialize_volumes_inexistent_external_volume(self):
vol_name = '{0:x}'.format(random.getrandbits(32)) vol_name = '{0:x}'.format(random.getrandbits(32))

View File

@ -1,12 +1,16 @@
from __future__ import absolute_import from __future__ import absolute_import
from __future__ import unicode_literals from __future__ import unicode_literals
import functools
import os
from docker.utils import version_lt from docker.utils import version_lt
from pytest import skip from pytest import skip
from .. import unittest from .. import unittest
from compose.cli.docker_client import docker_client from compose.cli.docker_client import docker_client
from compose.config.config import resolve_environment from compose.config.config import resolve_environment
from compose.const import API_VERSIONS
from compose.const import LABEL_PROJECT from compose.const import LABEL_PROJECT
from compose.progress_stream import stream_output from compose.progress_stream import stream_output
from compose.service import Service from compose.service import Service
@ -26,10 +30,35 @@ def get_links(container):
return [format_link(link) for link in links] return [format_link(link) for link in links]
def engine_version_too_low_for_v2():
if 'DOCKER_VERSION' not in os.environ:
return False
version = os.environ['DOCKER_VERSION'].partition('-')[0]
return version_lt(version, '1.10')
def v2_only():
def decorator(f):
@functools.wraps(f)
def wrapper(self, *args, **kwargs):
if engine_version_too_low_for_v2():
skip("Engine version is too low")
return
return f(self, *args, **kwargs)
return wrapper
return decorator
class DockerClientTestCase(unittest.TestCase): class DockerClientTestCase(unittest.TestCase):
@classmethod @classmethod
def setUpClass(cls): def setUpClass(cls):
cls.client = docker_client() if engine_version_too_low_for_v2():
version = API_VERSIONS[1]
else:
version = API_VERSIONS[2]
cls.client = docker_client(version)
def tearDown(self): def tearDown(self):
for c in self.client.containers( for c in self.client.containers(