From a974cd94af8c2855ca8fa55968d5528333bfe620 Mon Sep 17 00:00:00 2001 From: David Mulder Date: Tue, 26 Jan 2021 13:43:43 -0700 Subject: [PATCH] samba-tool: Test gpo manage files add command Signed-off-by: David Mulder Reviewed-by: Jeremy Allison --- python/samba/netcmd/gpo.py | 29 ++++++++++++++++++ python/samba/tests/samba_tool/gpo.py | 44 ++++++++++++++++++++++++++++ selftest/knownfail.d/gpo | 1 + 3 files changed, 74 insertions(+) create mode 100644 selftest/knownfail.d/gpo diff --git a/python/samba/netcmd/gpo.py b/python/samba/netcmd/gpo.py index af0df653948..198ffe351ef 100644 --- a/python/samba/netcmd/gpo.py +++ b/python/samba/netcmd/gpo.py @@ -2559,10 +2559,39 @@ samba-tool gpo manage files list {31B2F340-016D-11D2-945F-00C04FB984F9} (stat_from_mode(mode), user, group, target, source) self.outf.write('%s\n' % p) +class cmd_add_files(Command): + """Add VGP Files Group Policy to the sysvol + +This command adds files which will be copied from the sysvol and applied to winbind clients. + +Example: +samba-tool gpo manage files add {31B2F340-016D-11D2-945F-00C04FB984F9} ./source.txt /usr/share/doc/target.txt root root 600 + """ + + synopsis = "%prog [options]" + + takes_optiongroups = { + "sambaopts": options.SambaOptions, + "versionopts": options.VersionOptions, + "credopts": options.CredentialsOptions, + } + + takes_options = [ + Option("-H", "--URL", help="LDB URL for database or target server", type=str, + metavar="URL", dest="H"), + ] + + takes_args = ["gpo", "source", "target", "user", "group", "mode"] + + def run(self, gpo, source, target, user, group, mode, H=None, + sambaopts=None, credopts=None, versionopts=None): + pass + class cmd_files(SuperCommand): """Manage Files Group Policy Objects""" subcommands = {} subcommands["list"] = cmd_list_files() + subcommands["add"] = cmd_add_files() class cmd_manage(SuperCommand): """Manage Group Policy Objects""" diff --git a/python/samba/tests/samba_tool/gpo.py b/python/samba/tests/samba_tool/gpo.py index af2e45782bd..c885198c1b2 100644 --- a/python/samba/tests/samba_tool/gpo.py +++ b/python/samba/tests/samba_tool/gpo.py @@ -923,6 +923,50 @@ class GpoCmdTestCase(SambaToolCmdTest): # Unstage the manifest.xml file unstage_file(vgp_xml) + def test_files_add(self): + lp = LoadParm() + lp.load(os.environ['SERVERCONFFILE']) + local_path = lp.get('path', 'sysvol') + sysvol_source = os.path.join(local_path, lp.get('realm').lower(), + 'Policies', self.gpo_guid, 'Machine/VGP', + 'VTLA/Unix/Files/test.source') + source_file = os.path.join(self.tempdir, 'test.source') + source_data = '#!/bin/sh\necho hello world' + with open(source_file, 'w') as w: + w.write(source_data) + target_file = os.path.join(self.tempdir, 'test.target') + user = pwd.getpwuid(os.getuid()).pw_name + group = grp.getgrgid(os.getgid()).gr_name + (result, out, err) = self.runsublevelcmd("gpo", ("manage", + "files", "add"), + self.gpo_guid, + source_file, + target_file, + user, group, + '755', "-H", + "ldap://%s" % + os.environ["SERVER"], + "-U%s%%%s" % + (os.environ["USERNAME"], + os.environ["PASSWORD"])) + self.assertCmdSuccess(result, out, err, 'File add failed') + self.assertIn(source_data, open(sysvol_source, 'r').read(), + 'Failed to find the source file on the sysvol') + + (result, out, err) = self.runsublevelcmd("gpo", ("manage", + "files", "list"), + self.gpo_guid, "-H", + "ldap://%s" % + os.environ["SERVER"], + "-U%s%%%s" % + (os.environ["USERNAME"], + os.environ["PASSWORD"])) + self.assertIn(target_file, out, 'The test entry was not found!') + self.assertIn('-rwxr-xr-x', out, + 'The test entry permissions were not found') + + os.unlink(source_file) + def setUp(self): """set up a temporary GPO to work with""" super(GpoCmdTestCase, self).setUp() diff --git a/selftest/knownfail.d/gpo b/selftest/knownfail.d/gpo new file mode 100644 index 00000000000..960b8e57125 --- /dev/null +++ b/selftest/knownfail.d/gpo @@ -0,0 +1 @@ +^samba.tests.samba_tool.gpo.samba.tests.samba_tool.gpo.GpoCmdTestCase.test_files_add -- 2.47.3