1*57718be8SEnji Cooper# $NetBSD: t_rquotad.sh,v 1.4 2014/03/13 12:45:14 gson Exp $ 2*57718be8SEnji Cooper# 3*57718be8SEnji Cooper# Copyright (c) 2011 Manuel Bouyer 4*57718be8SEnji Cooper# All rights reserved. 5*57718be8SEnji Cooper# 6*57718be8SEnji Cooper# Redistribution and use in source and binary forms, with or without 7*57718be8SEnji Cooper# modification, are permitted provided that the following conditions 8*57718be8SEnji Cooper# are met: 9*57718be8SEnji Cooper# 1. Redistributions of source code must retain the above copyright 10*57718be8SEnji Cooper# notice, this list of conditions and the following disclaimer. 11*57718be8SEnji Cooper# 2. Redistributions in binary form must reproduce the above copyright 12*57718be8SEnji Cooper# notice, this list of conditions and the following disclaimer in the 13*57718be8SEnji Cooper# documentation and/or other materials provided with the distribution. 14*57718be8SEnji Cooper# 15*57718be8SEnji Cooper# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 16*57718be8SEnji Cooper# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 17*57718be8SEnji Cooper# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 18*57718be8SEnji Cooper# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 19*57718be8SEnji Cooper# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 20*57718be8SEnji Cooper# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 21*57718be8SEnji Cooper# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22*57718be8SEnji Cooper# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23*57718be8SEnji Cooper# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 24*57718be8SEnji Cooper# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25*57718be8SEnji Cooper# POSSIBILITY OF SUCH DAMAGE. 26*57718be8SEnji Cooper# 27*57718be8SEnji Cooperfor e in le be; do 28*57718be8SEnji Cooper for v in 1; do 29*57718be8SEnji Cooper for q in "user" "group" "both"; do 30*57718be8SEnji Cooper test_case_root get_nfs_${e}_${v}_${q} get_nfs_quota \ 31*57718be8SEnji Cooper "get NFS quota with ${q} enabled" ${e} ${v} ${q} 32*57718be8SEnji Cooper done 33*57718be8SEnji Cooper done 34*57718be8SEnji Cooperdone 35*57718be8SEnji Cooper 36*57718be8SEnji Cooperget_nfs_quota() 37*57718be8SEnji Cooper{ 38*57718be8SEnji Cooper create_ffs $* 39*57718be8SEnji Cooper local q=$3 40*57718be8SEnji Cooper local expect 41*57718be8SEnji Cooper 42*57718be8SEnji Cooper case ${q} in 43*57718be8SEnji Cooper user) 44*57718be8SEnji Cooper expect=u 45*57718be8SEnji Cooper ;; 46*57718be8SEnji Cooper group) 47*57718be8SEnji Cooper expect=g 48*57718be8SEnji Cooper ;; 49*57718be8SEnji Cooper both) 50*57718be8SEnji Cooper expect="u g" 51*57718be8SEnji Cooper ;; 52*57718be8SEnji Cooper *) 53*57718be8SEnji Cooper atf_fail "wrong quota type" 54*57718be8SEnji Cooper ;; 55*57718be8SEnji Cooper esac 56*57718be8SEnji Cooper 57*57718be8SEnji Cooper#start a a nfs server 58*57718be8SEnji Cooper 59*57718be8SEnji Cooper atf_check -s exit:0 rump_server -lrumpvfs -lrumpdev -lrumpnet \ 60*57718be8SEnji Cooper -lrumpnet_net -lrumpnet_netinet -lrumpnet_netinet6 \ 61*57718be8SEnji Cooper -lrumpnet_local -lrumpnet_shmif -lrumpdev_disk -lrumpfs_ffs \ 62*57718be8SEnji Cooper -lrumpfs_nfs -lrumpfs_nfsserver \ 63*57718be8SEnji Cooper -d key=/dk,hostpath=${IMG},size=host ${RUMP_SERVER} 64*57718be8SEnji Cooper 65*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 create 66*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 linkstr shmbus 67*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 inet 10.1.1.1 68*57718be8SEnji Cooper 69*57718be8SEnji Cooper export RUMPHIJACK_RETRYCONNECT=die 70*57718be8SEnji Cooper export LD_PRELOAD=/usr/lib/librumphijack.so 71*57718be8SEnji Cooper 72*57718be8SEnji Cooper atf_check -s exit:0 mkdir /rump/etc 73*57718be8SEnji Cooper atf_check -s exit:0 mkdir /rump/export 74*57718be8SEnji Cooper atf_check -s exit:0 mkdir -p /rump/var/run 75*57718be8SEnji Cooper atf_check -s exit:0 mkdir -p /rump/var/db 76*57718be8SEnji Cooper atf_check -s exit:0 touch /rump/var/db/mountdtab 77*57718be8SEnji Cooper 78*57718be8SEnji Cooper /bin/echo "/export -noresvport -noresvmnt 10.1.1.100" | \ 79*57718be8SEnji Cooper dd of=/rump/etc/exports 2> /dev/null 80*57718be8SEnji Cooper 81*57718be8SEnji Cooper atf_check -s exit:0 -e ignore mount_ffs /dk /rump/export 82*57718be8SEnji Cooper 83*57718be8SEnji Cooper#set a quota limit (and check that we can read it back) 84*57718be8SEnji Cooper for q in ${expect} ; do 85*57718be8SEnji Cooper local id=$(id -${q}) 86*57718be8SEnji Cooper atf_check -s exit:0 \ 87*57718be8SEnji Cooper env LD_PRELOAD=/usr/lib/librumphijack.so RUMPHIJACK=vfs=getvfsstat,blanket=/export edquota -$q -s10k/20 -h40M/50k \ 88*57718be8SEnji Cooper -t 2W/3D ${id} 89*57718be8SEnji Cooper atf_check -s exit:0 \ 90*57718be8SEnji Cooper-o "match:0 10 40960 2weeks 1 20 51200 3days" \ 91*57718be8SEnji Cooper-o "match:Disk quotas for .*: $" \ 92*57718be8SEnji Cooper env LD_PRELOAD=/usr/lib/librumphijack.so RUMPHIJACK=vfs=getvfsstat,blanket=/export quota -${q} -v 93*57718be8SEnji Cooper done 94*57718be8SEnji Cooper 95*57718be8SEnji Cooper # start rpcbind. we want /var/run/rpcbind.sock 96*57718be8SEnji Cooper export RUMPHIJACK='blanket=/var/run,socket=all' 97*57718be8SEnji Cooper atf_check -s exit:0 rpcbind 98*57718be8SEnji Cooper 99*57718be8SEnji Cooper # ok, then we want mountd in the similar fashion 100*57718be8SEnji Cooper export RUMPHIJACK='blanket=/var/run:/var/db:/export,socket=all,path=/rump,vfs=all' 101*57718be8SEnji Cooper atf_check -s exit:0 mountd /rump/etc/exports 102*57718be8SEnji Cooper 103*57718be8SEnji Cooper # and nfs 104*57718be8SEnji Cooper export RUMPHIJACK='blanket=/var/run,socket=all,vfs=all' 105*57718be8SEnji Cooper atf_check -s exit:0 nfsd 106*57718be8SEnji Cooper 107*57718be8SEnji Cooper #finally, rpc.rquotad 108*57718be8SEnji Cooper export RUMPHIJACK='blanket=/var/run:/export,vfs=getvfsstat,socket=all' 109*57718be8SEnji Cooper atf_check -s exit:0 /usr/libexec/rpc.rquotad 110*57718be8SEnji Cooper 111*57718be8SEnji Cooper # now start a client server 112*57718be8SEnji Cooper export RUMP_SERVER=unix://clientsock 113*57718be8SEnji Cooper RUMP_SOCKETS_LIST="${RUMP_SOCKETS_LIST} clientsock" 114*57718be8SEnji Cooper unset RUMPHIJACK 115*57718be8SEnji Cooper unset LD_PRELOAD 116*57718be8SEnji Cooper 117*57718be8SEnji Cooper atf_check -s exit:0 rump_server -lrumpvfs -lrumpnet \ 118*57718be8SEnji Cooper -lrumpnet_net -lrumpnet_netinet -lrumpnet_shmif -lrumpfs_nfs\ 119*57718be8SEnji Cooper ${RUMP_SERVER} 120*57718be8SEnji Cooper 121*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 create 122*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 linkstr shmbus 123*57718be8SEnji Cooper atf_check -s exit:0 rump.ifconfig shmif0 inet 10.1.1.100 124*57718be8SEnji Cooper 125*57718be8SEnji Cooper export LD_PRELOAD=/usr/lib/librumphijack.so 126*57718be8SEnji Cooper 127*57718be8SEnji Cooper atf_check -s exit:0 mkdir /rump/mnt 128*57718be8SEnji Cooper atf_check -s exit:0 mount_nfs 10.1.1.1:/export /rump/mnt 129*57718be8SEnji Cooper 130*57718be8SEnji Cooper #now try a quota(8) call 131*57718be8SEnji Cooper export RUMPHIJACK='blanket=/mnt,socket=all,path=/rump,vfs=getvfsstat' 132*57718be8SEnji Cooper for q in ${expect} ; do 133*57718be8SEnji Cooper local id=$(id -${q}) 134*57718be8SEnji Cooper atf_check -s exit:0 \ 135*57718be8SEnji Cooper-o "match:/mnt 0 10 40960 1 20 51200 " \ 136*57718be8SEnji Cooper-o "match:Disk quotas for .*: $" \ 137*57718be8SEnji Cooper quota -${q} -v 138*57718be8SEnji Cooper done 139*57718be8SEnji Cooper 140*57718be8SEnji Cooper unset LD_PRELOAD 141*57718be8SEnji Cooper rump_quota_shutdown 142*57718be8SEnji Cooper} 143