diff options
| author | Viacheslav Hletenko <v.gletenko@vyos.io> | 2024-08-21 16:32:16 +0000 | 
|---|---|---|
| committer | Mergify <37929162+mergify[bot]@users.noreply.github.com> | 2024-08-22 16:10:41 +0000 | 
| commit | e7d1805e4a774b97c176d3cc1184e1645580589e (patch) | |
| tree | 1d44cda096d9fe239eccb5a9da2d591cc46c5d56 /smoketest/scripts/cli | |
| parent | 0272bc92e70ae0e69cdd54f66a89921e2a98421c (diff) | |
| download | vyos-1x-e7d1805e4a774b97c176d3cc1184e1645580589e.tar.gz vyos-1x-e7d1805e4a774b97c176d3cc1184e1645580589e.zip | |
T6672: Fix system option ssh-client source-interfacemergify/bp/circinus/pr-4000
Fix for system option ssh-client source-interface
For the `verify_source_interface` the key `ifname` if required
(cherry picked from commit f453b33a6056de8fc5145ca9e680361fbce68348)
# Conflicts:
#	smoketest/scripts/cli/test_system_option.py
Diffstat (limited to 'smoketest/scripts/cli')
| -rwxr-xr-x | smoketest/scripts/cli/test_system_option.py | 99 | 
1 files changed, 99 insertions, 0 deletions
| diff --git a/smoketest/scripts/cli/test_system_option.py b/smoketest/scripts/cli/test_system_option.py new file mode 100755 index 000000000..ffb1d76ae --- /dev/null +++ b/smoketest/scripts/cli/test_system_option.py @@ -0,0 +1,99 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2024 VyOS maintainers and contributors +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 or later as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program.  If not, see <http://www.gnu.org/licenses/>. + +import os +import unittest +from base_vyostest_shim import VyOSUnitTestSHIM +from vyos.utils.file import read_file +from vyos.utils.process import is_systemd_service_active +from vyos.utils.system import sysctl_read + +base_path = ['system', 'option'] + +class TestSystemOption(VyOSUnitTestSHIM.TestCase): +    def tearDown(self): +        self.cli_delete(base_path) +        self.cli_commit() + +    def test_ctrl_alt_delete(self): +        self.cli_set(base_path + ['ctrl-alt-delete', 'reboot']) +        self.cli_commit() + +        tmp = os.readlink('/lib/systemd/system/ctrl-alt-del.target') +        self.assertEqual(tmp, '/lib/systemd/system/reboot.target') + +        self.cli_set(base_path + ['ctrl-alt-delete', 'poweroff']) +        self.cli_commit() + +        tmp = os.readlink('/lib/systemd/system/ctrl-alt-del.target') +        self.assertEqual(tmp, '/lib/systemd/system/poweroff.target') + +        self.cli_delete(base_path + ['ctrl-alt-delete', 'poweroff']) +        self.cli_commit() +        self.assertFalse(os.path.exists('/lib/systemd/system/ctrl-alt-del.target')) + +    def test_reboot_on_panic(self): +        panic_file = '/proc/sys/kernel/panic' + +        tmp = read_file(panic_file) +        self.assertEqual(tmp, '0') + +        self.cli_set(base_path + ['reboot-on-panic']) +        self.cli_commit() + +        tmp = read_file(panic_file) +        self.assertEqual(tmp, '60') + +    def test_performance(self): +        tuned_service = 'tuned.service' + +        self.assertFalse(is_systemd_service_active(tuned_service)) + +        # T3204 sysctl options must not be overwritten by tuned +        gc_thresh1 = '131072' +        gc_thresh2 = '262000' +        gc_thresh3 = '524000' + +        self.cli_set(['system', 'sysctl', 'parameter', 'net.ipv4.neigh.default.gc_thresh1', 'value', gc_thresh1]) +        self.cli_set(['system', 'sysctl', 'parameter', 'net.ipv4.neigh.default.gc_thresh2', 'value', gc_thresh2]) +        self.cli_set(['system', 'sysctl', 'parameter', 'net.ipv4.neigh.default.gc_thresh3', 'value', gc_thresh3]) + +        self.cli_set(base_path + ['performance', 'throughput']) +        self.cli_commit() + +        self.assertTrue(is_systemd_service_active(tuned_service)) + +        self.assertEqual(sysctl_read('net.ipv4.neigh.default.gc_thresh1'), gc_thresh1) +        self.assertEqual(sysctl_read('net.ipv4.neigh.default.gc_thresh2'), gc_thresh2) +        self.assertEqual(sysctl_read('net.ipv4.neigh.default.gc_thresh3'), gc_thresh3) + +    def test_ssh_client_options(self): +        loopback = 'lo' +        ssh_client_opt_file = '/etc/ssh/ssh_config.d/91-vyos-ssh-client-options.conf' + +        self.cli_set(['system', 'option', 'ssh-client', 'source-interface', loopback]) +        self.cli_commit() + +        tmp = read_file(ssh_client_opt_file) +        self.assertEqual(tmp, f'BindInterface {loopback}') + +        self.cli_delete(['system', 'option']) +        self.cli_commit() +        self.assertFalse(os.path.exists(ssh_client_opt_file)) + + +if __name__ == '__main__': +    unittest.main(verbosity=2, failfast=True) | 
