Refactor network_mode logic out of Service.
Signed-off-by: Daniel Nephin <dnephin@docker.com>
This commit is contained in:
parent
c183e52502
commit
187ad4ce26
4 changed files with 116 additions and 37 deletions
|
|
@ -221,7 +221,7 @@ class ProjectTest(unittest.TestCase):
|
|||
}
|
||||
], self.mock_client)
|
||||
service = project.get_service('test')
|
||||
self.assertEqual(service._get_net(), None)
|
||||
self.assertEqual(service.net.id, None)
|
||||
self.assertNotIn('NetworkMode', service._get_container_host_config({}))
|
||||
|
||||
def test_use_net_from_container(self):
|
||||
|
|
@ -236,7 +236,7 @@ class ProjectTest(unittest.TestCase):
|
|||
}
|
||||
], self.mock_client)
|
||||
service = project.get_service('test')
|
||||
self.assertEqual(service._get_net(), 'container:' + container_id)
|
||||
self.assertEqual(service.net.mode, 'container:' + container_id)
|
||||
|
||||
def test_use_net_from_service(self):
|
||||
container_name = 'test_aaa_1'
|
||||
|
|
@ -261,7 +261,7 @@ class ProjectTest(unittest.TestCase):
|
|||
], self.mock_client)
|
||||
|
||||
service = project.get_service('test')
|
||||
self.assertEqual(service._get_net(), 'container:' + container_name)
|
||||
self.assertEqual(service.net.mode, 'container:' + container_name)
|
||||
|
||||
def test_container_without_name(self):
|
||||
self.mock_client.containers.return_value = [
|
||||
|
|
|
|||
|
|
@ -13,13 +13,16 @@ from compose.const import LABEL_SERVICE
|
|||
from compose.container import Container
|
||||
from compose.service import build_volume_binding
|
||||
from compose.service import ConfigError
|
||||
from compose.service import ContainerNet
|
||||
from compose.service import get_container_data_volumes
|
||||
from compose.service import merge_volume_bindings
|
||||
from compose.service import NeedsBuildError
|
||||
from compose.service import Net
|
||||
from compose.service import NoSuchImageError
|
||||
from compose.service import parse_repository_tag
|
||||
from compose.service import parse_volume_spec
|
||||
from compose.service import Service
|
||||
from compose.service import ServiceNet
|
||||
|
||||
|
||||
class ServiceTest(unittest.TestCase):
|
||||
|
|
@ -337,7 +340,7 @@ class ServiceTest(unittest.TestCase):
|
|||
'foo',
|
||||
image='example.com/foo',
|
||||
client=self.mock_client,
|
||||
net=Service('other'),
|
||||
net=ServiceNet(Service('other')),
|
||||
links=[(Service('one'), 'one')],
|
||||
volumes_from=[Service('two')])
|
||||
|
||||
|
|
@ -373,6 +376,49 @@ class ServiceTest(unittest.TestCase):
|
|||
self.assertEqual(config_dict, expected)
|
||||
|
||||
|
||||
class NetTestCase(unittest.TestCase):
|
||||
|
||||
def test_net(self):
|
||||
net = Net('host')
|
||||
self.assertEqual(net.id, 'host')
|
||||
self.assertEqual(net.mode, 'host')
|
||||
self.assertEqual(net.service_name, None)
|
||||
|
||||
def test_net_container(self):
|
||||
container_id = 'abcd'
|
||||
net = ContainerNet(Container(None, {'Id': container_id}))
|
||||
self.assertEqual(net.id, container_id)
|
||||
self.assertEqual(net.mode, 'container:' + container_id)
|
||||
self.assertEqual(net.service_name, None)
|
||||
|
||||
def test_net_service(self):
|
||||
container_id = 'bbbb'
|
||||
service_name = 'web'
|
||||
mock_client = mock.create_autospec(docker.Client)
|
||||
mock_client.containers.return_value = [
|
||||
{'Id': container_id, 'Name': container_id, 'Image': 'abcd'},
|
||||
]
|
||||
|
||||
service = Service(name=service_name, client=mock_client)
|
||||
net = ServiceNet(service)
|
||||
|
||||
self.assertEqual(net.id, service_name)
|
||||
self.assertEqual(net.mode, 'container:' + container_id)
|
||||
self.assertEqual(net.service_name, service_name)
|
||||
|
||||
def test_net_service_no_containers(self):
|
||||
service_name = 'web'
|
||||
mock_client = mock.create_autospec(docker.Client)
|
||||
mock_client.containers.return_value = []
|
||||
|
||||
service = Service(name=service_name, client=mock_client)
|
||||
net = ServiceNet(service)
|
||||
|
||||
self.assertEqual(net.id, service_name)
|
||||
self.assertEqual(net.mode, None)
|
||||
self.assertEqual(net.service_name, service_name)
|
||||
|
||||
|
||||
def mock_get_image(images):
|
||||
if images:
|
||||
return images[0]
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue