mirror of
https://github.com/samba-team/samba.git
synced 2025-08-04 08:22:08 +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')
|
target = file_properties.find('target')
|
||||||
self.outf.write('ln -s %s %s\n' % (source.text, target.text))
|
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):
|
class cmd_symlink(SuperCommand):
|
||||||
"""Manage symlink Group Policy Objects"""
|
"""Manage symlink Group Policy Objects"""
|
||||||
subcommands = {}
|
subcommands = {}
|
||||||
subcommands["list"] = cmd_list_symlink()
|
subcommands["list"] = cmd_list_symlink()
|
||||||
|
subcommands["add"] = cmd_add_symlink()
|
||||||
|
|
||||||
class cmd_manage(SuperCommand):
|
class cmd_manage(SuperCommand):
|
||||||
"""Manage Group Policy Objects"""
|
"""Manage Group Policy Objects"""
|
||||||
|
@ -815,6 +815,31 @@ class GpoCmdTestCase(SambaToolCmdTest):
|
|||||||
# Unstage the manifest.xml file
|
# Unstage the manifest.xml file
|
||||||
unstage_file(vgp_xml)
|
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):
|
def setUp(self):
|
||||||
"""set up a temporary GPO to work with"""
|
"""set up a temporary GPO to work with"""
|
||||||
super(GpoCmdTestCase, self).setUp()
|
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