t_modload.sh revision 1.1.4.2 1 1.1.4.2 keiichi # $NetBSD: t_modload.sh,v 1.1.4.2 2008/03/24 07:16:33 keiichi Exp $
2 1.1.4.2 keiichi #
3 1.1.4.2 keiichi # Copyright (c) 2008 The NetBSD Foundation, Inc.
4 1.1.4.2 keiichi # All rights reserved.
5 1.1.4.2 keiichi #
6 1.1.4.2 keiichi # Redistribution and use in source and binary forms, with or without
7 1.1.4.2 keiichi # modification, are permitted provided that the following conditions
8 1.1.4.2 keiichi # are met:
9 1.1.4.2 keiichi # 1. Redistributions of source code must retain the above copyright
10 1.1.4.2 keiichi # notice, this list of conditions and the following disclaimer.
11 1.1.4.2 keiichi # 2. Redistributions in binary form must reproduce the above copyright
12 1.1.4.2 keiichi # notice, this list of conditions and the following disclaimer in the
13 1.1.4.2 keiichi # documentation and/or other materials provided with the distribution.
14 1.1.4.2 keiichi # 3. All advertising materials mentioning features or use of this software
15 1.1.4.2 keiichi # must display the following acknowledgement:
16 1.1.4.2 keiichi # This product includes software developed by the NetBSD
17 1.1.4.2 keiichi # Foundation, Inc. and its contributors.
18 1.1.4.2 keiichi # 4. Neither the name of The NetBSD Foundation nor the names of its
19 1.1.4.2 keiichi # contributors may be used to endorse or promote products derived
20 1.1.4.2 keiichi # from this software without specific prior written permission.
21 1.1.4.2 keiichi #
22 1.1.4.2 keiichi # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23 1.1.4.2 keiichi # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24 1.1.4.2 keiichi # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25 1.1.4.2 keiichi # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26 1.1.4.2 keiichi # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 1.1.4.2 keiichi # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28 1.1.4.2 keiichi # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29 1.1.4.2 keiichi # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30 1.1.4.2 keiichi # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31 1.1.4.2 keiichi # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 1.1.4.2 keiichi # POSSIBILITY OF SUCH DAMAGE.
33 1.1.4.2 keiichi #
34 1.1.4.2 keiichi
35 1.1.4.2 keiichi check_sysctl() {
36 1.1.4.2 keiichi echo "${1} = ${2}" >expout
37 1.1.4.2 keiichi atf_check "sysctl ${1}" 0 expout null
38 1.1.4.2 keiichi }
39 1.1.4.2 keiichi
40 1.1.4.2 keiichi atf_test_case plain
41 1.1.4.2 keiichi plain_head() {
42 1.1.4.2 keiichi atf_set "descr" "Test load without arguments"
43 1.1.4.2 keiichi atf_set "require.user" "root"
44 1.1.4.2 keiichi }
45 1.1.4.2 keiichi plain_body() {
46 1.1.4.2 keiichi cat >experr <<EOF
47 1.1.4.2 keiichi modload: No such file or directory
48 1.1.4.2 keiichi EOF
49 1.1.4.2 keiichi atf_check "modload non-existent.o" 1 null experr
50 1.1.4.2 keiichi
51 1.1.4.2 keiichi atf_check "modload $(atf_get_srcdir)/k_helper.o" 0 null null
52 1.1.4.2 keiichi check_sysctl vendor.k_helper.present 1
53 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_int_ok 0
54 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_str_ok 0
55 1.1.4.2 keiichi atf_check "modunload k_helper" 0 null null
56 1.1.4.2 keiichi }
57 1.1.4.2 keiichi plain_cleanup() {
58 1.1.4.2 keiichi modunload k_helper >/dev/null 2>&1
59 1.1.4.2 keiichi }
60 1.1.4.2 keiichi
61 1.1.4.2 keiichi atf_test_case bflag
62 1.1.4.2 keiichi bflag_head() {
63 1.1.4.2 keiichi atf_set "descr" "Test the -b flag"
64 1.1.4.2 keiichi atf_set "require.user" "root"
65 1.1.4.2 keiichi }
66 1.1.4.2 keiichi bflag_body() {
67 1.1.4.2 keiichi echo "Checking error conditions"
68 1.1.4.2 keiichi
69 1.1.4.2 keiichi atf_check "modload -b foo k_helper.o" 1 null stderr
70 1.1.4.2 keiichi atf_check "grep 'Invalid parameter.*foo' stderr" 0 ignore null
71 1.1.4.2 keiichi
72 1.1.4.2 keiichi atf_check "modload -b foo= k_helper.o" 1 null stderr
73 1.1.4.2 keiichi atf_check "grep 'Invalid boolean value' stderr" 0 ignore null
74 1.1.4.2 keiichi
75 1.1.4.2 keiichi atf_check "modload -b foo=bar k_helper.o" 1 null stderr
76 1.1.4.2 keiichi atf_check "grep 'Invalid boolean value.*bar' stderr" 0 ignore null
77 1.1.4.2 keiichi
78 1.1.4.2 keiichi atf_check "modload -b foo=falsea k_helper.o" 1 null stderr
79 1.1.4.2 keiichi atf_check "grep 'Invalid boolean value.*falsea' stderr" 0 ignore null
80 1.1.4.2 keiichi
81 1.1.4.2 keiichi atf_check "modload -b foo=truea k_helper.o" 1 null stderr
82 1.1.4.2 keiichi atf_check "grep 'Invalid boolean value.*truea' stderr" 0 ignore null
83 1.1.4.2 keiichi
84 1.1.4.2 keiichi # TODO Once sysctl(8) supports CTLTYPE_BOOL nodes.
85 1.1.4.2 keiichi #echo "Checking valid values"
86 1.1.4.2 keiichi }
87 1.1.4.2 keiichi bflag_cleanup() {
88 1.1.4.2 keiichi modunload k_helper >/dev/null 2>&1
89 1.1.4.2 keiichi }
90 1.1.4.2 keiichi
91 1.1.4.2 keiichi atf_test_case iflag
92 1.1.4.2 keiichi iflag_head() {
93 1.1.4.2 keiichi atf_set "descr" "Test the -i flag"
94 1.1.4.2 keiichi atf_set "require.user" "root"
95 1.1.4.2 keiichi }
96 1.1.4.2 keiichi iflag_body() {
97 1.1.4.2 keiichi echo "Checking error conditions"
98 1.1.4.2 keiichi
99 1.1.4.2 keiichi atf_check "modload -i foo k_helper.o" 1 null stderr
100 1.1.4.2 keiichi atf_check "grep 'Invalid parameter.*foo' stderr" 0 ignore null
101 1.1.4.2 keiichi
102 1.1.4.2 keiichi atf_check "modload -i foo= k_helper.o" 1 null stderr
103 1.1.4.2 keiichi atf_check "grep 'Invalid integer value' stderr" 0 ignore null
104 1.1.4.2 keiichi
105 1.1.4.2 keiichi atf_check "modload -i foo=bar k_helper.o" 1 null stderr
106 1.1.4.2 keiichi atf_check "grep 'Invalid integer value.*bar' stderr" 0 ignore null
107 1.1.4.2 keiichi
108 1.1.4.2 keiichi atf_check "modload -i foo=123a k_helper.o" 1 null stderr
109 1.1.4.2 keiichi atf_check "grep 'Invalid integer value.*123a' stderr" 0 ignore null
110 1.1.4.2 keiichi
111 1.1.4.2 keiichi echo "Checking valid values"
112 1.1.4.2 keiichi
113 1.1.4.2 keiichi for v in 5 10; do
114 1.1.4.2 keiichi atf_check "modload -i prop_int='${v}' \
115 1.1.4.2 keiichi $(atf_get_srcdir)/k_helper.o" 0 null null
116 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_int_ok 1
117 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_int_val "${v}"
118 1.1.4.2 keiichi atf_check "modunload k_helper" 0 null null
119 1.1.4.2 keiichi done
120 1.1.4.2 keiichi }
121 1.1.4.2 keiichi iflag_cleanup() {
122 1.1.4.2 keiichi modunload k_helper >/dev/null 2>&1
123 1.1.4.2 keiichi }
124 1.1.4.2 keiichi
125 1.1.4.2 keiichi atf_test_case sflag
126 1.1.4.2 keiichi sflag_head() {
127 1.1.4.2 keiichi atf_set "descr" "Test the -s flag"
128 1.1.4.2 keiichi atf_set "require.user" "root"
129 1.1.4.2 keiichi }
130 1.1.4.2 keiichi sflag_body() {
131 1.1.4.2 keiichi echo "Checking error conditions"
132 1.1.4.2 keiichi
133 1.1.4.2 keiichi atf_check "modload -s foo k_helper.o" 1 null stderr
134 1.1.4.2 keiichi atf_check "grep 'Invalid parameter.*foo' stderr" 0 ignore null
135 1.1.4.2 keiichi
136 1.1.4.2 keiichi echo "Checking valid values"
137 1.1.4.2 keiichi
138 1.1.4.2 keiichi for v in '1st string' '2nd string'; do
139 1.1.4.2 keiichi atf_check "modload -s prop_str='${v}' \
140 1.1.4.2 keiichi $(atf_get_srcdir)/k_helper.o" 0 null null
141 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_str_ok 1
142 1.1.4.2 keiichi check_sysctl vendor.k_helper.prop_str_val "${v}"
143 1.1.4.2 keiichi atf_check "modunload k_helper" 0 null null
144 1.1.4.2 keiichi done
145 1.1.4.2 keiichi }
146 1.1.4.2 keiichi sflag_cleanup() {
147 1.1.4.2 keiichi modunload k_helper >/dev/null 2>&1
148 1.1.4.2 keiichi }
149 1.1.4.2 keiichi
150 1.1.4.2 keiichi atf_init_test_cases()
151 1.1.4.2 keiichi {
152 1.1.4.2 keiichi atf_add_test_case plain
153 1.1.4.2 keiichi atf_add_test_case bflag
154 1.1.4.2 keiichi atf_add_test_case iflag
155 1.1.4.2 keiichi atf_add_test_case sflag
156 1.1.4.2 keiichi }
157