|
@@ -39,6 +39,47 @@ class ConfigTest(unittest.TestCase):
|
|
|
config.make_service_dict('foo', {'ports': ['8000']})
|
|
|
|
|
|
|
|
|
+class MergeTest(unittest.TestCase):
|
|
|
+ def test_merge_volumes_empty(self):
|
|
|
+ service_dict = config.merge_service_dicts({}, {})
|
|
|
+ self.assertNotIn('volumes', service_dict)
|
|
|
+
|
|
|
+ def test_merge_volumes_no_override(self):
|
|
|
+ service_dict = config.merge_service_dicts(
|
|
|
+ {'volumes': ['/foo:/code', '/data']},
|
|
|
+ {},
|
|
|
+ )
|
|
|
+ self.assertEqual(set(service_dict['volumes']), set(['/foo:/code', '/data']))
|
|
|
+
|
|
|
+ def test_merge_volumes_no_base(self):
|
|
|
+ service_dict = config.merge_service_dicts(
|
|
|
+ {},
|
|
|
+ {'volumes': ['/bar:/code']},
|
|
|
+ )
|
|
|
+ self.assertEqual(set(service_dict['volumes']), set(['/bar:/code']))
|
|
|
+
|
|
|
+ def test_merge_volumes_override_explicit_path(self):
|
|
|
+ service_dict = config.merge_service_dicts(
|
|
|
+ {'volumes': ['/foo:/code', '/data']},
|
|
|
+ {'volumes': ['/bar:/code']},
|
|
|
+ )
|
|
|
+ self.assertEqual(set(service_dict['volumes']), set(['/bar:/code', '/data']))
|
|
|
+
|
|
|
+ def test_merge_volumes_add_explicit_path(self):
|
|
|
+ service_dict = config.merge_service_dicts(
|
|
|
+ {'volumes': ['/foo:/code', '/data']},
|
|
|
+ {'volumes': ['/bar:/code', '/quux:/data']},
|
|
|
+ )
|
|
|
+ self.assertEqual(set(service_dict['volumes']), set(['/bar:/code', '/quux:/data']))
|
|
|
+
|
|
|
+ def test_merge_volumes_remove_explicit_path(self):
|
|
|
+ service_dict = config.merge_service_dicts(
|
|
|
+ {'volumes': ['/foo:/code', '/quux:/data']},
|
|
|
+ {'volumes': ['/bar:/code', '/data']},
|
|
|
+ )
|
|
|
+ self.assertEqual(set(service_dict['volumes']), set(['/bar:/code', '/data']))
|
|
|
+
|
|
|
+
|
|
|
class EnvTest(unittest.TestCase):
|
|
|
def test_parse_environment_as_list(self):
|
|
|
environment =[
|