e62ff53b73
their software. Obtained from: NetBSD
185 lines
4.7 KiB
Bash
185 lines
4.7 KiB
Bash
#!/bin/sh
|
|
#
|
|
# $NetBSD: h_funcs.subr,v 1.5 2006/11/09 16:20:06 jmmv Exp $
|
|
#
|
|
# Copyright (c) 2005, 2006 The NetBSD Foundation, Inc.
|
|
# All rights reserved.
|
|
#
|
|
# This code is derived from software contributed to The NetBSD Foundation
|
|
# by Julio M. Merino Vidal, developed as part of Google's Summer of Code
|
|
# 2005 program.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions
|
|
# are met:
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
|
|
#
|
|
# Helper functions for tests written in shell script.
|
|
#
|
|
|
|
Prog_Name=${0##*/}
|
|
Src_Dir=$(pwd)
|
|
Unprived_User=
|
|
Verbose=2
|
|
Work_Dir=$(pwd)/tmp
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# die
|
|
#
|
|
# Called by tests when a command fails unexpectedly. Terminates
|
|
# execution and tries to clean up the mount point.
|
|
#
|
|
die() {
|
|
if [ -d ${Work_Dir} ]; then
|
|
cd ${Src_Dir}
|
|
umount ${Work_Dir}
|
|
rmdir ${Work_Dir}
|
|
fi
|
|
[ ${Verbose} -eq 2 ] && err "Test ended unexpectedly"
|
|
[ ${Verbose} -eq 1 ] && echo " failed."
|
|
exit 1
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# err message
|
|
#
|
|
# Shows the given error message and terminates the program.
|
|
#
|
|
err() {
|
|
echo "${Prog_Name}: $*" 1>&2
|
|
exit 1
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# test_mount [args]
|
|
#
|
|
# Mounts tmpfs over ${Work_Dir} and changes the current directory
|
|
# to the mount point. Optional arguments may be passed to the
|
|
# mount command.
|
|
#
|
|
test_mount() {
|
|
mkdir ${Work_Dir} || die
|
|
if [ $# -gt 0 ]; then
|
|
mount -t tmpfs "$@" tmpfs ${Work_Dir} || die
|
|
else
|
|
mount -t tmpfs tmpfs ${Work_Dir} || die
|
|
fi
|
|
cd ${Work_Dir}
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# test_name message
|
|
#
|
|
# Prints a message about what a test is going to do.
|
|
#
|
|
test_name() {
|
|
[ ${Verbose} -gt 1 ] && echo " $*..."
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# test_unmount
|
|
#
|
|
# Unmounts the file system mounted by test_mount.
|
|
#
|
|
test_unmount() {
|
|
cd -
|
|
umount ${Work_Dir} || die
|
|
rmdir ${Work_Dir} || die
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# kqueue_monitor expected_nevents file1 [.. fileN]
|
|
#
|
|
# Monitors the commands given through stdin (one per line) using
|
|
# kqueue and stores the events raised in a log that can be later
|
|
# verified with kqueue_check.
|
|
#
|
|
kqueue_monitor() {
|
|
nev=${1}; shift
|
|
test_name "Running kqueue-monitored commands and expecting" \
|
|
"${nev} events"
|
|
${Src_Dir}/h_tools kqueue ${*} >kqueue.log || return 1
|
|
got=$(wc -l kqueue.log | awk '{ print $1 }')
|
|
test ${got} -eq ${nev}
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# kqueue_check file event
|
|
#
|
|
# Checks if kqueue raised the given event when monitoring the
|
|
# given file.
|
|
#
|
|
kqueue_check() {
|
|
grep "^${1} - ${2}$" kqueue.log >/dev/null
|
|
}
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
main() {
|
|
local args
|
|
|
|
[ $(id -un) = root ] || err "Must be run as root"
|
|
|
|
args=$(getopt u:v:w: $*)
|
|
if [ $? -ne 0 ]; then
|
|
echo "Usage: ${Prog_Name} [-u unprived_user] [-v level] " \
|
|
"[-w root_dir]" 1>&2
|
|
return 1
|
|
fi
|
|
set -- ${args}
|
|
while [ $# -gt 0 ]; do
|
|
case "$1" in
|
|
-u)
|
|
Unprived_User="$2"; shift
|
|
;;
|
|
-v)
|
|
Verbose="$2"; shift
|
|
;;
|
|
-w)
|
|
Work_Dir="$2"; shift
|
|
;;
|
|
--)
|
|
shift; break
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
[ ${Verbose} -eq 1 ] && echo -n "${Prog_Name}:"
|
|
[ ${Verbose} -eq 2 ] && echo "${Prog_Name}: Running tests"
|
|
test_run
|
|
[ ${Verbose} -eq 1 ] && echo " ok."
|
|
[ ${Verbose} -eq 2 ] && echo "${Prog_Name}: All tests were successful"
|
|
|
|
return 0
|
|
}
|
|
|
|
main "$@"
|