summaryrefslogtreecommitdiff
path: root/morphlib/morphloader_tests.py
diff options
context:
space:
mode:
Diffstat (limited to 'morphlib/morphloader_tests.py')
-rw-r--r--morphlib/morphloader_tests.py169
1 files changed, 135 insertions, 34 deletions
diff --git a/morphlib/morphloader_tests.py b/morphlib/morphloader_tests.py
index f38d58e8..8b87467a 100644
--- a/morphlib/morphloader_tests.py
+++ b/morphlib/morphloader_tests.py
@@ -99,6 +99,9 @@ build-system: dummy
'kind': 'system',
'name': 'foo',
'arch': 'x86_64',
+ 'strata': [
+ {'morph': 'bar'},
+ ],
'system-kind': 'foo',
})
self.assertRaises(
@@ -109,6 +112,9 @@ build-system: dummy
'kind': 'system',
'name': 'foo',
'arch': 'x86_64',
+ 'strata': [
+ {'morph': 'bar'},
+ ],
'disk-size': 'over 9000',
})
self.assertRaises(
@@ -122,12 +128,14 @@ build-system: dummy
morphlib.morphloader.MissingFieldError, self.loader.validate, m)
def test_fails_to_validate_system_with_invalid_field(self):
- m = morphlib.morph3.Morphology({
- 'kind': 'system',
- 'name': 'name',
- 'arch': 'x86_64',
- 'invalid': 'field',
- })
+ m = morphlib.morph3.Morphology(
+ kind="system",
+ name="foo",
+ arch="blah",
+ strata=[
+ {'morph': 'bar'},
+ ],
+ invalid='field')
self.assertRaises(
morphlib.morphloader.InvalidFieldError, self.loader.validate, m)
@@ -157,7 +165,8 @@ build-system: dummy
}
]
})
- self.assertRaises(ValueError, self.loader.validate, m)
+ self.assertRaises(morphlib.morphloader.DuplicateStratumError,
+ self.loader.validate, m)
def test_validate_requires_unique_chunk_names_within_a_stratum(self):
m = morphlib.morph3.Morphology(
@@ -177,28 +186,29 @@ build-system: dummy
}
]
})
- self.assertRaises(ValueError, self.loader.validate, m)
+ self.assertRaises(morphlib.morphloader.DuplicateChunkError,
+ self.loader.validate, m)
def test_validate_requires_a_valid_architecture(self):
m = morphlib.morph3.Morphology(
- {
- "kind": "system",
- "name": "foo",
- "arch": "blah",
- "strata": [],
- })
+ kind="system",
+ name="foo",
+ arch="blah",
+ strata=[
+ {'morph': 'bar'},
+ ])
self.assertRaises(
morphlib.morphloader.UnknownArchitectureError,
self.loader.validate, m)
def test_validate_normalises_architecture_armv7_to_armv7l(self):
m = morphlib.morph3.Morphology(
- {
- "kind": "system",
- "name": "foo",
- "arch": "armv7",
- "strata": [],
- })
+ kind="system",
+ name="foo",
+ arch="armv7",
+ strata=[
+ {'morph': 'bar'},
+ ])
self.loader.validate(m)
self.assertEqual(m['arch'], 'armv7l')
@@ -274,6 +284,50 @@ build-system: dummy
morphlib.morphloader.EmptyStratumError,
self.loader.validate, m)
+ def test_validate_requires_strata_in_system(self):
+ m = morphlib.morph3.Morphology(
+ name='system',
+ kind='system',
+ arch='testarch')
+ self.assertRaises(
+ morphlib.morphloader.MissingFieldError,
+ self.loader.validate, m)
+
+ def test_validate_requires_list_of_strata_in_system(self):
+ for v in (None, {}):
+ m = morphlib.morph3.Morphology(
+ name='system',
+ kind='system',
+ arch='testarch',
+ strata=v)
+ with self.assertRaises(
+ morphlib.morphloader.SystemStrataNotListError) as cm:
+
+ self.loader.validate(m)
+ self.assertEqual(cm.exception.strata_type, type(v))
+
+ def test_validate_requires_non_empty_strata_in_system(self):
+ m = morphlib.morph3.Morphology(
+ name='system',
+ kind='system',
+ arch='testarch',
+ strata=[])
+ self.assertRaises(
+ morphlib.morphloader.EmptySystemError,
+ self.loader.validate, m)
+
+ def test_validate_requires_stratum_specs_in_system(self):
+ m = morphlib.morph3.Morphology(
+ name='system',
+ kind='system',
+ arch='testarch',
+ strata=["foo"])
+ with self.assertRaises(
+ morphlib.morphloader.SystemStratumSpecsNotMappingError) as cm:
+
+ self.loader.validate(m)
+ self.assertEqual(cm.exception.strata, ["foo"])
+
def test_loads_yaml_from_string(self):
string = '''\
name: foo
@@ -461,11 +515,13 @@ name: foo
test_dict)
def test_sets_defaults_for_system(self):
- m = morphlib.morph3.Morphology({
- 'kind': 'system',
- 'name': 'foo',
- 'arch': 'x86_64',
- })
+ m = morphlib.morph3.Morphology(
+ kind='system',
+ name='foo',
+ arch='testarch',
+ strata=[
+ {'morph': 'bar'},
+ ])
self.loader.set_defaults(m)
self.loader.validate(m)
self.assertEqual(
@@ -474,27 +530,72 @@ name: foo
'kind': 'system',
'name': 'foo',
'description': '',
- 'arch': 'x86_64',
- 'strata': [],
+ 'arch': 'testarch',
+ 'strata': [
+ {'morph': 'bar'},
+ ],
'configuration-extensions': [],
})
def test_unsets_defaults_for_system(self):
- m = morphlib.morph3.Morphology({
- 'kind': 'system',
- 'name': 'foo',
- 'arch': 'x86_64',
- 'strata': [],
- })
+ m = morphlib.morph3.Morphology(
+ {
+ 'description': '',
+ 'kind': 'system',
+ 'name': 'foo',
+ 'arch': 'testarch',
+ 'strata': [
+ {'morph': 'bar'},
+ ],
+ 'configuration-extensions': [],
+ })
self.loader.unset_defaults(m)
self.assertEqual(
dict(m),
{
'kind': 'system',
'name': 'foo',
- 'arch': 'x86_64',
+ 'arch': 'testarch',
+ 'strata': [
+ {'morph': 'bar'},
+ ],
})
+ def test_sets_defaults_for_cluster(self):
+ m = morphlib.morph3.Morphology(
+ name='foo',
+ kind='cluster',
+ systems=[
+ {'morph': 'foo'},
+ {'morph': 'bar'}])
+ self.loader.set_defaults(m)
+ self.loader.validate(m)
+ self.assertEqual(m['systems'],
+ [{'morph': 'foo',
+ 'deploy-defaults': {},
+ 'deploy': {}},
+ {'morph': 'bar',
+ 'deploy-defaults': {},
+ 'deploy': {}}])
+
+ def test_unsets_defaults_for_cluster(self):
+ m = morphlib.morph3.Morphology(
+ name='foo',
+ kind='cluster',
+ description='',
+ systems=[
+ {'morph': 'foo',
+ 'deploy-defaults': {},
+ 'deploy': {}},
+ {'morph': 'bar',
+ 'deploy-defaults': {},
+ 'deploy': {}}])
+ self.loader.unset_defaults(m)
+ self.assertNotIn('description', m)
+ self.assertEqual(m['systems'],
+ [{'morph': 'foo'},
+ {'morph': 'bar'}])
+
def test_sets_stratum_chunks_repo_and_morph_from_name(self):
m = morphlib.morph3.Morphology(
{