summaryrefslogtreecommitdiff
path: root/smoketest/scripts/cli/test_service_ntp.py
diff options
context:
space:
mode:
authorLucas Christian <lucas@lucasec.com>2024-08-08 23:30:40 -0700
committerChristian Breunig <christian@breunig.cc>2024-09-21 08:51:28 +0200
commite504e0cac55725e93f21322877bb7d0c4f97c992 (patch)
tree1afa58398bccb29dab7812024f138ec059e03902 /smoketest/scripts/cli/test_service_ntp.py
parent46a76acc85e775e87db5a82fea7bd520d7765369 (diff)
downloadvyos-1x-e504e0cac55725e93f21322877bb7d0c4f97c992.tar.gz
vyos-1x-e504e0cac55725e93f21322877bb7d0c4f97c992.zip
T6630: ntp: add "interleave" option
Diffstat (limited to 'smoketest/scripts/cli/test_service_ntp.py')
-rwxr-xr-xsmoketest/scripts/cli/test_service_ntp.py29
1 files changed, 29 insertions, 0 deletions
diff --git a/smoketest/scripts/cli/test_service_ntp.py b/smoketest/scripts/cli/test_service_ntp.py
index ae45fe2f4..fe6b1a529 100755
--- a/smoketest/scripts/cli/test_service_ntp.py
+++ b/smoketest/scripts/cli/test_service_ntp.py
@@ -165,5 +165,34 @@ class TestSystemNTP(VyOSUnitTestSHIM.TestCase):
self.assertIn(f'maxslewrate 1000', config)
self.assertIn(f'smoothtime 400 0.001024 leaponly', config)
+ def test_interleave_option(self):
+ # "interleave" option differs from some others in that the
+ # name is not a 1:1 mapping from VyOS config
+ servers = ['192.0.2.1', '192.0.2.2']
+ options = ['prefer']
+ offload_interface = 'eth0'
+
+ for server in servers:
+ for option in options:
+ self.cli_set(base_path + ['server', server, option])
+ self.cli_set(base_path + ['server', server, 'interleave'])
+
+ # commit changes
+ self.cli_commit()
+
+ # Check generated configuration
+ # this file must be read with higher permissions
+ config = cmd(f'sudo cat {NTP_CONF}')
+ self.assertIn('driftfile /run/chrony/drift', config)
+ self.assertIn('dumpdir /run/chrony', config)
+ self.assertIn('ntsdumpdir /run/chrony', config)
+ self.assertIn('clientloglimit 1048576', config)
+ self.assertIn('rtcsync', config)
+ self.assertIn('makestep 1.0 3', config)
+ self.assertIn('leapsectz right/UTC', config)
+
+ for server in servers:
+ self.assertIn(f'server {server} iburst ' + ' '.join(options) + ' xleave', config)
+
if __name__ == '__main__':
unittest.main(verbosity=2)