mirror of
https://github.com/samba-team/samba.git
synced 2025-01-06 13:18:07 +03:00
88c4305ffb
This is a slow test of SMB2 protocol features, it needs not to be repeated. It only got run against both by accident at the original merge and then extended to run on the [compount_find] share (with smbd:find async delay usec = 10000) but really does not need to be run three times. Signed-off-by: Andrew Bartlett <abartlet@samba.org> Reviewed-by: Andreas Schneider <asn@samba.org>
969 lines
67 KiB
Python
Executable File
969 lines
67 KiB
Python
Executable File
#!/usr/bin/python
|
|
# This script generates a list of testsuites that should be run as part of
|
|
# the Samba 3 test suite.
|
|
|
|
# The output of this script is parsed by selftest.pl, which then decides
|
|
# which of the tests to actually run. It will, for example, skip all tests
|
|
# listed in selftest/skip or only run a subset during "make quicktest".
|
|
|
|
# The idea is that this script outputs all of the tests of Samba 3, not
|
|
# just those that are known to pass, and list those that should be skipped
|
|
# or are known to fail in selftest/skip or selftest/samba3-knownfail. This makes it
|
|
# very easy to see what functionality is still missing in Samba 3 and makes
|
|
# it possible to run the testsuite against other servers, such as Samba 4 or
|
|
# Windows that have a different set of features.
|
|
|
|
# The syntax for a testsuite is "-- TEST --" on a single line, followed
|
|
# by the name of the test, the environment it needs and the command to run, all
|
|
# three separated by newlines. All other lines in the output are considered
|
|
# comments.
|
|
|
|
import os
|
|
import sys
|
|
sys.path.insert(0, os.path.normpath(os.path.join(os.path.dirname(__file__), "../../selftest")))
|
|
import selftesthelpers
|
|
from selftesthelpers import bindir, srcdir, scriptdir, binpath
|
|
from selftesthelpers import plantestsuite, samba3srcdir
|
|
from selftesthelpers import smbtorture3, configuration, smbclient3, smbtorture4
|
|
from selftesthelpers import net, wbinfo, dbwrap_tool, rpcclient, python
|
|
from selftesthelpers import smbget, smbcacls, smbcquotas, ntlm_auth3
|
|
from selftesthelpers import valgrindify, smbtorture4_testsuites
|
|
from selftesthelpers import smbtorture4_options
|
|
from selftesthelpers import smbcontrol
|
|
from selftesthelpers import smbstatus
|
|
smbtorture4_options.extend([
|
|
'--option=torture:sharedelay=100000',
|
|
'--option=torture:writetimeupdatedelay=500000',
|
|
])
|
|
|
|
|
|
def plansmbtorture4testsuite(name, env, options, description=''):
|
|
if description == '':
|
|
modname = "samba3.%s" % (name, )
|
|
else:
|
|
modname = "samba3.%s %s" % (name, description)
|
|
|
|
selftesthelpers.plansmbtorture4testsuite(
|
|
name, env, options, target='samba3', modname=modname)
|
|
|
|
|
|
# find config.h
|
|
try:
|
|
config_h = os.environ["CONFIG_H"]
|
|
except KeyError:
|
|
samba4bindir = bindir()
|
|
config_h = os.path.join(samba4bindir, "default/include/config.h")
|
|
|
|
# check available features
|
|
config_hash = dict()
|
|
f = open(config_h, 'r')
|
|
try:
|
|
lines = f.readlines()
|
|
config_hash = dict((x[0], ' '.join(x[1:]))
|
|
for x in map(lambda line: line.strip().split(' ')[1:],
|
|
filter(lambda line: (line[0:7] == '#define') and (len(line.split(' ')) > 2), lines)))
|
|
finally:
|
|
f.close()
|
|
|
|
have_linux_kernel_oplocks = ("HAVE_KERNEL_OPLOCKS_LINUX" in config_hash)
|
|
have_inotify = ("HAVE_INOTIFY" in config_hash)
|
|
have_ldwrap = ("HAVE_LDWRAP" in config_hash)
|
|
with_pthreadpool = ("WITH_PTHREADPOOL" in config_hash)
|
|
|
|
|
|
plantestsuite("samba3.blackbox.success", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/test_success.sh")])
|
|
plantestsuite("samba3.blackbox.failure", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/test_failure.sh")])
|
|
|
|
plantestsuite("samba3.local_s3", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/test_local_s3.sh")])
|
|
|
|
plantestsuite("samba3.blackbox.registry.upgrade", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/test_registry_upgrade.sh"), net, dbwrap_tool])
|
|
|
|
tests = ["FDPASS", "LOCK1", "LOCK2", "LOCK3", "LOCK4", "LOCK5", "LOCK6", "LOCK7",
|
|
"LOCK9A", "LOCK9B",
|
|
"LOCK10",
|
|
"LOCK11",
|
|
"LOCK12",
|
|
"LOCK13",
|
|
"UNLINK", "BROWSE", "ATTR", "TRANS2", "TORTURE",
|
|
"OPLOCK1", "OPLOCK2", "OPLOCK4", "STREAMERROR",
|
|
"DIR", "DIR1", "DIR-CREATETIME", "TCON", "TCONDEV", "RW1", "RW2", "RW3", "LARGE_READX", "RW-SIGNING",
|
|
"OPEN", "XCOPY", "RENAME", "DELETE", "DELETE-LN", "WILDDELETE", "PROPERTIES", "W2K",
|
|
"TCON2", "IOCTL", "CHKPATH", "FDSESS", "CHAIN1", "CHAIN2", "OWNER-RIGHTS",
|
|
"CHAIN3", "PIDHIGH", "CLI_SPLICE",
|
|
"UID-REGRESSION-TEST", "SHORTNAME-TEST",
|
|
"CASE-INSENSITIVE-CREATE", "SMB2-BASIC", "NTTRANS-FSCTL", "SMB2-NEGPROT",
|
|
"SMB2-SESSION-REAUTH", "SMB2-SESSION-RECONNECT", "SMB2-FTRUNCATE",
|
|
"SMB2-ANONYMOUS", "SMB2-DIR-FSYNC",
|
|
"SMB2-PATH-SLASH",
|
|
"CLEANUP1",
|
|
"CLEANUP2",
|
|
"CLEANUP4",
|
|
"DELETE-STREAM",
|
|
"BAD-NBT-SESSION"]
|
|
|
|
for t in tests:
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "fileserver", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmp', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
plantestsuite("samba3.smbtorture_s3.crypt_client.%s" % t, "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmp', '$USERNAME', '$PASSWORD', smbtorture3, "-e", "-l $LOCAL_PATH"])
|
|
if t == "TORTURE":
|
|
# this is a negative test to verify that the server rejects
|
|
# access without encryption
|
|
plantestsuite("samba3.smbtorture_s3.crypt_server.%s" % t, "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmpenc', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
if t == "CLI_SPLICE":
|
|
# We must test this against the SMB1 fallback.
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "fileserver", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmp', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH", "-mNT1"])
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "ad_dc_ntvfs", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmp', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
t = "TLDAP"
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "ad_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER/tmp', '$DC_USERNAME', '$DC_PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
t = "OPLOCK5"
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t,
|
|
"fileserver",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_smbtorture_s3.sh"),
|
|
t,
|
|
'//$SERVER/tmp',
|
|
'$USERNAME',
|
|
'$PASSWORD',
|
|
smbtorture3,
|
|
"",
|
|
"-l $LOCAL_PATH",
|
|
"-mNT1"])
|
|
#
|
|
# RENAME-ACCESS needs to run against a special share - acl_xattr_ign_sysacl_windows
|
|
#
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % "RENAME-ACCESS", "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), "RENAME-ACCESS", '//$SERVER_IP/acl_xattr_ign_sysacl_windows', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
plantestsuite("samba3.smbtorture_s3.crypt_client.%s" % "RENAME-ACCESS", "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), "RENAME-ACCESS", '//$SERVER_IP/acl_xattr_ign_sysacl_windows', '$USERNAME', '$PASSWORD', smbtorture3, "-e", "-l $LOCAL_PATH"])
|
|
# non-crypt only
|
|
|
|
tests = ["OPLOCK-CANCEL"]
|
|
for t in tests:
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/tmp', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
env = "nt4_dc"
|
|
tests = ["MANGLE-ILLEGAL"]
|
|
for t in tests:
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, env, [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/mangle_illegal', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
tests = ["RW1", "RW2", "RW3", "SMB2-BASIC"]
|
|
for t in tests:
|
|
plantestsuite("samba3.smbtorture_s3.vfs_aio_pthread(simpleserver).%s" % t, "simpleserver", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/vfs_aio_pthread', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
plantestsuite("samba3.smbtorture_s3.vfs_aio_fork(simpleserver).%s" % t, "simpleserver", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/vfs_aio_fork', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
plantestsuite("samba3.smbtorture_s3.hidenewfiles(simpleserver)",
|
|
"simpleserver",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_smbtorture_s3.sh"),
|
|
'hide-new-files-timeout',
|
|
'//$SERVER_IP/hidenewfiles',
|
|
'$USERNAME',
|
|
'$PASSWORD',
|
|
smbtorture3,
|
|
"",
|
|
"-l $LOCAL_PATH"])
|
|
|
|
shares = [
|
|
"vfs_aio_pthread_async_dosmode_default1",
|
|
"vfs_aio_pthread_async_dosmode_default2",
|
|
"vfs_aio_pthread_async_dosmode_force_sync1",
|
|
"vfs_aio_pthread_async_dosmode_force_sync2"
|
|
]
|
|
for s in shares:
|
|
plantestsuite("samba3.smbtorture_s3.%s(simpleserver).SMB2-BASIC" % s, "simpleserver", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), 'SMB2-BASIC', '//$SERVER_IP/' + s, '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
t = "smb2.compound_find"
|
|
plansmbtorture4testsuite(t, "simpleserver", "//%s/%s %s" % ('$SERVER_IP', s, ' -U$USERNAME%$PASSWORD'), description=s)
|
|
|
|
posix_tests = ["POSIX", "POSIX-APPEND", "POSIX-SYMLINK-ACL", "POSIX-SYMLINK-EA", "POSIX-OFD-LOCK",
|
|
"POSIX-STREAM-DELETE", "WINDOWS-BAD-SYMLINK", "POSIX-MKDIR",
|
|
"POSIX-BLOCKING-LOCK",
|
|
"POSIX-ACL-OPLOCK",
|
|
"POSIX-ACL-SHAREROOT",
|
|
]
|
|
|
|
for t in posix_tests:
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/posix_share', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
plantestsuite("samba3.smbtorture_s3.crypt.%s" % t, "nt4_dc", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/posix_share', '$USERNAME', '$PASSWORD', smbtorture3, "-e", "-l $LOCAL_PATH"])
|
|
plantestsuite("samba3.smbtorture_s3.plain.%s" % t, "ad_dc_ntvfs", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//$SERVER_IP/posix_share', '$USERNAME', '$PASSWORD', smbtorture3, "", "-l $LOCAL_PATH"])
|
|
|
|
local_tests = [
|
|
"LOCAL-SUBSTITUTE",
|
|
"LOCAL-GENCACHE",
|
|
"LOCAL-BASE64",
|
|
"LOCAL-RBTREE",
|
|
"LOCAL-MEMCACHE",
|
|
"LOCAL-STREAM-NAME",
|
|
"LOCAL-string_to_sid",
|
|
"LOCAL-sid_to_string",
|
|
"LOCAL-binary_to_sid",
|
|
"LOCAL-DBTRANS",
|
|
"LOCAL-TEVENT-POLL",
|
|
"LOCAL-CONVERT-STRING",
|
|
"LOCAL-CONV-AUTH-INFO",
|
|
"LOCAL-IDMAP-TDB-COMMON",
|
|
"LOCAL-MESSAGING-READ1",
|
|
"LOCAL-MESSAGING-READ2",
|
|
"LOCAL-MESSAGING-READ3",
|
|
"LOCAL-MESSAGING-READ4",
|
|
"LOCAL-MESSAGING-FDPASS1",
|
|
"LOCAL-MESSAGING-FDPASS2",
|
|
"LOCAL-MESSAGING-FDPASS2a",
|
|
"LOCAL-MESSAGING-FDPASS2b",
|
|
"LOCAL-MESSAGING-SEND-ALL",
|
|
"LOCAL-PTHREADPOOL-TEVENT",
|
|
"LOCAL-CANONICALIZE-PATH",
|
|
"LOCAL-DBWRAP-WATCH1",
|
|
"LOCAL-DBWRAP-WATCH2",
|
|
"LOCAL-DBWRAP-WATCH3",
|
|
"LOCAL-DBWRAP-WATCH4",
|
|
"LOCAL-DBWRAP-DO-LOCKED1",
|
|
"LOCAL-G-LOCK1",
|
|
"LOCAL-G-LOCK2",
|
|
"LOCAL-G-LOCK3",
|
|
"LOCAL-G-LOCK4",
|
|
"LOCAL-G-LOCK4A",
|
|
"LOCAL-G-LOCK5",
|
|
"LOCAL-G-LOCK6",
|
|
"LOCAL-G-LOCK7",
|
|
"LOCAL-NAMEMAP-CACHE1",
|
|
"LOCAL-IDMAP-CACHE1",
|
|
"LOCAL-hex_encode_buf",
|
|
"LOCAL-remove_duplicate_addrs2"]
|
|
|
|
for t in local_tests:
|
|
plantestsuite("samba3.smbtorture_s3.%s" % t, "none", [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//foo/bar', '""', '""', smbtorture3, ""])
|
|
|
|
plantestsuite("samba.vfstest.stream_depot", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/stream-depot/run.sh"), binpath("vfstest"), "$PREFIX", configuration])
|
|
plantestsuite("samba.vfstest.xattr-tdb-1", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/xattr-tdb-1/run.sh"), binpath("vfstest"), "$PREFIX", configuration])
|
|
plantestsuite("samba.vfstest.acl", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/vfstest-acl/run.sh"), binpath("vfstest"), "$PREFIX", configuration])
|
|
plantestsuite("samba.vfstest.catia", "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/vfstest-catia/run.sh"), binpath("vfstest"), "$PREFIX", configuration])
|
|
|
|
plantestsuite("samba3.blackbox.smbclient_basic.NT1", "nt4_dc_schannel", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, "-mNT1"])
|
|
plantestsuite("samba3.blackbox.smbclient_basic.SMB2_02", "nt4_dc_schannel", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, "-mSMB2_02"])
|
|
plantestsuite("samba3.blackbox.smbclient_basic.SMB2_10", "nt4_dc_schannel", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, "-mSMB2_10"])
|
|
plantestsuite("samba3.blackbox.smbclient_basic.SMB3_02", "nt4_dc_schannel", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, "-mSMB3_02"])
|
|
plantestsuite("samba3.blackbox.smbclient_basic.SMB3_11", "nt4_dc_schannel", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, "-mSMB3_11"])
|
|
|
|
plantestsuite("samba3.blackbox.smbclient_basic", "ad_member", [os.path.join(samba3srcdir, "script/tests/test_smbclient_basic.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration])
|
|
for options in ["", "--option=clientntlmv2auth=no", "--option=clientusespnego=no", "--option=clientusespnego=no --option=clientntlmv2auth=no", "--option=clientntlmv2auth=no --option=clientlanmanauth=yes --max-protocol=LANMAN2", "--option=clientntlmv2auth=no --option=clientlanmanauth=yes --option=clientmaxprotocol=NT1"]:
|
|
env = "nt4_dc"
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.%s" % (options), env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, options])
|
|
|
|
for env in ["nt4_dc", "nt4_member", "ad_member", "ad_dc", "ad_dc_ntvfs", "s4member", "fl2000dc"]:
|
|
plantestsuite("samba3.blackbox.smbclient_machine_auth.plain", "%s:local" % env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_machine_auth.sh"), '$SERVER', smbclient3, configuration])
|
|
plantestsuite("samba3.blackbox.smbclient_ntlm.plain NT1", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_ntlm.sh"), '$SERVER', '$DC_USERNAME', '$DC_PASSWORD', "never", smbclient3, "NT1", configuration])
|
|
plantestsuite("samba3.blackbox.smbclient_ntlm.plain SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_ntlm.sh"), '$SERVER', '$DC_USERNAME', '$DC_PASSWORD', "never", smbclient3, "SMB3", configuration])
|
|
|
|
for options in ["--option=clientntlmv2auth=no", "--option=clientusespnego=no --option=clientntlmv2auth=no", "--option=clientusespnego=no --option=clientntlmv2auth=no -mNT1", ""]:
|
|
for env in ["nt4_member", "ad_member"]:
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.%s" % (options), env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.%s.member_creds" % (options), env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$SERVER/$USERNAME', '$PASSWORD', smbclient3, configuration, options])
|
|
|
|
for env in ["nt4_member", "ad_member"]:
|
|
plantestsuite("samba3.blackbox.smbclient_auth.empty_domain.domain_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '/$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.empty_domain.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '/$USERNAME', '$PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.dot_domain.domain_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', './$DC_USERNAME', '$DC_PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.dot_domain.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', './$USERNAME', '$PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.upn.domain_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME@$REALM', '$DC_PASSWORD', smbclient3, configuration, options])
|
|
plantestsuite("samba3.blackbox.smbclient_auth.upn.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$USERNAME@$SERVER', '$PASSWORD', smbclient3, configuration, options])
|
|
|
|
env = "ad_dc"
|
|
plantestsuite("samba3.blackbox.smbspool", env, [os.path.join(samba3srcdir, "script/tests/test_smbspool.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD', env])
|
|
|
|
for env in ["ad_member:local", "nt4_dc:local"]:
|
|
plantestsuite("samba3.blackbox.smbpasswd", env, [os.path.join(samba3srcdir, "script/tests/test_smbpasswd.sh"), '$SERVER', '$SERVER_IP', '$DC_USERNAME', '$DC_PASSWORD'])
|
|
|
|
env = "nt4_dc"
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.ipv6", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IPV6', '$SERVER/$USERNAME', '$PASSWORD', smbclient3, configuration])
|
|
|
|
for env in ["nt4_member", "ad_member"]:
|
|
plantestsuite("samba3.blackbox.net_cred_change", "%s:local" % env, [os.path.join(samba3srcdir, "script/tests/test_net_cred_change.sh"), configuration])
|
|
|
|
env = "ad_member"
|
|
t = "--krb5auth=$DOMAIN/$DC_USERNAME%$DC_PASSWORD"
|
|
plantestsuite("samba3.wbinfo_simple.%s" % t, "%s:local" % env, [os.path.join(srcdir(), "nsswitch/tests/test_wbinfo_simple.sh"), t])
|
|
plantestsuite("samba3.wbinfo_name_lookup", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_name_lookup.sh"),
|
|
'$DOMAIN', '$REALM', '$DC_USERNAME'])
|
|
|
|
env = "ad_member"
|
|
plantestsuite("samba3.wbinfo_user_info_cached", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_user_info_cached.sh"),
|
|
'$DOMAIN', '$REALM', 'joe', 'Secret007', '"Samba Users"', env])
|
|
plantestsuite("samba3.wbinfo_user_info_cached.trustdom", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_user_info_cached.sh"),
|
|
'$TRUST_F_BOTH_DOMAIN', '$TRUST_F_BOTH_REALM', 'joe', 'Secret007', '"Samba Users"', env])
|
|
|
|
env = "ad_member:local"
|
|
plantestsuite("samba3.wbinfo_user_info", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_user_info.sh"),
|
|
'$DOMAIN', '$REALM', '$DOMAIN', 'alice', 'alice', 'jane', 'jane.doe', env])
|
|
|
|
env = "fl2008r2dc:local"
|
|
plantestsuite("samba3.wbinfo_user_info", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_user_info.sh"),
|
|
'$TRUST_DOMAIN', '$TRUST_REALM', '$DOMAIN', 'alice', 'alice', 'jane', 'jane.doe', env])
|
|
|
|
env = "nt4_member:local"
|
|
plantestsuite("samba3.wbinfo_sids_to_xids", env,
|
|
[os.path.join(srcdir(),
|
|
"nsswitch/tests/test_wbinfo_sids_to_xids.sh")])
|
|
|
|
env = "ad_member"
|
|
t = "WBCLIENT-MULTI-PING"
|
|
plantestsuite("samba3.smbtorture_s3.%s" % t, env, [os.path.join(samba3srcdir, "script/tests/test_smbtorture_s3.sh"), t, '//foo/bar', '""', '""', smbtorture3, ""])
|
|
plantestsuite("samba3.substitutions", env, [os.path.join(samba3srcdir, "script/tests/test_substitutions.sh"), "$SERVER", "alice", "Secret007", "$PREFIX"])
|
|
|
|
for env in ["maptoguest", "simpleserver"]:
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.local_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD', smbclient3, configuration + " --option=clientntlmv2auth=no --option=clientlanmanauth=yes"])
|
|
|
|
env = "maptoguest"
|
|
plantestsuite("samba3.blackbox.smbclient_auth.plain.bad_username", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_auth.sh"), '$SERVER', '$SERVER_IP', 'notmy$USERNAME', '$PASSWORD', smbclient3, configuration + " --option=clientntlmv2auth=no --option=clientlanmanauth=yes"])
|
|
plantestsuite("samba3.blackbox.smbclient_ntlm.plain.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_ntlm.sh"), '$SERVER', '$USERNAME', '$PASSWORD', "baduser", smbclient3, "NT1", configuration])
|
|
plantestsuite("samba3.blackbox.smbclient_ntlm.plain.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_ntlm.sh"), '$SERVER', '$USERNAME', '$PASSWORD', "baduser", smbclient3, "NT1", configuration])
|
|
|
|
# plain
|
|
for env in ["nt4_dc"]:
|
|
plantestsuite("samba3.blackbox.smbclient_s3.NT1.plain", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$DC_USERNAME', '$DC_PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "NT1"])
|
|
plantestsuite("samba3.blackbox.smbclient_s3.SMB3.plain", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$DC_USERNAME', '$DC_PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "SMB3"])
|
|
|
|
for env in ["nt4_member", "ad_member"]:
|
|
plantestsuite("samba3.blackbox.smbclient_s3.NT1.plain.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$SERVER', '$SERVER/$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "NT1"])
|
|
plantestsuite("samba3.blackbox.smbclient_s3.SMB3.plain.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$SERVER', '$SERVER/$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "SMB3"])
|
|
|
|
for env in ["nt4_dc"]:
|
|
plantestsuite("samba3.blackbox.smbclient_s3.NT1.sign", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$DC_USERNAME', '$DC_PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "NT1", "--signing=required"])
|
|
plantestsuite("samba3.blackbox.smbclient_s3.SMB3.sign", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$DC_USERNAME', '$DC_PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "SMB3", "--signing=required"])
|
|
|
|
for env in ["nt4_member", "ad_member"]:
|
|
plantestsuite("samba3.blackbox.smbclient_s3.NT1.sign.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$SERVER', '$SERVER/$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "NT1", "--signing=required"])
|
|
plantestsuite("samba3.blackbox.smbclient_s3.SMB3.sign.member_creds", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$SERVER', '$SERVER/$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "SMB3", "--signing=required"])
|
|
|
|
for env in ["nt4_dc"]:
|
|
# encrypted
|
|
plantestsuite("samba3.blackbox.smbclient_s3.NT1.crypt", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "NT1", "-e"])
|
|
plantestsuite("samba3.blackbox.smbclient_s3.SMB3.crypt", env, [os.path.join(samba3srcdir, "script/tests/test_smbclient_s3.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, wbinfo, net, configuration, "SMB3", "-e"])
|
|
|
|
for env in ["fileserver"]:
|
|
plantestsuite("samba3.blackbox.preserve_case.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_preserve_case.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, "NT1"])
|
|
plantestsuite("samba3.blackbox.preserve_case.SMB2+", env, [os.path.join(samba3srcdir, "script/tests/test_preserve_case.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, '"SMB2 SMB3"'])
|
|
plantestsuite("samba3.blackbox.dfree_command.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_dfree_command.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, "NT1"])
|
|
plantestsuite("samba3.blackbox.dfree_command.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_dfree_command.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, "SMB3"])
|
|
plantestsuite("samba3.blackbox.dfree_quota.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_dfree_quota.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3, smbcquotas, smbcacls, "NT1"])
|
|
plantestsuite("samba3.blackbox.dfree_quota.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_dfree_quota.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3, smbcquotas, smbcacls, "SMB3"])
|
|
plantestsuite("samba3.blackbox.smbcquotas", env, [os.path.join(samba3srcdir, "script/tests/test_smbcquota.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbcquotas])
|
|
plantestsuite("samba3.blackbox.valid_users", env, [os.path.join(samba3srcdir, "script/tests/test_valid_users.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3])
|
|
plantestsuite("samba3.blackbox.force_create_mode", env, [os.path.join(samba3srcdir, "script/tests/test_force_create_mode.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$PREFIX', env, smbclient3])
|
|
plantestsuite("samba3.blackbox.dropbox", env, [os.path.join(samba3srcdir, "script/tests/test_dropbox.sh"), '$SERVER', '$DOMAIN', 'gooduser', '$PASSWORD', '$PREFIX', env, smbclient3])
|
|
plantestsuite("samba3.blackbox.offline", env, [os.path.join(samba3srcdir, "script/tests/test_offline.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH/offline', smbclient3])
|
|
plantestsuite("samba3.blackbox.shadow_copy2.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_shadow_copy.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH/shadow', smbclient3, '-m', 'NT1'])
|
|
plantestsuite("samba3.blackbox.shadow_copy2.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_shadow_copy.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH/shadow', smbclient3, '-m', 'SMB3'])
|
|
plantestsuite("samba3.blackbox.shadow_copy_torture", env, [os.path.join(samba3srcdir, "script/tests/test_shadow_copy_torture.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH/shadow', smbtorture4])
|
|
plantestsuite("samba3.blackbox.smbclient.forceuser_validusers", env, [os.path.join(samba3srcdir, "script/tests/test_forceuser_validusers.sh"), '$SERVER', '$DOMAIN', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3])
|
|
plantestsuite("samba3.blackbox.smbget", env, [os.path.join(samba3srcdir, "script/tests/test_smbget.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', 'smbget_user', '$PASSWORD', '$LOCAL_PATH/smbget', smbget])
|
|
plantestsuite("samba3.blackbox.netshareenum", env, [os.path.join(samba3srcdir, "script/tests/test_shareenum.sh"), '$SERVER', '$USERNAME', '$PASSWORD', rpcclient])
|
|
plantestsuite("samba3.blackbox.acl_xattr.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_acl_xattr.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, '-mNT1'])
|
|
plantestsuite("samba3.blackbox.acl_xattr.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_acl_xattr.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, '-mSMB3'])
|
|
plantestsuite("samba3.blackbox.smb2.not_casesensitive", env, [os.path.join(samba3srcdir, "script/tests/test_smb2_not_casesensitive.sh"), '//$SERVER/tmp', '$SERVER_IP', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3])
|
|
plantestsuite("samba3.blackbox.inherit_owner.default.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'tmp', '0', '0', '-m', 'NT1'])
|
|
plantestsuite("samba3.blackbox.inherit_owner.default.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'tmp', '0', '0', '-m', 'SMB3'])
|
|
plantestsuite("samba3.blackbox.inherit_owner.full.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'inherit_owner', '1', '1', '-m', 'NT1'])
|
|
plantestsuite("samba3.blackbox.inherit_owner.full.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'inherit_owner', '1', '1', '-m', 'SMB3'])
|
|
plantestsuite("samba3.blackbox.inherit_owner.unix.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'inherit_owner_u', '0', '1', '-m', 'NT1'])
|
|
plantestsuite("samba3.blackbox.inherit_owner.unix.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_inherit_owner.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'inherit_owner_u', '0', '1', '-m', 'SMB3'])
|
|
plantestsuite("samba3.blackbox.large_acl.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_large_acl.sh"), '$SERVER', '$USERNAME', '$PASSWORD', smbclient3, smbcacls, '-m', 'NT1'])
|
|
plantestsuite("samba3.blackbox.large_acl.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_large_acl.sh"), '$SERVER', '$USERNAME', '$PASSWORD', smbclient3, smbcacls, '-m', 'SMB3'])
|
|
plantestsuite("samba3.blackbox.give_owner", env, [os.path.join(samba3srcdir, "script/tests/test_give_owner.sh"), '$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'tmp'])
|
|
plantestsuite("samba3.blackbox.homes", env, [os.path.join(samba3srcdir, "script/tests/test_homes.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', '$PREFIX', smbclient3, configuration])
|
|
plantestsuite("samba3.blackbox.force_group_change", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_force_group_change.sh"),
|
|
'$SERVER', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3, smbcontrol])
|
|
plantestsuite("samba3.blackbox.zero-data", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_zero_data.sh"),
|
|
'$SERVER_IP', '$USERNAME', '$PASSWORD', '$LOCAL_PATH'])
|
|
plantestsuite("samba3.blackbox.timestamps", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_timestamps.sh"),
|
|
'$SERVER_IP', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3])
|
|
|
|
#
|
|
# tar command tests
|
|
#
|
|
|
|
# Test smbclient/tarmode
|
|
plantestsuite("samba3.blackbox.smbclient_tarmode.NT1", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_tarmode.sh"),
|
|
'$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD',
|
|
'$LOCAL_PATH/tarmode', '$PREFIX', smbclient3, configuration, "-mNT1"])
|
|
plantestsuite("samba3.blackbox.smbclient_tarmode.SMB3", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_tarmode.sh"),
|
|
'$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD',
|
|
'$LOCAL_PATH/tarmode', '$PREFIX', smbclient3, configuration, "-mSMB3"])
|
|
|
|
# Test suite for new smbclient/tar with libarchive (GSoC 13)
|
|
plantestsuite("samba3.blackbox.smbclient_tar.NT1", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_tarmode.pl"),
|
|
'-n', '$SERVER', '-i', '$SERVER_IP', '-s', 'tmp',
|
|
'-u', '$USERNAME', '-p', '$PASSWORD', '-l', '$LOCAL_PATH/tarmode',
|
|
'-d', '$PREFIX', '-b', smbclient3,
|
|
'--subunit', '--', configuration, '-mNT1'])
|
|
plantestsuite("samba3.blackbox.smbclient_tar.SMB3", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_tarmode.pl"),
|
|
'-n', '$SERVER', '-i', '$SERVER_IP', '-s', 'tmp',
|
|
'-u', '$USERNAME', '-p', '$PASSWORD', '-l', '$LOCAL_PATH/tarmode',
|
|
'-d', '$PREFIX', '-b', smbclient3,
|
|
'--subunit', '--', configuration, '-mSMB3'])
|
|
|
|
for env in ["fileserver:local"]:
|
|
plantestsuite("samba3.blackbox.net_usershare", env, [os.path.join(samba3srcdir, "script/tests/test_net_usershare.sh"), '$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD', smbclient3])
|
|
|
|
plantestsuite("samba3.blackbox.smbstatus", env, [os.path.join(samba3srcdir, "script/tests/test_smbstatus.sh"), '$SERVER', '$SERVER_IP', '$DOMAIN', '$USERNAME', '$PASSWORD', '$USERID', '$LOCAL_PATH', '$PREFIX', smbclient3, smbstatus, configuration, "SMB3"])
|
|
plantestsuite("samba3.blackbox.net_registry_import", env, [os.path.join(samba3srcdir, "script/tests/test_net_registry_import.sh"), '$SERVER', '$LOCAL_PATH', '$USERNAME', '$PASSWORD'])
|
|
|
|
# TODO encrypted against member, with member creds, and with DC creds
|
|
plantestsuite("samba3.blackbox.net.misc", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_misc.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, "NT1"])
|
|
plantestsuite("samba3.blackbox.net.misc", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_misc.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, "SMB3"])
|
|
plantestsuite("samba3.blackbox.net.local.registry", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_registry.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration])
|
|
plantestsuite("samba3.blackbox.net.registry.check", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_registry_check.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, dbwrap_tool])
|
|
plantestsuite("samba3.blackbox.net.rpc.registry", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_registry.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, 'rpc'])
|
|
|
|
plantestsuite("samba3.blackbox.net.local.registry.roundtrip", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_registry_roundtrip.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration])
|
|
plantestsuite("samba3.blackbox.net.rpc.registry.roundtrip", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_registry_roundtrip.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, 'rpc'])
|
|
|
|
plantestsuite("samba3.blackbox.net.local.conf", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_conf.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration])
|
|
plantestsuite("samba3.blackbox.net.rpc.conf", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_conf.sh"),
|
|
scriptdir, "$SMB_CONF_PATH", net, configuration, 'rpc'])
|
|
|
|
|
|
plantestsuite("samba3.blackbox.testparm", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_testparm_s3.sh"),
|
|
"$LOCAL_PATH"])
|
|
|
|
plantestsuite(
|
|
"samba3.pthreadpool", "none",
|
|
[os.path.join(samba3srcdir, "script/tests/test_pthreadpool.sh")])
|
|
|
|
if with_pthreadpool and have_ldwrap:
|
|
plantestsuite("samba3.pthreadpool_cmocka", "none",
|
|
[os.path.join(bindir(), "pthreadpooltest_cmocka")])
|
|
|
|
if with_pthreadpool:
|
|
plantestsuite("samba3.libwbclient_threads",
|
|
"nt4_member",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_libwbclient_threads.sh"),
|
|
"$DOMAIN", "$DC_USERNAME"])
|
|
|
|
plantestsuite("samba3.test_nfs4_acl", "none",
|
|
[os.path.join(bindir(), "test_nfs4_acls"),
|
|
"$SMB_CONF_PATH"])
|
|
|
|
plantestsuite(
|
|
"samba3.resolvconf", "none",
|
|
[os.path.join(samba3srcdir, "script/tests/test_resolvconf.sh")])
|
|
|
|
plantestsuite("samba3.tevent_glib_glue", "none",
|
|
[os.path.join(samba3srcdir, "script/tests/test_tevent_glib_glue.sh")])
|
|
|
|
plantestsuite("samba3.async_req", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_async_req.sh")])
|
|
|
|
# smbtorture4 tests
|
|
|
|
base = ["base.attr", "base.charset", "base.chkpath", "base.createx_access", "base.defer_open", "base.delaywrite", "base.delete",
|
|
"base.deny1", "base.deny2", "base.deny3", "base.denydos", "base.dir1", "base.dir2",
|
|
"base.disconnect", "base.fdpass", "base.lock",
|
|
"base.mangle", "base.negnowait", "base.ntdeny1",
|
|
"base.ntdeny2", "base.open", "base.openattr", "base.properties", "base.rename", "base.rw1",
|
|
"base.secleak", "base.tcon", "base.tcondev", "base.trans2", "base.unlink", "base.vuid",
|
|
"base.xcopy", "base.samba3error"]
|
|
|
|
raw = ["raw.acls", "raw.chkpath", "raw.close", "raw.composite", "raw.context", "raw.eas",
|
|
"raw.ioctl", "raw.lock", "raw.mkdir", "raw.mux", "raw.notify", "raw.open", "raw.oplock",
|
|
"raw.qfileinfo", "raw.qfsinfo", "raw.read", "raw.rename", "raw.search", "raw.seek",
|
|
"raw.sfileinfo.base", "raw.sfileinfo.bug", "raw.streams", "raw.unlink", "raw.write",
|
|
"raw.samba3hide", "raw.samba3badpath", "raw.sfileinfo.rename", "raw.session",
|
|
"raw.samba3caseinsensitive", "raw.samba3posixtimedlock",
|
|
"raw.samba3rootdirfid", "raw.sfileinfo.end-of-file",
|
|
"raw.bench-oplock", "raw.bench-lock", "raw.bench-open", "raw.bench-tcon",
|
|
"raw.samba3checkfsp", "raw.samba3closeerr", "raw.samba3oplocklogoff", "raw.samba3badnameblob"]
|
|
|
|
smb2 = smbtorture4_testsuites("smb2.")
|
|
|
|
rpc = ["rpc.authcontext", "rpc.samba3.bind", "rpc.samba3.srvsvc", "rpc.samba3.sharesec",
|
|
"rpc.samba3.spoolss", "rpc.samba3.wkssvc", "rpc.samba3.winreg",
|
|
"rpc.samba3.getaliasmembership-0",
|
|
"rpc.samba3.netlogon", "rpc.samba3.sessionkey", "rpc.samba3.getusername",
|
|
"rpc.samba3.smb1-pipe-name", "rpc.samba3.smb2-pipe-name",
|
|
"rpc.samba3.smb-reauth1", "rpc.samba3.smb-reauth2",
|
|
"rpc.samba3.lsa_over_netlogon", "rpc.samba3.pipes_supported_interfaces",
|
|
"rpc.svcctl", "rpc.ntsvcs", "rpc.winreg", "rpc.eventlog",
|
|
"rpc.spoolss.printserver", "rpc.spoolss.win", "rpc.spoolss.notify", "rpc.spoolss.printer",
|
|
"rpc.spoolss.driver",
|
|
"rpc.lsa", "rpc.lsa-getuser", "rpc.lsa.lookupsids", "rpc.lsa.lookupnames",
|
|
"rpc.lsa.privileges", "rpc.lsa.secrets",
|
|
"rpc.mdssvc",
|
|
"rpc.samr", "rpc.samr.users", "rpc.samr.users.privileges", "rpc.samr.passwords",
|
|
"rpc.samr.passwords.pwdlastset", "rpc.samr.passwords.lockout", "rpc.samr.passwords.badpwdcount", "rpc.samr.large-dc", "rpc.samr.machine.auth",
|
|
"rpc.samr.priv", "rpc.samr.passwords.validate",
|
|
"rpc.netlogon.admin",
|
|
"rpc.schannel", "rpc.schannel2", "rpc.bench-schannel1", "rpc.schannel_anon_setpw", "rpc.join", "rpc.bind",
|
|
"rpc.initshutdown", "rpc.wkssvc", "rpc.srvsvc"]
|
|
|
|
local = ["local.nss"]
|
|
|
|
idmap = ["idmap.rfc2307", "idmap.alloc", "idmap.rid", "idmap.ad"]
|
|
|
|
rap = ["rap.basic", "rap.rpc", "rap.printing", "rap.sam"]
|
|
|
|
unix = ["unix.info2", "unix.whoami"]
|
|
|
|
nbt = ["nbt.dgram"]
|
|
|
|
vfs = [
|
|
"vfs.fruit",
|
|
"vfs.acl_xattr",
|
|
"vfs.fruit_netatalk",
|
|
"vfs.fruit_file_id",
|
|
"vfs.fruit_timemachine",
|
|
"vfs.fruit_conversion",
|
|
"vfs.unfruit",
|
|
]
|
|
|
|
tests = base + raw + smb2 + rpc + unix + local + rap + nbt + idmap + vfs
|
|
|
|
for t in tests:
|
|
if t == "base.delaywrite" or t == "base.deny1" or t == "base.deny2":
|
|
plansmbtorture4testsuite(t, "fileserver", '//$SERVER/tmp -U$USERNAME%$PASSWORD --maximum-runtime=900')
|
|
elif t == "base.createx_access":
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD -k yes --maximum-runtime=900')
|
|
elif t == "rap.sam":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=doscharset=ISO-8859-1')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=doscharset=ISO-8859-1')
|
|
elif t == "winbind.pac":
|
|
plansmbtorture4testsuite(t, "ad_member:local", '//$SERVER/tmp --realm=$REALM --machine-pass --option=torture:addc=$DC_SERVER', description="machine account")
|
|
elif t == "unix.whoami":
|
|
plansmbtorture4testsuite(t, "nt4_member:local", '//$SERVER/tmp --machine-pass', description="machine account")
|
|
plansmbtorture4testsuite(t, "ad_member:local", '//$SERVER/tmp --machine-pass --option=torture:addc=$DC_SERVER', description="machine account")
|
|
for env in ["nt4_dc", "nt4_member"]:
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmp -U$DC_USERNAME%$DC_PASSWORD')
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmpguest -U%', description='anonymous connection')
|
|
for env in ["ad_dc", "ad_member"]:
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmp -U$DC_USERNAME@$REALM%$DC_PASSWORD --option=torture:addc=$DC_SERVER')
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmp -k yes -U$DC_USERNAME@$REALM%$DC_PASSWORD --option=torture:addc=$DC_SERVER', description='kerberos connection')
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmpguest -U% --option=torture:addc=$DC_SERVER', description='anonymous connection')
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmp -k no -U$DC_USERNAME@$REALM%$DC_PASSWORD', description='ntlm user@realm')
|
|
elif t == "raw.samba3posixtimedlock" or t == "smb2.samba3misc":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmpguest -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/brl_delay_inject1 -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share',
|
|
description="brl_delay_inject1")
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/brl_delay_inject2 -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share',
|
|
description="brl_delay_inject2")
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmpguest -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/ad_dc/share')
|
|
elif t == "raw.chkpath":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmpcase -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmpcase -U$USERNAME%$PASSWORD')
|
|
elif t == "raw.samba3hide" or t == "raw.samba3checkfsp" or t == "raw.samba3closeerr":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "simpleserver", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "raw.session":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD', 'plain')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmpenc -U$USERNAME%$PASSWORD', 'enc')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -k no -U$USERNAME%$PASSWORD', 'ntlm')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -k yes -U$USERNAME%$PASSWORD', 'krb5')
|
|
elif t == "smb2.session":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD', 'plain')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmpenc -U$USERNAME%$PASSWORD', 'enc')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -k no -U$USERNAME%$PASSWORD', 'ntlm')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -k yes -U$USERNAME%$PASSWORD', 'krb5')
|
|
# Certain tests fail when run against ad_member with MIT kerberos because the private krb5.conf overrides the provisioned lib/krb5.conf,
|
|
# ad_member_idmap_rid sets "create krb5.conf = no"
|
|
plansmbtorture4testsuite(t, "ad_member_idmap_rid", '//$SERVER/tmp -k yes -U$DC_USERNAME@$REALM%$DC_PASSWORD', 'krb5')
|
|
elif t == "rpc.lsa":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD', 'over ncacn_np ')
|
|
plansmbtorture4testsuite(t, "nt4_dc", 'ncacn_ip_tcp:$SERVER_IP -U$USERNAME%$PASSWORD', 'over ncacn_ip_tcp ')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD', 'over ncacn_np ')
|
|
plansmbtorture4testsuite(t, "ad_dc", 'ncacn_ip_tcp:$SERVER_IP -U$USERNAME%$PASSWORD', 'over ncacn_ip_tcp ')
|
|
elif t == "rpc.mdssvc":
|
|
plansmbtorture4testsuite(t, "fileserver", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=torture:no_spotlight_localdir=$SELFTEST_PREFIX/fileserver/share')
|
|
elif t == "rpc.samr.passwords.validate":
|
|
plansmbtorture4testsuite(t, "nt4_dc", 'ncacn_ip_tcp:$SERVER_IP[seal] -U$USERNAME%$PASSWORD', 'over ncacn_ip_tcp ')
|
|
plansmbtorture4testsuite(t, "ad_dc", 'ncacn_ip_tcp:$SERVER_IP[seal] -U$USERNAME%$PASSWORD', 'over ncacn_ip_tcp ')
|
|
elif t == "smb2.durable-open" or t == "smb2.durable-v2-open" or t == "smb2.replay" or t == "smb2.durable-v2-delay":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/durable -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/durable -U$USERNAME%$PASSWORD')
|
|
elif t == "base.rw1":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/valid-users-tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/write-list-tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "idmap.rfc2307":
|
|
plantestsuite(t, "ad_member_rfc2307",
|
|
[os.path.join(samba3srcdir,
|
|
"../nsswitch/tests/test_idmap_rfc2307.sh"),
|
|
'$DOMAIN',
|
|
'Administrator', '2000000',
|
|
'Guest', '2000001',
|
|
'"Domain Users"', '2000002',
|
|
'DnsAdmins', '2000003',
|
|
'2000005', '35',
|
|
'ou=idmap,dc=samba,dc=example,dc=com',
|
|
'$DC_SERVER', '$DC_USERNAME', '$DC_PASSWORD'])
|
|
elif t == "idmap.alloc":
|
|
plantestsuite(t, "ad_member_rfc2307", [os.path.join(samba3srcdir, "../nsswitch/tests/test_idmap_nss.sh"), '$DOMAIN'])
|
|
elif t == "idmap.rid":
|
|
plantestsuite(t, "ad_member_idmap_rid", [os.path.join(samba3srcdir, "../nsswitch/tests/test_idmap_rid.sh"), '$DOMAIN', '2000000'])
|
|
elif t == "idmap.ad":
|
|
plantestsuite(t, "ad_member_idmap_ad", [os.path.join(samba3srcdir, "../nsswitch/tests/test_idmap_ad.sh"), '$DOMAIN', '$DC_SERVER', '$DC_PASSWORD', '$TRUST_DOMAIN', '$TRUST_SERVER', '$TRUST_PASSWORD'])
|
|
elif t == "raw.acls":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_simple_40 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-simple-40')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_special_40 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-special-40')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_simple_41 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-simple-41')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_xdr_40 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-xdr-40')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_xdr_41 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-xdr-41')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_nfs_40 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-nfs-40')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/nfs4acl_nfs_41 -U$USERNAME%$PASSWORD', description='nfs4acl_xattr-nfs-41')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmpcase -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.ioctl":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/fs_specific -U$USERNAME%$PASSWORD', 'fs_specific')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.lock":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/aio -U$USERNAME%$PASSWORD', 'aio')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "raw.lock" or t == "base.lock":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "raw.read":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/aio -U$USERNAME%$PASSWORD', 'aio')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "raw.search":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
# test the dirsort module.
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmpsort -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "vfs.fruit":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share --option=torture:share2=vfs_wo_fruit', 'metadata_netatalk')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_metadata_stream -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share --option=torture:share2=vfs_wo_fruit', 'metadata_stream')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_stream_depot -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share --option=torture:share2=vfs_wo_fruit_stream_depot', 'streams_depot')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_delete_empty_adfiles -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share --option=torture:share2=vfs_wo_fruit', 'fruit_delete_empty_adfiles')
|
|
elif t == "vfs.fruit_netatalk":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_xattr -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share')
|
|
elif t == "vfs.fruit_timemachine":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_timemachine -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share')
|
|
elif t == "vfs.fruit_file_id":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_zero_fileid -U$USERNAME%$PASSWORD')
|
|
elif t == "vfs.fruit_conversion":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=torture:share2=vfs_fruit_wipe_intentionally_left_blank_rfork --option=torture:delete_empty_adfiles=false', 'wipe_intentionally_left_blank_rfork')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=torture:share2=vfs_fruit_delete_empty_adfiles --option=torture:delete_empty_adfiles=true', 'delete_empty_adfiles')
|
|
elif t == "vfs.unfruit":
|
|
creds = '-U$USERNAME%$PASSWORD'
|
|
share2 = '--option=torture:share2=tmp'
|
|
netopt = '--option=torture:net=%s' % net
|
|
shareopt = '--option=torture:sharename'
|
|
|
|
plansmbtorture4testsuite(t, "nt4_dc:local", '//$SERVER_IP/vfs_fruit %s %s %s %s=%s' % (creds, share2, netopt, shareopt, 'vfs_fruit'), 'metadata_netatalk')
|
|
plansmbtorture4testsuite(t, "nt4_dc:local", '//$SERVER_IP/vfs_fruit_metadata_stream %s %s %s %s=%s' % (creds, share2, netopt, shareopt, 'vfs_fruit_metadata_stream'), 'metadata_stream')
|
|
plansmbtorture4testsuite(t, "nt4_dc:local", '//$SERVER_IP/vfs_fruit_stream_depot %s %s %s %s=%s' % (creds, share2, netopt, shareopt, 'vfs_fruit_stream_depot'), 'streams_depot')
|
|
elif t == "rpc.schannel_anon_setpw":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$%', description="anonymous password set")
|
|
plansmbtorture4testsuite(t, "nt4_dc_schannel", '//$SERVER_IP/tmp -U$%', description="anonymous password set (schannel enforced server-side)")
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$%', description="anonymous password set")
|
|
elif t == "local.nss":
|
|
for env in ["nt4_dc:local", "ad_member:local", "nt4_member:local", "ad_dc:local"]:
|
|
plansmbtorture4testsuite(t, env, '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.change_notify_disabled":
|
|
plansmbtorture4testsuite(t, "simpleserver", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.notify" or t == "raw.notify" or t == "smb2.oplock" or t == "raw.oplock":
|
|
# These tests are a little slower so don't duplicate them with ad_dc
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --signing=required')
|
|
elif t == "smb2.dosmode":
|
|
plansmbtorture4testsuite(t, "simpleserver", '//$SERVER/dosmode -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.kernel-oplocks":
|
|
if have_linux_kernel_oplocks:
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER/kernel_oplocks -U$USERNAME%$PASSWORD --option=torture:localdir=$SELFTEST_PREFIX/nt4_dc/share')
|
|
elif t == "smb2.notify-inotify":
|
|
if have_inotify:
|
|
plansmbtorture4testsuite(t, "fileserver", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "vfs.acl_xattr":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.compound_find":
|
|
plansmbtorture4testsuite(t, "fileserver", '//$SERVER/compound_find -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "fileserver", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "rpc.samr.users.privileges":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=torture:nt4_dc=true')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.compound":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/aio -U$USERNAME%$PASSWORD', 'aio')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "rpc.samba3.netlogon" or t == "rpc.samba3.sessionkey":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD --option=torture:wksname=samba3rpctest')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD --option=torture:wksname=samba3rpctest')
|
|
elif t == "smb2.streams":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/streams_xattr -U$USERNAME%$PASSWORD', 'streams_xattr')
|
|
elif t == "smb2.aio_delay":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/aio_delay_inject -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.delete-on-close-perms":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/delete_readonly -U$USERNAME%$PASSWORD --option=torture:delete_readonly=true')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "smb2.fileid":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/vfs_fruit_xattr -U$USERNAME%$PASSWORD')
|
|
elif t == "rpc.wkssvc":
|
|
plansmbtorture4testsuite(t, "ad_member", '//$SERVER/tmp -U$DC_USERNAME%$DC_PASSWORD')
|
|
elif t == "rpc.srvsvc":
|
|
plansmbtorture4testsuite(t, "ad_member", '//$SERVER/tmp -U$DC_USERNAME%$DC_PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$DC_USERNAME%$DC_PASSWORD')
|
|
elif t == "rpc.samba3.lsa_over_netlogon":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "rpc.samba3.pipes_supported_interfaces":
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
elif t == "rpc.spoolss.notify":
|
|
plansmbtorture4testsuite(t, "ad_member", '//$SERVER_IP/tmp -U$DC_USERNAME%$DC_PASSWORD')
|
|
else:
|
|
plansmbtorture4testsuite(t, "nt4_dc", '//$SERVER_IP/tmp -U$USERNAME%$PASSWORD')
|
|
plansmbtorture4testsuite(t, "ad_dc", '//$SERVER/tmp -U$USERNAME%$PASSWORD')
|
|
|
|
|
|
test = 'rpc.lsa.lookupsids'
|
|
auth_options = ["", "ntlm", "spnego", "spnego,ntlm", "spnego,smb1", "spnego,smb2"]
|
|
signseal_options = ["", ",connect", ",packet", ",sign", ",seal"]
|
|
endianness_options = ["", ",bigendian"]
|
|
for s in signseal_options:
|
|
for e in endianness_options:
|
|
for a in auth_options:
|
|
binding_string = "ncacn_np:$SERVER[%s%s%s]" % (a, s, e)
|
|
options = binding_string + " -U$USERNAME%$PASSWORD"
|
|
plansmbtorture4testsuite(test, "nt4_dc", options, 'over ncacn_np with [%s%s%s] ' % (a, s, e))
|
|
plantestsuite("samba3.blackbox.rpcclient over ncacn_np with [%s%s%s] " % (a, s, e), "nt4_dc:local", [os.path.join(samba3srcdir, "script/tests/test_rpcclient.sh"),
|
|
"none", options, configuration])
|
|
|
|
# We should try more combinations in future, but this is all
|
|
# the pre-calculated credentials cache supports at the moment
|
|
#
|
|
# As the ktest env requires SMB3_00 we need to use "smb2" until
|
|
# dcerpc client code in smbtorture support autonegotiation
|
|
# of any smb dialect.
|
|
e = ""
|
|
a = "smb2"
|
|
binding_string = "ncacn_np:$SERVER[%s%s%s]" % (a, s, e)
|
|
options = binding_string + " -k yes --krb5-ccache=$PREFIX/ktest/krb5_ccache-2"
|
|
plansmbtorture4testsuite(test, "ktest", options, 'krb5 with old ccache ncacn_np with [%s%s%s] ' % (a, s, e))
|
|
|
|
options = binding_string + " -k yes --krb5-ccache=$PREFIX/ktest/krb5_ccache-3"
|
|
plansmbtorture4testsuite(test, "ktest", options, 'krb5 ncacn_np with [%s%s%s] ' % (a, s, e))
|
|
|
|
auth_options2 = ["krb5", "spnego,krb5"]
|
|
for a in auth_options2:
|
|
binding_string = "ncacn_np:$SERVER[%s%s%s]" % (a, s, e)
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient krb5 ncacn_np with [%s%s%s] " % (a, s, e), "ktest:local", [os.path.join(samba3srcdir, "script/tests/test_rpcclient.sh"),
|
|
"$PREFIX/ktest/krb5_ccache-3", binding_string, "-k", configuration])
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient_samlogon", "ad_member:local", [os.path.join(samba3srcdir, "script/tests/test_rpcclient_samlogon.sh"),
|
|
"$DC_USERNAME", "$DC_PASSWORD", "ncacn_np:$DC_SERVER", configuration])
|
|
plantestsuite("samba3.blackbox.sharesec", "simpleserver:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_sharesec.sh"),
|
|
configuration, os.path.join(bindir(), "sharesec"),
|
|
os.path.join(bindir(), "net"), "tmp"])
|
|
|
|
plantestsuite("samba3.blackbox.close-denied-share", "simpleserver:local",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_close_denied_share.sh"),
|
|
configuration,
|
|
os.path.join(bindir(), "sharesec"),
|
|
os.path.join(bindir(), "smbclient"),
|
|
os.path.join(bindir(), "smbcontrol"),
|
|
'$SERVER_IP',
|
|
"tmp"])
|
|
|
|
plantestsuite("samba3.blackbox.force-close-share", "simpleserver:local",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_force_close_share.sh"),
|
|
configuration,
|
|
os.path.join(bindir(), "smbclient"),
|
|
os.path.join(bindir(), "smbcontrol"),
|
|
'$SERVER_IP',
|
|
"aio_delay_inject"])
|
|
|
|
plantestsuite("samba3.blackbox.open-eintr", "simpleserver:local",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_open_eintr.sh"),
|
|
configuration,
|
|
os.path.join(bindir(), "smbclient"),
|
|
os.path.join(bindir(), "smbcontrol"),
|
|
'$SERVER_IP',
|
|
"error_inject"])
|
|
|
|
plantestsuite("samba3.blackbox.net_tdb", "simpleserver:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_tdb.sh"),
|
|
smbclient3, '$SERVER', 'tmp', '$USERNAME', '$PASSWORD',
|
|
configuration, '$LOCAL_PATH', '$LOCK_DIR'])
|
|
|
|
plantestsuite("samba3.blackbox.smbd_error", "simpleserver:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbd_error.sh")])
|
|
|
|
plantestsuite("samba3.blackbox.smbd_no_krb5", "ad_member:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbd_no_krb5.sh"),
|
|
smbclient3, '$SERVER', "$DC_USERNAME", "$DC_PASSWORD", "$PREFIX"])
|
|
|
|
plantestsuite("samba3.blackbox.durable_v2_delay", "simpleserver:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_durable_handle_reconnect.sh")])
|
|
|
|
plantestsuite("samba3.blackbox.net_cache_samlogon", "ad_member:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_cache_samlogon.sh"),
|
|
'$SERVER', 'tmp', '$DC_USERNAME', '$DC_PASSWORD'])
|
|
|
|
plantestsuite("samba3.blackbox.net_rpc_share_allowedusers", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_rpc_share_allowedusers.sh"),
|
|
"$SERVER", "$USERNAME", "$PASSWORD", "$PREFIX/net_rpc_share_allowedusers",
|
|
configuration])
|
|
|
|
plantestsuite("samba3.blackbox.net_dom_join_fail_dc", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_dom_join_fail_dc.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER", "$PREFIX/net_dom_join_fail_dc",
|
|
configuration])
|
|
plantestsuite("samba3.blackbox.net_rpc_join", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_rpc_join.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER", "$PREFIX/net_rpc_join",
|
|
configuration])
|
|
plantestsuite("samba3.blackbox.net_rpc_oldjoin", "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_rpc_oldjoin.sh"),
|
|
"$SERVER", "$PREFIX/net_rpc_oldjoin",
|
|
"$SMB_CONF_PATH"])
|
|
plantestsuite("samba3.blackbox.net_rpc_join_creds", "nt4_dc",
|
|
[os.path.join(samba3srcdir, "script/tests/test_net_rpc_join_creds.sh"),
|
|
"$DOMAIN", "$USERNAME", "$PASSWORD", "$SERVER", "$PREFIX/net_rpc_join_creds",
|
|
configuration])
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient_srvsvc", "simpleserver",
|
|
[os.path.join(samba3srcdir, "script/tests/test_rpcclientsrvsvc.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER",
|
|
os.path.join(bindir(), "rpcclient"), "tmp"])
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient_lookup", "simpleserver",
|
|
[os.path.join(samba3srcdir, "script/tests/test_rpcclient_lookup.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER",
|
|
os.path.join(bindir(), "rpcclient")])
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient.pw-nt-hash", "simpleserver",
|
|
[os.path.join(samba3srcdir, "script/tests/test_rpcclient_pw_nt_hash.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER",
|
|
os.path.join(bindir(), "rpcclient")])
|
|
|
|
plantestsuite("samba3.blackbox.smbclient.encryption_off", "simpleserver",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_encryption_off.sh"),
|
|
"$USERNAME", "$PASSWORD", "$SERVER",
|
|
smbclient3])
|
|
|
|
plantestsuite("samba3.blackbox.rpcclient_netsessenum", "ad_member",
|
|
[os.path.join(samba3srcdir,
|
|
"script/tests/test_rpcclient_netsessenum.sh"),
|
|
"$DOMAIN", "$DC_USERNAME", "$DC_PASSWORD", "$SERVER",
|
|
os.path.join(bindir(), "rpcclient"), smbtorture3, "tmp"])
|
|
|
|
# The ktest environment uses:
|
|
# server min protocol = SMB3_00
|
|
# client max protocol = SMB3
|
|
options_list = ["", "-e"]
|
|
for options in options_list:
|
|
plantestsuite("samba3.blackbox.smbclient_krb5 old ccache %s" % options, "ktest:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_krb5.sh"),
|
|
"$PREFIX/ktest/krb5_ccache-2",
|
|
smbclient3, "$SERVER", options, configuration])
|
|
|
|
plantestsuite("samba3.blackbox.smbclient_krb5 new ccache %s" % options, "ktest:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_krb5.sh"),
|
|
"$PREFIX/ktest/krb5_ccache-3",
|
|
smbclient3, "$SERVER", options, configuration])
|
|
|
|
plantestsuite("samba3.blackbox.smbclient_large_file %s krb5" % options, "ktest:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_large_file.sh"),
|
|
"$PREFIX/ktest/krb5_ccache-3",
|
|
smbclient3, "$SERVER", "$PREFIX", options, "-k " + configuration])
|
|
|
|
options_list = ["-mNT1", "-mNT1 -e", "-mSMB3", "-mSMB3 -e"]
|
|
for options in options_list:
|
|
plantestsuite("samba3.blackbox.smbclient_large_file %s NTLM" % options, "nt4_dc:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_large_file.sh"),
|
|
"none",
|
|
smbclient3, "$SERVER", "$PREFIX", options, "-U$USERNAME%$PASSWORD " + configuration])
|
|
|
|
for alias in ["foo", "bar"]:
|
|
plantestsuite("samba3.blackbox.smbclient_netbios_aliases [%s]" % alias, "ad_member:local",
|
|
[os.path.join(samba3srcdir, "script/tests/test_smbclient_netbios_aliases.sh"),
|
|
smbclient3, alias, "$DC_USERNAME", "$DC_PASSWORD", "$PREFIX", options, configuration])
|
|
|
|
for e in endianness_options:
|
|
for a in auth_options:
|
|
for s in signseal_options:
|
|
binding_string = "ncacn_ip_tcp:$SERVER_IP[%s%s%s]" % (a, s, e)
|
|
options = binding_string + " -U$USERNAME%$PASSWORD"
|
|
plansmbtorture4testsuite(test, "nt4_dc", options, 'over ncacn_ip_tcp with [%s%s%s] ' % (a, s, e))
|
|
|
|
plansmbtorture4testsuite('rpc.epmapper', 'nt4_dc:local', 'ncalrpc: -U$USERNAME%$PASSWORD', 'over ncalrpc')
|
|
plansmbtorture4testsuite('rpc.fsrvp', 'nt4_dc:local', 'ncacn_np:$SERVER_IP -U$USERNAME%$PASSWORD', 'over ncacn_np')
|
|
|
|
for env in ["ad_member_idmap_rid:local", "maptoguest:local"]:
|
|
plantestsuite("samba3.blackbox.guest", env,
|
|
[os.path.join(samba3srcdir, "script/tests/test_guest_auth.sh"),
|
|
'$SERVER', smbclient3, smbcontrol, net, configuration])
|
|
|
|
plantestsuite("samba3.blackbox.itime", "ad_dc", [os.path.join(samba3srcdir, "script/tests/test_itime.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', smbclient3, 'xattr'])
|
|
|
|
|
|
def planclusteredmembertestsuite(tname, prefix):
|
|
'''Define a clustered test for the clusteredmember environment'''
|
|
|
|
tshare = 'tmp'
|
|
|
|
autharg = '-U${DOMAIN}/${DC_USERNAME}%${DC_PASSWORD}'
|
|
namearg = 'clustered.%s' % tname
|
|
modnamearg = 'samba3.%s' % namearg
|
|
extraargs = ''
|
|
|
|
prefix = os.path.join(prefix, 'clusteredmember')
|
|
unclist = os.path.join(prefix, 'unclists/%s.txt' % tshare)
|
|
|
|
unclistarg = '--unclist=%s' % unclist
|
|
sharearg = '//$SERVER_IP/%s' % tshare
|
|
|
|
return selftesthelpers.plansmbtorture4testsuite(
|
|
namearg,
|
|
'clusteredmember',
|
|
[extraargs, unclistarg, sharearg, autharg, tname],
|
|
target='samba3',
|
|
modname=modnamearg)
|
|
|
|
|
|
CLUSTERED_TESTS = [ 'base.ntdeny2' ]
|
|
|
|
for test in CLUSTERED_TESTS:
|
|
planclusteredmembertestsuite(test, "$PREFIX")
|