tevent: add test_event_fd1()
[Samba.git] / source3 / script / tests / test_smbclient_s3.sh
blob5ec28219946657f660fc1f654ac041aa84a051e6
1 #!/bin/sh
3 # this runs the file serving tests that are expected to pass with samba3
5 if [ $# -lt 7 ]; then
6 cat <<EOF
7 Usage: test_smbclient_s3.sh SERVER SERVER_IP DOMAIN USERNAME PASSWORD USERID LOCAL_PATH PREFIX SMBCLIENT WBINFO
8 EOF
9 exit 1;
12 SERVER="${1}"
13 SERVER_IP="${2}"
14 DOMAIN="${3}"
15 USERNAME="${4}"
16 PASSWORD="${5}"
17 USERID="${6}"
18 LOCAL_PATH="${7}"
19 PREFIX="${8}"
20 SMBCLIENT="${9}"
21 WBINFO="${10}"
22 SMBCLIENT="$VALGRIND ${SMBCLIENT}"
23 WBINFO="$VALGRIND ${WBINFO}"
24 shift 10
25 ADDARGS="$*"
27 incdir=`dirname $0`/../../../testprogs/blackbox
28 . $incdir/subunit.sh
30 failed=0
32 # Test that a noninteractive smbclient does not prompt
33 test_noninteractive_no_prompt()
35 prompt="smb"
37 cmd='echo du | $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS 2>&1'
38 eval echo "$cmd"
39 out=`eval $cmd`
41 if [ $? != 0 ] ; then
42 echo "$out"
43 echo "command failed"
44 false
45 return
48 echo "$out" | grep $prompt >/dev/null 2>&1
50 if [ $? = 0 ] ; then
51 # got a prompt .. fail
52 echo matched interactive prompt in non-interactive mode
53 false
54 else
55 true
59 # Test that an interactive smbclient prompts to stdout
60 test_interactive_prompt_stdout()
62 prompt="smb"
63 tmpfile=$PREFIX/smbclient_interactive_prompt_commands
65 cat > $tmpfile <<EOF
67 quit
68 EOF
70 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
71 eval echo "$cmd"
72 out=`eval $cmd`
73 ret=$?
74 rm -f $tmpfile
76 if [ $ret != 0 ] ; then
77 echo "$out"
78 echo "command failed"
79 false
80 return
83 echo "$out" | grep $prompt >/dev/null 2>&1
85 if [ $? = 0 ] ; then
86 # got a prompt .. succeed
87 true
88 else
89 echo failed to match interactive prompt on stdout
90 false
94 # Test creating a bad symlink and deleting it.
95 test_bad_symlink()
97 prompt="posix_unlink deleted file /newname"
98 tmpfile=$PREFIX/smbclient_bad_symlinks_commands
100 cat > $tmpfile <<EOF
101 posix
102 posix_unlink newname
103 symlink badname newname
104 posix_unlink newname
105 quit
108 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
109 eval echo "$cmd"
110 out=`eval $cmd`
111 ret=$?
112 rm -f $tmpfile
114 if [ $ret != 0 ] ; then
115 echo "$out"
116 echo "failed create then delete bad symlink with error $ret"
117 false
118 return
121 echo "$out" | grep "$prompt" >/dev/null 2>&1
123 ret=$?
124 if [ $ret = 0 ] ; then
125 # got the correct prompt .. succeed
126 true
127 else
128 echo "$out"
129 echo "failed create then delete bad symlink - grep failed with $ret"
130 false
134 # Test creating a good symlink and deleting it by path.
135 test_good_symlink()
137 tmpfile=$PREFIX/smbclient.in.$$
138 slink_name="$LOCAL_PATH/slink"
139 slink_target="$LOCAL_PATH/slink_target"
141 touch $slink_target
142 ln -s $slink_target $slink_name
143 cat > $tmpfile <<EOF
144 del slink
145 quit
148 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
149 eval echo "$cmd"
150 out=`eval $cmd`
151 ret=$?
152 rm -f $tmpfile
154 if [ $ret != 0 ] ; then
155 echo "$out"
156 echo "failed delete good symlink with error $ret"
157 rm $slink_target
158 rm $slink_name
159 false
160 return
163 if [ ! -e $slink_target ] ; then
164 echo "failed delete good symlink - symlink target deleted !"
165 rm $slink_target
166 rm $slink_name
167 false
168 return
171 if [ -e $slink_name ] ; then
172 echo "failed delete good symlink - symlink still exists"
173 rm $slink_target
174 rm $slink_name
175 false
176 else
177 # got the correct prompt .. succeed
178 rm $slink_target
179 true
183 # Test writing into a read-only directory (logon as guest) fails.
184 test_read_only_dir()
186 prompt="NT_STATUS_ACCESS_DENIED making remote directory"
187 tmpfile=$PREFIX/smbclient.in.$$
190 ## We can't do this as non-root. We always have rights to
191 ## create the directory.
193 if [ "$USERID" != 0 ] ; then
194 echo "skipping test_read_only_dir as non-root"
195 true
196 return
200 ## We can't do this with an encrypted connection. No credentials
201 ## to set up the channel.
203 if [ "$ADDARGS" = "-e" ] ; then
204 echo "skipping test_read_only_dir with encrypted connection"
205 true
206 return
209 cat > $tmpfile <<EOF
210 mkdir a_test_dir
211 quit
214 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT -U% //$SERVER/$1" -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
215 eval echo "$cmd"
216 out=`eval $cmd`
217 ret=$?
218 rm -f $tmpfile
220 if [ $ret != 0 ] ; then
221 echo "$out"
222 echo "failed writing into read-only directory with error $ret"
224 false
225 return
228 echo "$out" | grep "$prompt" >/dev/null 2>&1
230 ret=$?
231 if [ $ret = 0 ] ; then
232 # got the correct prompt .. succeed
233 true
234 else
235 echo "$out"
236 echo "failed writing into read-only directory - grep failed with $ret"
237 false
242 # Test sending a message
243 test_message()
245 tmpfile=$PREFIX/message_in.$$
247 cat > $tmpfile <<EOF
248 Test message from pid $$
251 cmd='$SMBCLIENT "$@" -U$USERNAME%$PASSWORD -M $SERVER -p 139 $ADDARGS -n msgtest < $tmpfile 2>&1'
252 eval echo "$cmd"
253 out=`eval $cmd`
254 ret=$?
256 if [ $ret != 0 ] ; then
257 echo "$out"
258 echo "failed sending message to $SERVER with error $ret"
259 false
260 rm -f $tmpfile
261 return
264 # The server writes this into a file message.msgtest, via message.%m to test the % sub code
265 cmd='$SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmpguest -p 139 $ADDARGS -c "get message.msgtest $PREFIX/message_out.$$" 2>&1'
266 eval echo "$cmd"
267 out=`eval $cmd`
268 ret=$?
270 if [ $ret != 0 ] ; then
271 echo "$out"
272 echo "failed getting sent message from $SERVER with error $ret"
273 false
274 return
277 if [ cmp $PREFIX/message_out.$$ $tmpfile != 0 ] ; then
278 echo "failed comparison of message from $SERVER"
279 false
280 return
282 true
285 # Test reading an owner-only file (logon as guest) fails.
286 test_owner_only_file()
288 prompt="NT_STATUS_ACCESS_DENIED opening remote file"
289 tmpfile=$PREFIX/smbclient.in.$$
292 ## We can't do this as non-root. We always have rights to
293 ## read the file.
295 if [ "$USERID" != 0 ] ; then
296 echo "skipping test_owner_only_file as non-root"
297 true
298 return
302 ## We can't do this with an encrypted connection. No credentials
303 ## to set up the channel.
305 if [ "$ADDARGS" = "-e" ] ; then
306 echo "skipping test_owner_only_file with encrypted connection"
307 true
308 return
311 cat > $tmpfile <<EOF
312 get unreadable_file
313 quit
316 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U% //$SERVER/ro-tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
317 eval echo "$cmd"
318 out=`eval $cmd`
319 ret=$?
320 rm -f $tmpfile
322 if [ $ret != 0 ] ; then
323 echo "$out"
324 echo "failed reading owner-only file with error $ret"
325 false
326 return
329 echo "$out" | grep "$prompt" >/dev/null 2>&1
331 ret=$?
332 if [ $ret = 0 ] ; then
333 # got the correct prompt .. succeed
334 true
335 else
336 echo "$out"
337 echo "failed reading owner-only file - grep failed with $ret"
338 false
342 # Test accessing an msdfs path.
343 test_msdfs_link()
345 tmpfile=$PREFIX/smbclient.in.$$
346 prompt=" msdfs-target "
348 cat > $tmpfile <<EOF
350 cd \\msdfs-src1
351 ls msdfs-target
352 quit
355 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/msdfs-share -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
356 eval echo "$cmd"
357 out=`eval $cmd`
358 ret=$?
359 rm -f $tmpfile
361 if [ $ret != 0 ] ; then
362 echo "$out"
363 echo "failed accessing \\msdfs-src1 link with error $ret"
364 false
365 return
368 echo "$out" | grep "$prompt" >/dev/null 2>&1
370 ret=$?
371 if [ $ret != 0 ] ; then
372 echo "$out"
373 echo "failed listing \\msdfs-src1 - grep failed with $ret"
374 false
377 cat > $tmpfile <<EOF
379 cd \\deeppath\\msdfs-src2
380 ls msdfs-target
381 quit
384 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/msdfs-share -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
385 eval echo "$cmd"
386 out=`eval $cmd`
387 ret=$?
388 rm -f $tmpfile
390 if [ $ret != 0 ] ; then
391 echo "$out"
392 echo "failed accessing \\deeppath\\msdfs-src2 link with error $ret"
393 false
394 return
397 echo "$out" | grep "$prompt" >/dev/null 2>&1
399 ret=$?
400 if [ $ret != 0 ] ; then
401 echo "$out"
402 echo "failed listing \\deeppath\\msdfs-src2 - grep failed with $ret"
403 false
404 return
405 else
406 true
407 return
411 # Archive bits are correctly set on file/dir creation and rename.
412 test_rename_archive_bit()
414 prompt_file="attributes: A (20)"
415 prompt_dir="attributes: D (10)"
416 tmpfile="$PREFIX/smbclient.in.$$"
417 filename="foo.$$"
418 filename_ren="bar.$$"
419 dirname="foodir.$$"
420 dirname_ren="bardir.$$"
421 filename_path="$PREFIX/$filename"
422 local_name1="$LOCAL_PATH/$filename"
423 local_name2="$LOCAL_PATH/$filename_ren"
424 local_dir_name1="$LOCAL_PATH/$dirname"
425 local_dir_name2="$LOCAL_PATH/$dirname_ren"
427 rm -f $filename_path
428 rm -f $local_name1
429 rm -f $local_name2
431 # Create a new file, ensure it has 'A' attributes.
432 touch $filename_path
434 cat > $tmpfile <<EOF
435 lcd $PREFIX
436 put $filename
437 allinfo $filename
438 quit
441 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
442 eval echo "$cmd"
443 out=`eval $cmd`
444 ret=$?
445 rm -f $tmpfile
447 if [ $ret != 0 ] ; then
448 echo "$out"
449 echo "failed creating file $filename with error $ret"
450 false
451 return
454 echo "$out" | grep "$prompt_file" >/dev/null 2>&1
456 ret=$?
458 rm -f $filename_path
459 rm -f $local_name1
460 rm -f $local_name2
462 if [ $ret = 0 ] ; then
463 # got the correct prompt .. succeed
464 true
465 else
466 echo "$out"
467 echo "Attributes incorrect on new file $ret"
468 false
471 # Now check if we remove 'A' and rename, the A comes back.
472 touch $filename_path
474 cat > $tmpfile <<EOF
475 lcd $PREFIX
476 put $filename
477 setmode $filename -a
478 ren $filename $filename_ren
479 allinfo $filename_ren
480 quit
483 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
484 eval echo "$cmd"
485 out=`eval $cmd`
486 ret=$?
487 rm -f $tmpfile
489 if [ $ret != 0 ] ; then
490 echo "$out"
491 echo "failed creating file and renaming $filename with error $ret"
492 false
493 return
496 echo "$out" | grep "$prompt_file" >/dev/null 2>&1
498 ret=$?
500 rm -f $filename_path
501 rm -f $local_name1
502 rm -f $local_name2
504 if [ $ret = 0 ] ; then
505 # got the correct prompt .. succeed
506 true
507 else
508 echo "$out"
509 echo "Attributes incorrect on renamed file $ret"
510 false
513 rm -rf $local_dir_name1
514 rm -rf $local_dir_name2
516 # Create a new directory, ensure it has 'D' but not 'A' attributes.
518 cat > $tmpfile <<EOF
519 mkdir $dirname
520 allinfo $dirname
521 quit
524 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
525 eval echo "$cmd"
526 out=`eval $cmd`
527 ret=$?
528 rm -f $tmpfile
530 if [ $ret != 0 ] ; then
531 echo "$out"
532 echo "failed creating directory $dirname with error $ret"
533 false
534 return
537 echo "$out" | grep "$prompt_dir" >/dev/null 2>&1
539 ret=$?
541 rm -rf $local_dir_name1
542 rm -rf $local_dir_name2
544 if [ $ret = 0 ] ; then
545 # got the correct prompt .. succeed
546 true
547 else
548 echo "$out"
549 echo "Attributes incorrect on new directory $ret"
550 false
553 # Now check if we rename, we still only have 'D' attributes
555 cat > $tmpfile <<EOF
556 mkdir $dirname
557 ren $dirname $dirname_ren
558 allinfo $dirname_ren
559 quit
562 cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/tmp -I $SERVER_IP $ADDARGS < $tmpfile 2>&1'
563 eval echo "$cmd"
564 out=`eval $cmd`
565 ret=$?
566 rm -f $tmpfile
568 if [ $ret != 0 ] ; then
569 echo "$out"
570 echo "failed creating directory $dirname and renaming with error $ret"
571 false
572 return
575 echo "$out" | grep "$prompt_dir" >/dev/null 2>&1
577 ret=$?
579 rm -f $local_name1
580 rm -f $local_name2
582 if [ $ret = 0 ] ; then
583 # got the correct prompt .. succeed
584 true
585 else
586 echo "$out"
587 echo "Attributes incorrect on renamed directory $ret"
588 false
592 # Test authenticating using the winbind ccache
593 test_ccache_access()
595 $WBINFO --ccache-save="${USERNAME}%${PASSWORD}"
596 ret=$?
598 if [ $ret != 0 ] ; then
599 echo "wbinfo failed to store creds in cache (user='${USERNAME}', pass='${PASSWORD}')"
600 false
601 return
604 $SMBCLIENT //$SERVER_IP/tmp -C -U "${USERNAME}%" \
605 -c quit 2>&1
606 ret=$?
608 if [ $ret != 0 ] ; then
609 echo "smbclient failed to use cached credentials"
610 false
611 return
614 $WBINFO --ccache-save="${USERNAME}%GarBage"
615 ret=$?
617 if [ $ret != 0 ] ; then
618 echo "wbinfo failed to store creds in cache (user='${USERNAME}', pass='GarBage')"
619 false
620 return
623 $SMBCLIENT //$SERVER_IP/tmp -C -U "${USERNAME}%" \
624 -c quit 2>&1
625 ret=$?
627 if [ $ret -eq 0 ] ; then
628 echo "smbclient succeeded with wrong cached credentials"
629 false
630 return
633 $WBINFO --logoff
636 # Test authenticating using the winbind ccache
637 test_auth_file()
639 tmpfile=$PREFIX/smbclient.in.$$
640 cat > $tmpfile <<EOF
641 username=${USERNAME}
642 password=${PASSWORD}
643 domain=${DOMAIN}
645 $SMBCLIENT //$SERVER_IP/tmp --authentication-file=$tmpfile \
646 -c quit 2>&1
647 ret=$?
648 rm $tmpfile
650 if [ $ret != 0 ] ; then
651 echo "smbclient failed to use auth file"
652 false
653 return
656 cat > $tmpfile <<EOF
657 username=${USERNAME}
658 password=xxxx
659 domain=${DOMAIN}
661 $SMBCLIENT //$SERVER_IP/tmp --authentication-file=$tmpfile\
662 -c quit 2>&1
663 ret=$?
664 rm $tmpfile
666 if [ $ret -eq 0 ] ; then
667 echo "smbclient succeeded with wrong auth file credentials"
668 false
669 return
674 LOGDIR_PREFIX=test_smbclient_s3
676 # possibly remove old logdirs:
678 for OLDDIR in $(find ${PREFIX} -type d -name "${LOGDIR_PREFIX}_*") ; do
679 echo "removing old directory ${OLDDIR}"
680 rm -rf ${OLDDIR}
681 done
683 LOGDIR=$(mktemp -d ${PREFIX}/${LOGDIR_PREFIX}_XXXXXX)
686 testit "smbclient -L $SERVER_IP" $SMBCLIENT -L $SERVER_IP -N -p 139 || failed=`expr $failed + 1`
687 testit "smbclient -L $SERVER -I $SERVER_IP" $SMBCLIENT -L $SERVER -I $SERVER_IP -N -p 139 -c quit || failed=`expr $failed + 1`
689 testit "noninteractive smbclient does not prompt" \
690 test_noninteractive_no_prompt || \
691 failed=`expr $failed + 1`
693 testit "noninteractive smbclient -l does not prompt" \
694 test_noninteractive_no_prompt -l $LOGDIR || \
695 failed=`expr $failed + 1`
697 testit "interactive smbclient prompts on stdout" \
698 test_interactive_prompt_stdout || \
699 failed=`expr $failed + 1`
701 testit "interactive smbclient -l prompts on stdout" \
702 test_interactive_prompt_stdout -l $LOGDIR || \
703 failed=`expr $failed + 1`
705 testit "creating a bad symlink and deleting it" \
706 test_bad_symlink || \
707 failed=`expr $failed + 1`
709 testit "creating a good symlink and deleting it by path" \
710 test_good_symlink || \
711 failed=`expr $failed + 1`
713 testit "writing into a read-only directory fails" \
714 test_read_only_dir ro-tmp || \
715 failed=`expr $failed + 1`
717 testit "writing into a read-only share fails" \
718 test_read_only_dir valid-users-tmp || \
719 failed=`expr $failed + 1`
721 testit "Reading a owner-only file fails" \
722 test_owner_only_file || \
723 failed=`expr $failed + 1`
725 testit "Accessing an MS-DFS link" \
726 test_msdfs_link || \
727 failed=`expr $failed + 1`
729 testit "Ensure archive bit is set correctly on file/dir rename" \
730 test_rename_archive_bit || \
731 failed=`expr $failed + 1`
733 testit "ccache access works for smbclient" \
734 test_ccache_access || \
735 failed=`expr $failed + 1`
737 testit "sending a message to the remote server" \
738 test_message || \
739 failed=`expr $failed + 1`
741 testit "using an authentication file" \
742 test_auth_file || \
743 failed=`expr $failed + 1`
745 testit "rm -rf $LOGDIR" \
746 rm -rf $LOGDIR || \
747 failed=`expr $failed + 1`
749 testok $0 $failed