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:
committed by
Jeremy Allison
parent
7e70d72d97
commit
7b2ecefd55
@ -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"""
|
||||
|
@ -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
1
selftest/knownfail.d/gpo
Normal file
@ -0,0 +1 @@
|
||||
^samba.tests.samba_tool.gpo.samba.tests.samba_tool.gpo.GpoCmdTestCase.test_symlink_add
|
Reference in New Issue
Block a user