From b363885250897b37820e08a335e5a043dff2a272 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Thu, 24 Jan 2019 10:15:56 -0800 Subject: s3: tests: Add regression test for smbd crash on share force group change with existing connection. Mark as known fail for now. BUG: https://bugzilla.samba.org/show_bug.cgi?id=13690 Signed-off-by: Jeremy Allison Reviewed-by: Ralph Boehme (cherry picked from commit 7b21b4c1f538650f23ec77fb3c02fe1e224d89aa) --- selftest/knownfail | 2 + selftest/selftesthelpers.py | 1 + selftest/target/Samba3.pm | 6 ++ source3/script/tests/test_force_group_change.sh | 73 +++++++++++++++++++++++++ source3/selftest/tests.py | 3 + 5 files changed, 85 insertions(+) create mode 100755 source3/script/tests/test_force_group_change.sh diff --git a/selftest/knownfail b/selftest/knownfail index 84776d4f35d..52b179a83c2 100644 --- a/selftest/knownfail +++ b/selftest/knownfail @@ -348,3 +348,5 @@ # Disabling NTLM means you can't use samr to change the password ^samba.tests.ntlmdisabled.python\(ktest\).ntlmdisabled.NtlmDisabledTests.test_samr_change_password\(ktest\) ^samba.tests.ntlmdisabled.python\(ad_dc_no_ntlm\).ntlmdisabled.NtlmDisabledTests.test_ntlm_connection\(ad_dc_no_ntlm\) +# BUG:https://bugzilla.samba.org/show_bug.cgi?id=13690 +^samba3.blackbox.force_group_change.* diff --git a/selftest/selftesthelpers.py b/selftest/selftesthelpers.py index 8b885b59419..77313cb2ba6 100644 --- a/selftest/selftesthelpers.py +++ b/selftest/selftesthelpers.py @@ -196,3 +196,4 @@ smbcquotas = binpath('smbcquotas') smbget = binpath('smbget') rpcclient = binpath('rpcclient') smbcacls = binpath('smbcacls') +smbcontrol = binpath('smbcontrol') diff --git a/selftest/target/Samba3.pm b/selftest/target/Samba3.pm index e30d1a4c7c8..ac75d9347e1 100755 --- a/selftest/target/Samba3.pm +++ b/selftest/target/Samba3.pm @@ -928,6 +928,12 @@ sub setup_fileserver($$) force group = everyone write list = force_user +# BUG: https://bugzilla.samba.org/show_bug.cgi?id=13690 +[force_group_test] + path = $share_dir + comment = force group test +# force group = everyone + [smbget] path = $smbget_sharedir comment = smb username is [%U] diff --git a/source3/script/tests/test_force_group_change.sh b/source3/script/tests/test_force_group_change.sh new file mode 100755 index 00000000000..6cb1ab4e048 --- /dev/null +++ b/source3/script/tests/test_force_group_change.sh @@ -0,0 +1,73 @@ +#!/bin/sh + +# Copyright (c) Jeremy Allison +# License: GPLv3 +# Regression test for BUG:https://bugzilla.samba.org/show_bug.cgi?id=13690 + +if [ $# -lt 6 ]; then + echo "Usage: test_force_group_change.sh SERVER USERNAME PASSWORD LOCAL_PATH SMBCLIENT SMBCONTROL" + exit 1 +fi + +SERVER="${1}" +USERNAME="${2}" +PASSWORD="${3}" +LOCAL_PATH="${4}" +SMBCLIENT="${5}" +SMBCONTROL="${6}" +shift 6 + +incdir=`dirname $0`/../../../testprogs/blackbox +. $incdir/subunit.sh + +failed=0 + +test_force_group_change() +{ +# +# A SMB_CONF variable passed in here is the client smb.conf. +# We need to convert to the server.conf file from +# the LOCAL_PATH variable. +# +SERVER_CONFIG=`dirname $LOCAL_PATH`/lib/server.conf +SERVER_CONFIG_SAVE=${SERVER_CONFIG}.bak +SERVER_CONFIG_NEW=${SERVER_CONFIG}.new +cp $SERVER_CONFIG $SERVER_CONFIG_SAVE + +sed -e 's/#\tforce group = everyone/\tforce group = everyone/' <${SERVER_CONFIG} >${SERVER_CONFIG_NEW} + + tmpfile=$PREFIX/smbclient_force_group_change_commands + cat > $tmpfile <