testprogs: Add net offlinejoin composeodj tests
authorSamuel Cabrero <scabrero@samba.org>
Mon, 4 Sep 2023 14:49:52 +0000 (16:49 +0200)
committerJule Anger <janger@samba.org>
Wed, 29 Nov 2023 15:55:45 +0000 (15:55 +0000)
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13577

Signed-off-by: Samuel Cabrero <scabrero@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Autobuild-User(master): Andrew Bartlett <abartlet@samba.org>
Autobuild-Date(master): Tue Sep  5 22:11:46 UTC 2023 on atb-devel-224

(cherry picked from commit f3c632e74ba100b455eeac66e8914b11d1d9b0a0)

Autobuild-User(v4-18-test): Jule Anger <janger@samba.org>
Autobuild-Date(v4-18-test): Wed Nov 29 15:55:45 UTC 2023 on atb-devel-224

testprogs/blackbox/test_net_offline.sh

index a3809b59e0a37ebcfd2d6235a5a282496f765ab5..f4a8026df626d2857efd5dbf84a2cc0fcc1b1ceb 100755 (executable)
@@ -27,6 +27,7 @@ cd $RUNDIR
 failed=0
 
 net_tool="$BINDIR/net --configfile=$BASEDIR/$WORKDIR/client.conf --option=security=ads"
+samba_texpect="$BINDIR/texpect"
 
 # Load test functions
 . $(dirname $0)/subunit.sh
@@ -69,6 +70,93 @@ rm -f $ODJFILE
 
 testit "leave" $VALGRIND $net_tool ads leave  -U$DC_USERNAME%$DC_PASSWORD || failed=$(expr $failed + 1)
 
+test_compose_odj() {
+       local mode=$1
+       local composeargv=()
+
+       # Retrieve the necessary information to compose the ODJ blob
+       # The machine needs to be correctly joined at this point
+       local netbios_domain_name=$($net_tool ads lookup | awk -F': ' '/^Pre-Win2k Domain/ {print $2}')
+       local domain_sid=$($net_tool getdomainsid | awk -F': ' "/^SID for domain $netbios_domain_name/ {print \$2}")
+       local domain_guid=$($net_tool ads lookup | awk -F': ' '/^GUID/ {print $2}')
+       local forest_name=$($net_tool ads lookup | awk -F': ' '/^Forest/ {print $2}')
+       local dc_name=$($net_tool ads info | awk -F': ' '/^LDAP server name/ {print $2}')
+       local dc_address=$($net_tool ads info | awk -F': ' '/^LDAP server:/ {print $2}')
+       local ret=1
+       local out=""
+
+       composeargv=( \
+               "domain_sid=${domain_sid}" \
+               "domain_guid=${domain_guid}" \
+               "forest_name=${forest_name}" \
+               "-S ${dc_name}" \
+               "-I ${dc_address}" \
+               "savefile=${ODJFILE}"
+       )
+       case $mode in
+       machacct)
+               cmd='$net_tool offlinejoin composeodj ${composeargv[@]} -P 2>&1'
+               out=$(eval $cmd)
+               ret=$?
+       ;;
+       stdinfd)
+               cmd='echo ${netbios} | $net_tool offlinejoin composeodj ${composeargv[@]} -U${netbios^^}\$ 2>&1'
+               out=$(PASSWD_FD=0 eval $cmd)
+               ret=$?
+       ;;
+       callback)
+               tmpfile=$BASEDIR/$WORKDIR/composeodj_password_script
+               cat >$tmpfile <<EOF
+expect Password for [${netbios_domain_name^^}\\${netbios^^}\$]:
+send $netbios\n
+EOF
+               cmd='$samba_texpect -v $tmpfile $net_tool offlinejoin composeodj ${composeargv[@]} 2>&1'
+               out=$(eval $cmd)
+               ret=$?
+               rm -f $tmpfile
+       ;;
+       *)
+               out="Unknown mode '$mode'"
+       ;;
+       esac
+
+       if [ $ret -ne 0 ]; then
+               echo "Failed to compose ODJ blob: $out"
+               return 1
+       fi
+}
+
+# 4. Test composeodj
+
+modes=("machacct" "stdinfd" "callback")
+for mode in "${modes[@]}"; do
+
+       defpwd="defpwd"
+       if [ "$mode" == "machacct" ]; then
+               defpwd=""
+       fi
+
+       testit "provision[$mode]" $VALGRIND $net_tool offlinejoin provision domain=$REALM machine_name=$netbios savefile=$ODJFILE $defpwd -U$DC_USERNAME%$DC_PASSWORD || failed=$(expr $failed + 1)
+
+       testit "requestodj [$mode]" $VALGRIND $net_tool offlinejoin requestodj loadfile=$ODJFILE || failed=$(expr $failed + 1)
+
+       testit "testjoin [$mode]" $VALGRIND $net_tool ads testjoin -P --use-kerberos=required || failed=$(expr $failed + 1)
+
+       testit "removeodjblob [$mode]" rm $ODJFILE || failed=$(expr $failed + 1)
+
+       testit "composeodj [$mode]" test_compose_odj $mode || failed=$(expr $failed + 1)
+
+       testit "removesecretsdb [$mode]" rm $BASEDIR/$WORKDIR/private/secrets.tdb || failed=$(expr $failed + 1)
+
+       testit "requestodj [$mode]" $VALGRIND $net_tool offlinejoin requestodj loadfile=$ODJFILE || failed=$(expr $failed + 1)
+
+       testit "removeodjblob [$mode]" rm $ODJFILE || failed=$(expr $failed + 1)
+
+       testit "testjoin [$mode]" $VALGRIND $net_tool ads testjoin -P --use-kerberos=required || failed=$(expr $failed + 1)
+
+       testit "leave [$mode]" $VALGRIND $net_tool ads leave  -U$DC_USERNAME%$DC_PASSWORD || failed=$(expr $failed + 1)
+done
+
 rm -rf $BASEDIR/$WORKDIR
 
 exit $failed