mirror of
https://github.com/samba-team/samba.git
synced 2025-02-28 01:58:17 +03:00
s3:tests: Reformat test_symlink_rename_smb1_posix.sh
shfmt -f source3/script/| xargs shfmt -w -p -i 0 -fn Signed-off-by: Andreas Schneider <asn@samba.org> Reviewed-by: Andrew Bartlett <abartlet@samba.org>
This commit is contained in:
parent
b86936063c
commit
8722450d09
@ -1,10 +1,10 @@
|
||||
#!/bin/sh
|
||||
|
||||
if [ $# -lt 7 ]; then
|
||||
cat <<EOF
|
||||
cat <<EOF
|
||||
Usage: test_symlink_rename_smb1_posix.sh SERVER SERVER_IP USERNAME PASSWORD LOCAL_PATH PREFIX SMBCLIENT
|
||||
EOF
|
||||
exit 1;
|
||||
exit 1
|
||||
fi
|
||||
|
||||
SERVER="${1}"
|
||||
@ -26,7 +26,6 @@ failed=0
|
||||
SAMBA_DEPRECATED_SUPPRESS=1
|
||||
export SAMBA_DEPRECATED_SUPPRESS
|
||||
|
||||
|
||||
# Define the test environment/filenames.
|
||||
#
|
||||
share_test_dir="$LOCAL_PATH"
|
||||
@ -48,28 +47,28 @@ dir_outside_share_noexist="/tmp/symlink_rename_test_dir_noexist.$$"
|
||||
#
|
||||
do_cleanup()
|
||||
{
|
||||
(
|
||||
#subshell.
|
||||
cd "$share_test_dir" || return
|
||||
rm -f "file_exists"
|
||||
rm -f "symlink_noexist"
|
||||
rm -f "symlink_file_outside_share"
|
||||
rm -f "symlink_file_outside_share_noexist"
|
||||
rm -f "symlink_dir_outside_share"
|
||||
rm -f "symlink_dir_outside_share_noexist"
|
||||
rm -f "symlink_file_outside_share_noperms"
|
||||
rm -f "symlink_dir_outside_share_noperms"
|
||||
# Links inside share.
|
||||
rm -f "symlink_file_inside_share_noperms"
|
||||
rm -f "file_inside_share_noperms"
|
||||
rm -f "symlink_dir_inside_share_noperms"
|
||||
chmod 755 "dir_inside_share_noperms"
|
||||
rm -rf "dir_inside_share_noperms"
|
||||
)
|
||||
rm -f "$file_outside_share"
|
||||
rm -rf "$dir_outside_share"
|
||||
rm -f "$file_outside_share_noperms"
|
||||
rm -rf "$dir_outside_share_noperms"
|
||||
(
|
||||
#subshell.
|
||||
cd "$share_test_dir" || return
|
||||
rm -f "file_exists"
|
||||
rm -f "symlink_noexist"
|
||||
rm -f "symlink_file_outside_share"
|
||||
rm -f "symlink_file_outside_share_noexist"
|
||||
rm -f "symlink_dir_outside_share"
|
||||
rm -f "symlink_dir_outside_share_noexist"
|
||||
rm -f "symlink_file_outside_share_noperms"
|
||||
rm -f "symlink_dir_outside_share_noperms"
|
||||
# Links inside share.
|
||||
rm -f "symlink_file_inside_share_noperms"
|
||||
rm -f "file_inside_share_noperms"
|
||||
rm -f "symlink_dir_inside_share_noperms"
|
||||
chmod 755 "dir_inside_share_noperms"
|
||||
rm -rf "dir_inside_share_noperms"
|
||||
)
|
||||
rm -f "$file_outside_share"
|
||||
rm -rf "$dir_outside_share"
|
||||
rm -f "$file_outside_share_noperms"
|
||||
rm -rf "$dir_outside_share_noperms"
|
||||
}
|
||||
|
||||
#
|
||||
@ -91,27 +90,27 @@ chmod 0 "$dir_outside_share_noperms"
|
||||
#
|
||||
# Create links to these objects inside the share definition.
|
||||
(
|
||||
#subshell.
|
||||
cd "$share_test_dir" || return
|
||||
# Source file for all renames. None of these should succeed.
|
||||
touch "file_exists"
|
||||
ln -s "noexist" "symlink_noexist"
|
||||
ln -s "$file_outside_share" "symlink_file_outside_share"
|
||||
ln -s "$file_outside_share_noexist" "symlink_file_outside_share_noexist"
|
||||
ln -s "$dir_outside_share" "symlink_dir_outside_share"
|
||||
ln -s "$dir_outside_share_noexist" "symlink_dir_outside_share_noexist"
|
||||
ln -s "$file_outside_share_noperms" "symlink_file_outside_share_noperms"
|
||||
ln -s "$dir_outside_share_noperms" "symlink_dir_outside_share_noperms"
|
||||
#
|
||||
# Create symlinks to access denied file and directory
|
||||
# objects within the share
|
||||
touch "file_inside_share_noperms"
|
||||
chmod 0 "file_inside_share_noperms"
|
||||
ln -s "file_inside_share_noperms" "symlink_file_inside_share_noperms"
|
||||
mkdir "dir_inside_share_noperms"
|
||||
touch "dir_inside_share_noperms/noperm_file_exists"
|
||||
chmod 0 "dir_inside_share_noperms"
|
||||
ln -s "dir_inside_share_noperms" "symlink_dir_inside_share_noperms"
|
||||
#subshell.
|
||||
cd "$share_test_dir" || return
|
||||
# Source file for all renames. None of these should succeed.
|
||||
touch "file_exists"
|
||||
ln -s "noexist" "symlink_noexist"
|
||||
ln -s "$file_outside_share" "symlink_file_outside_share"
|
||||
ln -s "$file_outside_share_noexist" "symlink_file_outside_share_noexist"
|
||||
ln -s "$dir_outside_share" "symlink_dir_outside_share"
|
||||
ln -s "$dir_outside_share_noexist" "symlink_dir_outside_share_noexist"
|
||||
ln -s "$file_outside_share_noperms" "symlink_file_outside_share_noperms"
|
||||
ln -s "$dir_outside_share_noperms" "symlink_dir_outside_share_noperms"
|
||||
#
|
||||
# Create symlinks to access denied file and directory
|
||||
# objects within the share
|
||||
touch "file_inside_share_noperms"
|
||||
chmod 0 "file_inside_share_noperms"
|
||||
ln -s "file_inside_share_noperms" "symlink_file_inside_share_noperms"
|
||||
mkdir "dir_inside_share_noperms"
|
||||
touch "dir_inside_share_noperms/noperm_file_exists"
|
||||
chmod 0 "dir_inside_share_noperms"
|
||||
ln -s "dir_inside_share_noperms" "symlink_dir_inside_share_noperms"
|
||||
)
|
||||
|
||||
#
|
||||
@ -119,39 +118,39 @@ ln -s "dir_inside_share_noperms" "symlink_dir_inside_share_noperms"
|
||||
#
|
||||
smbclient_expect_error()
|
||||
{
|
||||
filecmd="$1"
|
||||
filename1="$2"
|
||||
filename2="$3"
|
||||
expected_error="$4"
|
||||
tmpfile=$PREFIX/smbclient_interactive_prompt_commands
|
||||
cat > "$tmpfile" <<EOF
|
||||
filecmd="$1"
|
||||
filename1="$2"
|
||||
filename2="$3"
|
||||
expected_error="$4"
|
||||
tmpfile=$PREFIX/smbclient_interactive_prompt_commands
|
||||
cat >"$tmpfile" <<EOF
|
||||
posix
|
||||
$filecmd $filename1 $filename2
|
||||
quit
|
||||
EOF
|
||||
cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT -U$USERNAME%$PASSWORD //$SERVER/local_symlinks -I$SERVER_IP -mNT1 < $tmpfile 2>&1'
|
||||
eval echo "$cmd"
|
||||
out=$(eval "$cmd")
|
||||
ret=$?
|
||||
rm -f "$tmpfile"
|
||||
cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT -U$USERNAME%$PASSWORD //$SERVER/local_symlinks -I$SERVER_IP -mNT1 < $tmpfile 2>&1'
|
||||
eval echo "$cmd"
|
||||
out=$(eval "$cmd")
|
||||
ret=$?
|
||||
rm -f "$tmpfile"
|
||||
|
||||
if [ $ret != 0 ] ; then
|
||||
printf "%s\n" "$out"
|
||||
printf "failed accessing local_symlinks with error %s\n" "$ret"
|
||||
return 1
|
||||
fi
|
||||
if [ $ret != 0 ]; then
|
||||
printf "%s\n" "$out"
|
||||
printf "failed accessing local_symlinks with error %s\n" "$ret"
|
||||
return 1
|
||||
fi
|
||||
|
||||
if [ "$expected_error" = "NT_STATUS_OK" ] ; then
|
||||
printf "%s" "$out" | grep -v "NT_STATUS_"
|
||||
else
|
||||
printf "%s" "$out" | grep "$expected_error"
|
||||
fi
|
||||
ret=$?
|
||||
if [ $ret != 0 ] ; then
|
||||
printf "%s\n" "$out"
|
||||
printf "failed - should get %s doing posix \"%s %s %s\"\n" "$expected_error" "$filecmd" "$filename1" "$filename2"
|
||||
return 1
|
||||
fi
|
||||
if [ "$expected_error" = "NT_STATUS_OK" ]; then
|
||||
printf "%s" "$out" | grep -v "NT_STATUS_"
|
||||
else
|
||||
printf "%s" "$out" | grep "$expected_error"
|
||||
fi
|
||||
ret=$?
|
||||
if [ $ret != 0 ]; then
|
||||
printf "%s\n" "$out"
|
||||
printf "failed - should get %s doing posix \"%s %s %s\"\n" "$expected_error" "$filecmd" "$filename1" "$filename2"
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
#
|
||||
@ -159,25 +158,25 @@ EOF
|
||||
#
|
||||
test_symlink_rename_SMB1_posix()
|
||||
{
|
||||
#
|
||||
# rename commands.
|
||||
# As all the targets exist as symlinks, these should all fail.
|
||||
#
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_inside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_inside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
return 0
|
||||
#
|
||||
# rename commands.
|
||||
# As all the targets exist as symlinks, these should all fail.
|
||||
#
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share_noexist" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_outside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_outside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_file_inside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
smbclient_expect_error "rename" "file_exists" "symlink_dir_inside_share_noperms" "NT_STATUS_OBJECT_NAME_COLLISION" || return 1
|
||||
return 0
|
||||
}
|
||||
|
||||
testit "symlink_rename_SMB1_posix" \
|
||||
test_symlink_rename_SMB1_posix || \
|
||||
failed=$((failed+1))
|
||||
test_symlink_rename_SMB1_posix ||
|
||||
failed=$((failed + 1))
|
||||
|
||||
#
|
||||
# Cleanup.
|
||||
|
Loading…
x
Reference in New Issue
Block a user