summaryrefslogtreecommitdiff
path: root/testprogs
diff options
context:
space:
mode:
authorAndrew Bartlett <abartlet@samba.org>2013-01-22 23:39:15 +1100
committerAndrew Bartlett <abartlet@samba.org>2013-01-27 11:55:54 +0100
commit0f8ef5a2c83e0496ef79c3d6f8b1188fdd1943a0 (patch)
treeb720ab17269fbaef456b7c95cebc24f8ab45d937 /testprogs
parent58d6d884cf8a8de5a1fa2dfd4a0cbacdff0d2483 (diff)
downloadsamba-0f8ef5a2c83e0496ef79c3d6f8b1188fdd1943a0.tar.gz
samba-0f8ef5a2c83e0496ef79c3d6f8b1188fdd1943a0.tar.bz2
samba-0f8ef5a2c83e0496ef79c3d6f8b1188fdd1943a0.zip
selftest: Add test of upgradeprovision using the old alpha13 tree
This ensures that upgradeprovision works as expected on a known good old database. Andrew Bartlett Reviewed-by: Stefan Metzmacher <metze@samba.org> Autobuild-User(master): Andrew Bartlett <abartlet@samba.org> Autobuild-Date(master): Sun Jan 27 11:55:54 CET 2013 on sn-devel-104
Diffstat (limited to 'testprogs')
-rwxr-xr-xtestprogs/blackbox/upgradeprovision-alpha13.sh135
1 files changed, 135 insertions, 0 deletions
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