summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--selftest/tests.py1
-rw-r--r--source4/selftest/provisions/alpha13/etc/smb.conf.template10
-rwxr-xr-xtestprogs/blackbox/upgradeprovision-alpha13.sh135
3 files changed, 141 insertions, 5 deletions
diff --git a/selftest/tests.py b/selftest/tests.py
index d845834957..03bedfcad6 100644
--- a/selftest/tests.py
+++ b/selftest/tests.py
@@ -46,6 +46,7 @@ planpythontestsuite("none", "samba.tests.messaging")
planpythontestsuite("none", "samba.tests.samba3sam")
planpythontestsuite("none", "wafsamba.tests.test_suite", extra_path=[os.path.join(samba4srcdir, "..", "buildtools"), os.path.join(samba4srcdir, "..", "buildtools", "wafadmin")])
plantestsuite("samba4.blackbox.dbcheck.alpha13", "none" , ["PYTHON=%s" % python, os.path.join(bbdir, "dbcheck-alpha13.sh"), '$PREFIX_ABS/provision', configuration])
+plantestsuite("samba4.blackbox.upgradeprovision.alpha13", "none" , ["PYTHON=%s" % python, os.path.join(bbdir, "upgradeprovision-alpha13.sh"), '$PREFIX_ABS/provision', configuration])
planpythontestsuite("none", "samba.tests.upgradeprovision")
planpythontestsuite("none", "samba.tests.xattr")
planpythontestsuite("none", "samba.tests.ntacls")
diff --git a/source4/selftest/provisions/alpha13/etc/smb.conf.template b/source4/selftest/provisions/alpha13/etc/smb.conf.template
index cc6c82ff2d..ffdcc04141 100644
--- a/source4/selftest/provisions/alpha13/etc/smb.conf.template
+++ b/source4/selftest/provisions/alpha13/etc/smb.conf.template
@@ -4,14 +4,14 @@
realm = ALPHA13.SAMBA.CORP
server role = domain controller
- private dir = @@PREFIX@@/alpha13/private
- lock dir = @@PREFIX@@/alpha13
- posix:eadb = @@PREFIX@@/alpha13/private/eadb.tdb
+ private dir = @@PREFIX@@/private
+ lock dir = @@PREFIX@@/
+ posix:eadb = @@PREFIX@@/private/eadb.tdb
[netlogon]
- path = @@PREFIX@@/alpha13/sysvol/alpha13.samba.corp/scripts
+ path = @@PREFIX@@/sysvol/alpha13.samba.corp/scripts
read only = no
[sysvol]
- path = @@PREFIX@@/alpha13/sysvol
+ path = @@PREFIX@@/sysvol
read only = no
diff --git a/testprogs/blackbox/upgradeprovision-alpha13.sh b/testprogs/blackbox/upgradeprovision-alpha13.sh
new file mode 100755
index 0000000000..1747c7b4e9
--- /dev/null
+++ b/testprogs/blackbox/upgradeprovision-alpha13.sh
@@ -0,0 +1,135 @@
+#!/bin/sh
+
+if [ $# -lt 1 ]; then
+cat <<EOF
+Usage: dbcheck.sh PREFIX
+EOF
+exit 1;
+fi
+
+PREFIX_ABS="$1"
+shift 1
+
+. `dirname $0`/subunit.sh
+
+alpha13_dir=`dirname $0`/../../source4/selftest/provisions/alpha13
+
+alpha13() {
+ if test -x $BINDIR/tdbrestore;
+ then
+ `dirname $0`/../../source4/selftest/provisions/undump.sh $alpha13_dir $PREFIX_ABS/alpha13_upgrade $BINDIR/tdbrestore
+ `dirname $0`/../../source4/selftest/provisions/undump.sh $alpha13_dir $PREFIX_ABS/alpha13_upgrade_full $BINDIR/tdbrestore
+ else
+ `dirname $0`/../../source4/selftest/provisions/undump.sh $alpha13_dir $PREFIX_ABS/alpha13_upgrade
+ `dirname $0`/../../source4/selftest/provisions/undump.sh $alpha13_dir $PREFIX_ABS/alpha13_upgrade_full
+ fi
+ cp -a $alpha13_dir/private/*.keytab $PREFIX_ABS/alpha13_upgrade/private/
+ cp -a $alpha13_dir/sysvol $PREFIX_ABS/alpha13_upgrade/
+ mkdir $PREFIX_ABS/alpha13_upgrade/etc/
+ cat $alpha13_dir/etc/smb.conf.template | \
+ sed "s|@@PREFIX@@|$PREFIX_ABS/alpha13_upgrade|g" \
+ > $PREFIX_ABS/alpha13_upgrade/etc/smb.conf
+
+ cp -a $alpha13_dir/private/*.keytab $PREFIX_ABS/alpha13_upgrade_full/private/
+ cp -a $alpha13_dir/sysvol $PREFIX_ABS/alpha13_upgrade_full/
+ mkdir $PREFIX_ABS/alpha13_upgrade_full/etc/
+ cat $alpha13_dir/etc/smb.conf.template | \
+ sed "s|@@PREFIX@@|$PREFIX_ABS/alpha13_upgrade_full|g" \
+ > $PREFIX_ABS/alpha13_upgrade_full/etc/smb.conf
+}
+
+remove_dns_user() {
+ # This is done, because otherwise the upgrdeprovision will not run without --full
+ $BINDIR/ldbdel -H tdb://$PREFIX_ABS/alpha13_upgrade/private/sam.ldb cn=dns,cn=users,dc=alpha13,dc=samba,dc=corp
+}
+
+reindex() {
+ $BINDIR/samba-tool dbcheck --reindex -H tdb://$PREFIX_ABS/alpha13_upgrade/private/sam.ldb $@
+}
+
+# This should 'fail', because it returns the number of modified records
+dbcheck() {
+ $BINDIR/samba-tool dbcheck --cross-ncs --fix --yes -H tdb://$PREFIX_ABS/alpha13_upgrade/private/sam.ldb $@
+}
+
+dbcheck_clean() {
+ $BINDIR/samba-tool dbcheck --cross-ncs -H tdb://$PREFIX_ABS/alpha13_upgrade/private/sam.ldb $@
+}
+
+# This should 'fail', because it returns the number of modified records
+dbcheck_full() {
+ $BINDIR/samba-tool dbcheck --cross-ncs --fix --yes -H tdb://$PREFIX_ABS/alpha13_upgrade_full/private/sam.ldb $@
+}
+
+dbcheck_full_clean() {
+ $BINDIR/samba-tool dbcheck --cross-ncs -H tdb://$PREFIX_ABS/alpha13_upgrade_full/private/sam.ldb $@
+}
+
+upgradeprovision() {
+ $PYTHON $BINDIR/samba_upgradeprovision -s "$PREFIX_ABS/alpha13_upgrade/etc/smb.conf" --debugchange
+}
+
+upgradeprovision_full() {
+ $PYTHON $BINDIR/samba_upgradeprovision -s "$PREFIX_ABS/alpha13_upgrade_full/etc/smb.conf" --full --debugchange
+}
+
+if [ -d $PREFIX_ABS/alpha13_upgrade ]; then
+ rm -fr $PREFIX_ABS/alpha13_upgrade
+fi
+
+if [ -d $PREFIX_ABS/alpha13_upgrade_full ]; then
+ rm -fr $PREFIX_ABS/alpha13_upgrade_full
+fi
+
+if [ -d $alpha13_dir ]; then
+ testit "alpha13" alpha13
+ testit "remove_dns_user" remove_dns_user
+ testit "upgradeprovision" upgradeprovision
+ testit "upgradeprovision_full" upgradeprovision_full
+ testit "reindex" reindex
+ testit_expect_failure "dbcheck" dbcheck
+ testit "dbcheck_clean" dbcheck_clean
+ testit_expect_failure "dbcheck_full" dbcheck_full
+ testit "dbcheck_full_clean" dbcheck_full_clean
+else
+ subunit_start_test "alpha13"
+ subunit_skip_test "alpha13" <<EOF
+no test provision
+EOF
+
+ subunit_start_test "remove_dns_user"
+ subunit_skip_test "remove_dns_user" <<EOF
+no test provision
+EOF
+
+ subunit_start_test "upgradeprovision"
+ subunit_skip_test "upgradeprovision" <<EOF
+no test provision
+EOF
+ subunit_start_test "upgradeprovision_full"
+ subunit_skip_test "upgradeprovision_full" <<EOF
+no test provision
+EOF
+ subunit_start_test "reindex"
+ subunit_skip_test "reindex" <<EOF
+no test provision
+EOF
+ subunit_start_test "dbcheck"
+ subunit_skip_test "dbcheck" <<EOF
+no test provision
+EOF
+ subunit_start_test "dbcheck_clean"
+ subunit_skip_test "dbcheck_clean" <<EOF
+no test provision
+EOF
+ subunit_start_test "dbcheck_full"
+ subunit_skip_test "dbcheck_full" <<EOF
+no test provision
+EOF
+ subunit_start_test "dbcheck_full_clean"
+ subunit_skip_test "dbcheck_full_clean" <<EOF
+no test provision
+EOF
+fi
+
+exit $failed