1
0
mirror of https://github.com/samba-team/samba.git synced 2025-08-02 00:22:11 +03:00

samba-tool: Test gpo manage symlink add command

Signed-off-by: David Mulder <dmulder@suse.com>
Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
David Mulder
2021-01-21 10:26:57 -07:00
committed by Jeremy Allison
parent 7e70d72d97
commit 7b2ecefd55
3 changed files with 55 additions and 0 deletions

View File

@ -2305,10 +2305,39 @@ samba-tool gpo manage symlink list {31B2F340-016D-11D2-945F-00C04FB984F9}
target = file_properties.find('target')
self.outf.write('ln -s %s %s\n' % (source.text, target.text))
class cmd_add_symlink(Command):
"""Adds a VGP Symbolic Link Group Policy to the sysvol
This command adds a symlink setting to the sysvol that will be applied to winbind clients.
Example:
samba-tool gpo manage symlink add {31B2F340-016D-11D2-945F-00C04FB984F9} /tmp/source /tmp/target
"""
synopsis = "%prog <gpo> <source> <target> [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"]
def run(self, gpo, source, target, H=None, sambaopts=None, credopts=None,
versionopts=None):
pass
class cmd_symlink(SuperCommand):
"""Manage symlink Group Policy Objects"""
subcommands = {}
subcommands["list"] = cmd_list_symlink()
subcommands["add"] = cmd_add_symlink()
class cmd_manage(SuperCommand):
"""Manage Group Policy Objects"""

View File

@ -815,6 +815,31 @@ class GpoCmdTestCase(SambaToolCmdTest):
# Unstage the manifest.xml file
unstage_file(vgp_xml)
def test_symlink_add(self):
source_text = os.path.join(self.tempdir, 'test.source')
target_text = os.path.join(self.tempdir, 'test.target')
symlink = 'ln -s %s %s' % (source_text, target_text)
(result, out, err) = self.runsublevelcmd("gpo", ("manage",
"symlink", "add"),
self.gpo_guid,
source_text, target_text,
"-H", "ldap://%s" %
os.environ["SERVER"],
"-U%s%%%s" %
(os.environ["USERNAME"],
os.environ["PASSWORD"]))
self.assertCmdSuccess(result, out, err, 'Symlink add failed')
(result, out, err) = self.runsublevelcmd("gpo", ("manage",
"symlink", "list"),
self.gpo_guid, "-H",
"ldap://%s" %
os.environ["SERVER"],
"-U%s%%%s" %
(os.environ["USERNAME"],
os.environ["PASSWORD"]))
self.assertIn(symlink, out, 'The test entry was not found!')
def setUp(self):
"""set up a temporary GPO to work with"""
super(GpoCmdTestCase, self).setUp()

1
selftest/knownfail.d/gpo Normal file
View File

@ -0,0 +1 @@
^samba.tests.samba_tool.gpo.samba.tests.samba_tool.gpo.GpoCmdTestCase.test_symlink_add