2016-01-06 12:59:06 +02:00
#!/bin/sh
#
# Blackbox test for disk-free, quota, and their interaction
#
if [ $# -lt 6 ] ; then
2022-04-22 15:34:08 +02:00
cat <<EOF
2016-08-11 23:54:22 +03:00
Usage: test_dfree_quota.sh SERVER DOMAIN USERNAME PASSWORD LOCAL_PATH SMBCLIENT SMBCQUOTAS SMBCACLS
2016-01-06 12:59:06 +02:00
EOF
2022-04-22 15:34:08 +02:00
exit 1
2016-01-06 12:59:06 +02:00
fi
SERVER = $1
DOMAIN = $2
USERNAME = $3
PASSWORD = $4
2022-04-22 15:34:08 +02:00
ENVDIR = $( dirname $5 )
2016-01-06 12:59:06 +02:00
WORKDIR = $5 /dfree
smbclient = $6
smbcquotas = $7
2016-08-11 23:54:22 +03:00
smbcacls = $8
2019-11-27 19:37:26 +00:00
protocol = $9
shift 9
2016-01-06 12:59:06 +02:00
failed = 0
CONFFILE = $ENVDIR /lib/dfq.conf
2022-04-22 15:34:08 +02:00
incdir = $( dirname $0 ) /../../../testprogs/blackbox
2016-01-06 12:59:06 +02:00
. $incdir /subunit.sh
2022-04-22 15:34:08 +02:00
sighup_smbd( )
{
kill -HUP -$( cat $ENVDIR /pid/smbd.pid)
2016-01-06 12:59:06 +02:00
}
2022-04-22 15:34:08 +02:00
conf_lines( )
{
local uid
local gid
uid = $( id -u $USERNAME )
gid = $( id -g $USERNAME )
uid1 = $( id -u user1)
uid2 = $( id -u user2)
cat <<ABC
2016-01-06 12:59:06 +02:00
conf1:df:block size = 512:disk free = 10:disk size = 20
conf2:df:block size = 1024:disk free = 10:disk size = 20
conf3:df:block size = 4096:disk free = 750:disk size = 281474976710656
confq1:u$uid :block size = 4096:hard limit = 750:soft limit = 1000:cur blocks = 10
confdfq1:df:block size = 4096:disk free = 10:disk size = 20
confdfq1:u$uid :block size = 4096:hard limit = 750:soft limit = 1000:cur blocks = 10
confdfq2:df:block size = 4096:disk free = 10:disk size = 20
confdfq2:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 37
confdfq3:df:block size = 4096:disk free = 10:disk size = 80
confdfq3:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 0
confdfq4:df:block size = 4096:disk free = 10:disk size = 80
confdfq4:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 37
slimit:df:block size = 4096:disk free = 10:disk size = 80
slimit:u$uid :block size = 4096:hard limit = 44:soft limit = 40:cur blocks = 42
hlimit:df:block size = 4096:disk free = 10:disk size = 80
hlimit:u$uid :block size = 4096:hard limit = 44:soft limit = 0:cur blocks = 45
islimit:df:block size = 4096:disk free = 10:disk size = 80
islimit:u$uid :block size = 4096:hard limit = 44:soft limit = 40:cur blocks = 37:inode soft limit = 30:inode hard limit = 35:cur inodes = 32
ihlimit:df:block size = 4096:disk free = 10:disk size = 80
ihlimit:u$uid :block size = 4096:hard limit = 44:soft limit = 40:cur blocks = 37:inode soft limit = 0:inode hard limit = 35:cur inodes = 36
trygrp1:df:block size = 4096:disk free = 10:disk size = 80
trygrp1:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 41:err = 1
trygrp1:g$gid :block size = 4096:hard limit = 60:soft limit = 60:cur blocks = 55
trygrp2:df:block size = 4096:disk free = 10:disk size = 80
trygrp2:u$uid :block size = 4096:hard limit = 0:soft limit = 0:cur blocks = 41
trygrp2:g$gid :block size = 4096:hard limit = 60:soft limit = 60:cur blocks = 56
2016-01-19 14:38:03 +02:00
blksize:df:block size = 512:disk free = 614400:disk size = 614400
blksize:u$uid :block size = 1024:hard limit = 512000:soft limit = 0:cur blocks = 0
2016-05-26 22:52:09 +03:00
notenforce:df:block size = 4096:disk free = 10:disk size = 80
notenforce:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 37
notenforce:udflt:block size = 4096:qflags = 0
nfs:df:block size = 4096:disk free = 10:disk size = 80
nfs:u$uid :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 37
nfs:udflt:nosys = 1
2016-08-11 23:54:22 +03:00
confdfqp:df:block size = 4096:disk free = 10:disk size = 80
confdfqp:u$uid1 :block size = 4096:hard limit = 40:soft limit = 40:cur blocks = 36
confdfqp:u$uid2 :block size = 4096:hard limit = 41:soft limit = 41:cur blocks = 36
2019-08-13 13:44:52 -07:00
sgid:stat:sgid = 98765
sgid:u$uid :block size = 4096:hard limit = 0:soft limit = 0:cur blocks = 80
sgid:g98765:block size = 4096:hard limit = 50:soft limit = 50:cur blocks = 40
2016-01-06 12:59:06 +02:00
ABC
}
2022-04-22 15:34:08 +02:00
setup_1_conf( )
{
conf_name = " $1 "
subdir = " $2 "
absdir = $( readlink -f $WORKDIR /$subdir )
conf_lines | sed -rn " s/^ $conf_name :(.*)/\1/p " | tr ":" "\n" |
awk -F '=' -v atdir = $absdir 'NF==1 {section=$1} NF==2 {sub(/\s*$/, "", $1); printf "\tfake_dfq:%s/%s/%s =%s\n", section, $1, atdir, $2}'
2016-01-06 12:59:06 +02:00
}
2022-04-22 15:34:08 +02:00
setup_conf( )
{
rm $CONFFILE
touch $CONFFILE
2016-01-06 12:59:06 +02:00
2022-04-22 15:34:08 +02:00
until [ -z " $1 " ] ; do
setup_1_conf $1 $2 >>$CONFFILE
shift
shift
done
sighup_smbd
#let it load...
sleep .5
2016-01-06 12:59:06 +02:00
}
2022-04-22 15:34:08 +02:00
test_smbclient_dfree( )
{
2016-01-06 12:59:06 +02:00
name = " $1 "
2022-04-22 15:34:08 +02:00
share = " $2 "
dir = " $3 "
confs = " $4 "
expected = " $5 "
shift
shift
shift
shift
subunit_start_test " $name "
setup_conf $confs
2022-02-24 11:41:14 +01:00
output = $( $VALGRIND $smbclient //$SERVER /$share -c " cd $dir ; l " " $@ " 2>& 1)
2022-04-22 15:34:08 +02:00
status = $?
if [ " $status " = "0" ] ; then
2016-01-06 12:59:06 +02:00
received = $( echo " $output " | awk '/blocks of size/ {print $1, $5, $6}' )
if [ " $expected " = " $received " ] ; then
subunit_pass_test " $name "
2023-04-11 14:34:07 +12:00
return 0
2016-01-06 12:59:06 +02:00
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return 1
2016-01-06 12:59:06 +02:00
fi
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return $status
2016-01-06 12:59:06 +02:00
fi
}
2018-05-23 11:25:42 -07:00
# Issue two queries to different directories in one session to test
# caching effects
2022-04-22 15:34:08 +02:00
test_smbclient_dfree_2( )
{
2018-05-23 11:25:42 -07:00
name = " $1 "
share = " $2 "
dir1 = " $3 "
dir2 = " $4 "
confs = " $5 "
expected = " $6 "
subunit_start_test " $name "
setup_conf $confs
output = $( $VALGRIND $smbclient //$SERVER /$share \
2022-02-24 11:41:14 +01:00
-c " cd $dir1 ; du; cd ..; cd $dir2 ; du " " $@ " 2>& 1)
2018-05-23 11:25:42 -07:00
status = $?
if [ " $status " = "0" ] ; then
2022-04-22 15:34:08 +02:00
received = $( echo " $output " |
awk '/blocks of size/ {print $1, $5, $6}' |
tr '\n' ' ' )
2018-05-23 11:25:42 -07:00
if [ " $expected " = " $received " ] ; then
subunit_pass_test " $name "
2023-04-11 14:34:07 +12:00
return 0
2018-05-23 11:25:42 -07:00
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return 1
2018-05-23 11:25:42 -07:00
fi
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return $status
2018-05-23 11:25:42 -07:00
fi
}
2022-04-22 15:34:08 +02:00
test_smbcquotas( )
{
2016-01-06 12:59:06 +02:00
name = " $1 "
2022-04-22 15:34:08 +02:00
conf = " $2 "
user = " $3 "
expected = " $4 "
proto = " $5 "
shift
shift
shift
shift
2016-01-06 12:59:06 +02:00
shift
subunit_start_test " $name "
2022-04-22 15:34:08 +02:00
setup_conf " $conf " "."
if [ " $proto " = "smb2" ] ; then
mproto = "-m SMB2"
else
mproto = "-m SMB1"
fi
2017-03-08 14:27:27 +00:00
2022-02-24 11:41:14 +01:00
output = $( $VALGRIND $smbcquotas $mproto //$SERVER /dfq " $@ " 2>/dev/null | tr '\\' '/' )
2016-01-06 12:59:06 +02:00
status = $?
if [ " $status " = "0" ] ; then
2016-01-27 21:47:30 +02:00
received = $( echo " $output " | awk " / $SERVER \\/ $user / {printf \"%s%s%s\", \$3, \$4, \$5} " )
2016-01-06 12:59:06 +02:00
if [ " $expected " = " $received " ] ; then
subunit_pass_test " $name "
2023-04-11 14:34:07 +12:00
return 0
2016-01-06 12:59:06 +02:00
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return 1
2016-01-06 12:59:06 +02:00
fi
else
echo " $output " | subunit_fail_test " $name "
2023-04-11 14:34:07 +12:00
return $status
2016-01-06 12:59:06 +02:00
fi
}
2020-10-22 11:08:19 +02:00
if [ $protocol != "SMB3" ] && [ $protocol != "NT1" ] ; then
2019-11-27 19:37:26 +00:00
echo " unsupported protocol $protocol " | subunit_fail_test "Test dfree quota"
2022-04-22 15:34:08 +02:00
failed = $( expr $failed + 1)
2019-11-27 19:37:26 +00:00
fi
if [ $protocol = "NT1" ] ; then
setup_conf
#basic quota test (SMB1 only)
2022-04-22 15:34:08 +02:00
test_smbcquotas "Test user quota" confq1 $USERNAME "40960/4096000/3072000" "smb1" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = NT1 || failed = $( expr $failed + 1)
2019-11-27 19:37:26 +00:00
exit $failed
fi
2016-01-06 12:59:06 +02:00
#basic disk-free tests
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root SMB3 no quota" dfq "." "conf1 ." "10 1024. 5" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test dfree subdir SMB3 no quota" dfq "subdir1" "conf1 . conf2 subdir1" "20 1024. 10" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test large disk" dfq "." "conf3 ." "1125899906842624 1024. 3000" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2017-03-08 14:27:27 +00:00
#basic quota test (SMB2 only)
2022-04-22 15:34:08 +02:00
test_smbcquotas "Test user quota" confq1 $USERNAME "40960/4096000/3072000" "smb2" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB2 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
2018-05-23 11:25:42 -07:00
# Test dfree cache through queries in two different directories
test_smbclient_dfree_2 "Test dfree cache" dfq_cache "." "subdir1" \
2022-04-22 15:34:08 +02:00
"conf1 . conf2 subdir1" "10 1024. 5 20 1024. 10 " \
-U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 ||
failed = $( expr $failed + 1)
2018-05-23 11:25:42 -07:00
2016-01-06 12:59:06 +02:00
#quota limit > disk size, remaining quota > disk free
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root df vs quota case 1" dfq "." "confdfq1 ." "80 1024. 40" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
#quota limit > disk size, remaining quota < disk free
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root df vs quota case 2" dfq "." "confdfq2 ." "80 1024. 12" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
#quota limit < disk size, remaining quota > disk free
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root df vs quota case 3" dfq "." "confdfq3 ." "160 1024. 40" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
#quota limit < disk size, remaining quota < disk free
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root df vs quota case 4" dfq "." "confdfq4 ." "160 1024. 12" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test dfree subdir df vs quota case 4" dfq "subdir1" "confdfq4 subdir1" "160 1024. 12" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
#quota-->disk free special cases
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test quota->dfree soft limit" dfq "subdir1" "slimit subdir1" "168 1024. 0" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test quota->dfree hard limit" dfq "subdir1" "hlimit subdir1" "180 1024. 0" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test quota->dfree inode soft limit" dfq "subdir1" "islimit subdir1" "148 1024. 0" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test quota->dfree inode hard limit" dfq "subdir1" "ihlimit subdir1" "148 1024. 0" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test quota->dfree err try group" dfq "subdir1" "trygrp1 subdir1" "240 1024. 20" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
test_smbclient_dfree "Test quota->dfree no-quota try group" dfq "subdir1" "trygrp2 subdir1" "240 1024. 16" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-06 12:59:06 +02:00
2019-08-13 13:44:52 -07:00
# sgid on directory
test_smbclient_dfree "Test quota on sgid directory" dfq "subdir1" \
2022-04-22 15:34:08 +02:00
"sgid subdir1" "200 1024. 40" -U$USERNAME %$PASSWORD \
--option= clientmaxprotocol = SMB3 ||
failed = $( expr $failed + 1)
2019-08-13 13:44:52 -07:00
2016-01-19 14:38:03 +02:00
#block size different in quota and df systems
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test quota->dfree different block size" dfq "subdir1" "blksize subdir1" "307200 1024. 307200" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-01-19 14:38:03 +02:00
2016-05-26 22:52:09 +03:00
#quota configured but not enforced
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root quota not enforced" dfq "." "notenforce ." "320 1024. 40" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-05-26 22:52:09 +03:00
#FS quota not implemented (NFS case)
2022-04-22 15:34:08 +02:00
test_smbclient_dfree "Test dfree share root FS quota not implemented" dfq "." "nfs ." "160 1024. 12" -U$USERNAME %$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-05-26 22:52:09 +03:00
2016-08-11 23:54:22 +03:00
#test for dfree when owner is inherited
#setup two folders with different owners
rm -rf $WORKDIR /subdir3/*
2022-04-22 15:34:08 +02:00
for d in / subdir3; do
$VALGRIND $smbcacls -U$USERNAME %$PASSWORD -D " ACL: $SERVER \user1:ALLOWED/0x0/FULL " //$SERVER /dfq $d >/dev/null 2>& 1
$VALGRIND $smbcacls -U$USERNAME %$PASSWORD -a " ACL: $SERVER \user1:ALLOWED/0x0/FULL " //$SERVER /dfq $d || failed = $( expr $failed + 1)
$VALGRIND $smbcacls -U$USERNAME %$PASSWORD -D " ACL: $SERVER \user2:ALLOWED/0x0/FULL " //$SERVER /dfq $d >/dev/null 2>& 1
$VALGRIND $smbcacls -U$USERNAME %$PASSWORD -a " ACL: $SERVER \user2:ALLOWED/0x0/FULL " //$SERVER /dfq $d || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
done
2022-04-22 15:34:08 +02:00
$VALGRIND $smbclient //$SERVER /dfq -c "cd subdir3; mkdir user1" -Uuser1%$PASSWORD --option= clientmaxprotocol = SMB3 >/dev/null 2>& 1 || failed = $( expr $failed + 1)
$VALGRIND $smbclient //$SERVER /dfq -c "cd subdir3; mkdir user2" -Uuser2%$PASSWORD --option= clientmaxprotocol = SMB3 >/dev/null 2>& 1 || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
#test quotas
test_smbclient_dfree "Test dfree without inherit owner - user1 at user1" \
2022-04-22 15:34:08 +02:00
dfq "subdir3/user1" "confdfqp subdir3/user1 confdfqp subdir3/user2" "160 1024. 16" \
-Uuser1%$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
test_smbclient_dfree "Test dfree without inherit owner - user1 at user2" \
2022-04-22 15:34:08 +02:00
dfq "subdir3/user2" "confdfqp subdir3/user1 confdfqp subdir3/user2" "160 1024. 16" \
-Uuser1%$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
test_smbclient_dfree "Test dfree with inherit owner - user1 at user1" \
2022-04-22 15:34:08 +02:00
dfq_owner "subdir3/user1" "confdfqp subdir3/user1 confdfqp subdir3/user2" "160 1024. 16" \
-Uuser1%$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
test_smbclient_dfree "Test dfree with inherit owner - user1 at user2" \
2022-04-22 15:34:08 +02:00
dfq_owner "subdir3/user2" "confdfqp subdir3/user1 confdfqp subdir3/user2" "164 1024. 20" \
-Uuser1%$PASSWORD --option= clientmaxprotocol = SMB3 || failed = $( expr $failed + 1)
2016-08-11 23:54:22 +03:00
2016-01-06 12:59:06 +02:00
setup_conf
exit $failed