diff options
author | Christian Breunig <christian@breunig.cc> | 2023-09-08 07:32:38 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-08 07:32:38 +0200 |
commit | c57a519ea9af262f410e9e6887684e772f34fe69 (patch) | |
tree | c1b7c2f3036950b21d440dd3b1e354d2df3dc2cc /smoketest/bin/vyos-configtest | |
parent | fd5517b38191f5bb5897912ef62f5a8d1156b7b3 (diff) | |
parent | 56a6e53f78f1d91ab267cb858061450b7af905b3 (diff) | |
download | vyos-1x-c57a519ea9af262f410e9e6887684e772f34fe69.tar.gz vyos-1x-c57a519ea9af262f410e9e6887684e772f34fe69.zip |
Merge pull request #2221 from sarthurdev/configtest_extend
smoketest: T5558: Extend configtest to allow checking of migration script results
Diffstat (limited to 'smoketest/bin/vyos-configtest')
-rwxr-xr-x | smoketest/bin/vyos-configtest | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/smoketest/bin/vyos-configtest b/smoketest/bin/vyos-configtest index 3e42b0380..c1b602737 100755 --- a/smoketest/bin/vyos-configtest +++ b/smoketest/bin/vyos-configtest @@ -24,6 +24,7 @@ from vyos.configsession import ConfigSession, ConfigSessionError from vyos import ConfigError config_dir = '/usr/libexec/vyos/tests/config' +config_test_dir = '/usr/libexec/vyos/tests/config-tests' save_config = '/tmp/vyos-configtest-save' class DynamicClassBase(unittest.TestCase): @@ -42,7 +43,7 @@ class DynamicClassBase(unittest.TestCase): except OSError: pass -def make_test_function(filename): +def make_test_function(filename, test_path=None): def test_config_load(self): config_path = os.path.join(config_dir, filename) self.session.migrate_and_load_config(config_path) @@ -51,6 +52,16 @@ def make_test_function(filename): except (ConfigError, ConfigSessionError): self.session.discard() self.fail() + + if test_path: + config_commands = self.session.show(['configuration', 'commands']) + + with open(test_path, 'r') as f: + for line in f.readlines(): + if not line or line.startswith("#"): + continue + + self.assertIn(line, config_commands) return test_config_load def class_name_from_func_name(s): @@ -69,10 +80,18 @@ if __name__ == '__main__': config_list.sort() for config in config_list: - test_func = make_test_function(config) + test_path = os.path.join(config_test_dir, config) + + if not os.path.exists(test_path): + test_path = None + else: + log.info(f'Loaded migration result test for config "{config}"') + + test_func = make_test_function(config, test_path) func_name = config.replace('-', '_') klassname = f'TestConfig{class_name_from_func_name(func_name)}' + globals()[klassname] = type(klassname, (DynamicClassBase,), {f'test_{func_name}': test_func}) |