forked from osbuild/osbuild
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add test for org.osbuild.containers.storage.conf stage
- Loading branch information
1 parent
4d66c61
commit 717ba17
Showing
2 changed files
with
124 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
#!/usr/bin/python3 | ||
|
||
import os.path | ||
import pytoml | ||
from unittest.mock import call, patch | ||
|
||
import pytest | ||
|
||
import osbuild.meta | ||
from osbuild.testutil.imports import import_module_from_path | ||
|
||
TEST_INPUT = [ | ||
({}, {"additionalimagestores": [ "/path/to/store" ]}, [("storage.options.additionalimagestores", ["/path/to/store"])]), | ||
({}, {"additionalimagestores": [ "/path/to/store" ]}, [("storage.options.additionalimagestores", ["/path/to/store"])]), | ||
({ "transient_store": True, "runroot": "/foo"} , {}, [("storage.transient_store", True), ("storage.runroot", '/foo')]), | ||
] | ||
|
||
def assert_dict_has(dict, keys, expected_value): | ||
v = dict | ||
for key in keys.split("."): | ||
assert key in v | ||
v = v[key] | ||
assert v == expected_value | ||
|
||
@pytest.mark.parametrize("test_filename", ["/etc/containers/storage.conf", "/usr/share/containers/storage.conf"]) | ||
@pytest.mark.parametrize("test_storage,test_options,expected", TEST_INPUT) | ||
def test_containers_storage_conf_integration(tmp_path, test_filename, test_storage, test_options, expected): # pylint: disable=unused-argument | ||
treedir = os.path.join(tmp_path, "tree") | ||
confdir, confname = os.path.split(test_filename.lstrip("/")) | ||
confdir = os.path.join(treedir, confdir) | ||
os.makedirs(confdir, exist_ok=True) | ||
|
||
stage_path = os.path.join(os.path.dirname(__file__), "../org.osbuild.containers.storage.conf") | ||
stage = import_module_from_path("stage", stage_path) | ||
options = { | ||
"filename": test_filename, | ||
"config": { | ||
"storage": { | ||
"options": { | ||
} | ||
} | ||
} | ||
} | ||
|
||
options["config"]["storage"].update(test_storage) | ||
options["config"]["storage"]["options"].update(test_options) | ||
|
||
stage.main(treedir, options) | ||
|
||
confpath = os.path.join(confdir, confname) | ||
assert os.path.exists(confpath) | ||
|
||
conf = None | ||
with open(confpath, 'rb') as f: | ||
conf = pytoml.load(f) | ||
|
||
assert conf != None | ||
|
||
for (key, value) in expected: | ||
assert_dict_has(conf, key, value) | ||
|
||
@pytest.mark.parametrize( | ||
"test_data,storage_test_data,expected_err", | ||
[ | ||
# None | ||
({}, {}, "does not have enough properties"), | ||
# All options | ||
({ | ||
"filename": "/etc/containers/storage.conf", | ||
"filebase": "/some/path", | ||
"comment": ["List of", "comments"] | ||
}, | ||
{ | ||
"driver": "vfs", | ||
"graphroot": "/some/path", | ||
"runroot": "/other/path", | ||
"transient_store": True, | ||
"options": { | ||
"additionalimagestores": [ "/path/to/store" ], | ||
"pull_options": { | ||
"enable_partial_images": "true", | ||
"use_hard_links": "false", | ||
"convert_images": "false" | ||
}, | ||
"overlay": { | ||
"mountopt": "metadata" | ||
} | ||
} | ||
}, ""), | ||
({}, { "transient_store": "true" }, "is not of type 'boolean'"), | ||
# Pull options are strings, not booleans (in the config file format) | ||
({}, { "options": { "pull_options": {"use_hard_links": "foobar" }}}, "is not one of" ), | ||
({}, { "options": { "pull_options": {"use_hard_links": True }}}, "is not one of" ), | ||
({}, { "options": { "pull_options": {"use_hard_links": True }}}, "is not of type 'string'"), | ||
], | ||
) | ||
def test_schema_validation_containers_storage_conf(test_data, storage_test_data, expected_err): | ||
name = "org.osbuild.containers.storage.conf" | ||
version = "2" | ||
root = os.path.join(os.path.dirname(__file__), "../..") | ||
mod_info = osbuild.meta.ModuleInfo.load(root, "Stage", name) | ||
schema = osbuild.meta.Schema(mod_info.get_schema(version=version), name) | ||
|
||
test_input = { | ||
"type": "org.osbuild.containers.storage.conf", | ||
"options": { | ||
"config": { | ||
"storage": { | ||
} | ||
} | ||
} | ||
} | ||
|
||
test_input["options"].update(test_data) | ||
test_input["options"]["config"]["storage"].update(storage_test_data) | ||
res = schema.validate(test_input) | ||
|
||
if expected_err == "": | ||
assert res.valid is True, f"err: {[e.as_dict() for e in res.errors]}" | ||
else: | ||
assert res.valid is False | ||
err_msgs = [e.as_dict()["message"] for e in res.errors] | ||
assert expected_err in err_msgs[0] or expected_err in err_msgs[1] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters