t_opencrypto.sh revision 1.4.8.2 1 1.4.8.2 tls # $NetBSD: t_opencrypto.sh,v 1.4.8.2 2014/08/20 00:04:46 tls Exp $
2 1.4.8.2 tls #
3 1.4.8.2 tls # Copyright (c) 2014 The NetBSD Foundation, Inc.
4 1.4.8.2 tls # All rights reserved.
5 1.4.8.2 tls #
6 1.4.8.2 tls # Redistribution and use in source and binary forms, with or without
7 1.4.8.2 tls # modification, are permitted provided that the following conditions
8 1.4.8.2 tls # are met:
9 1.4.8.2 tls # 1. Redistributions of source code must retain the above copyright
10 1.4.8.2 tls # notice, this list of conditions and the following disclaimer.
11 1.4.8.2 tls # 2. Redistributions in binary form must reproduce the above copyright
12 1.4.8.2 tls # notice, this list of conditions and the following disclaimer in the
13 1.4.8.2 tls # documentation and/or other materials provided with the distribution.
14 1.4.8.2 tls #
15 1.4.8.2 tls # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
16 1.4.8.2 tls # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17 1.4.8.2 tls # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 1.4.8.2 tls # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
19 1.4.8.2 tls # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 1.4.8.2 tls # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 1.4.8.2 tls # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 1.4.8.2 tls # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 1.4.8.2 tls # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 1.4.8.2 tls # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 1.4.8.2 tls # POSSIBILITY OF SUCH DAMAGE.
26 1.4.8.2 tls #
27 1.4.8.2 tls
28 1.4.8.2 tls # Start a rumpserver, load required modules, and set requires sysctl vars
29 1.4.8.2 tls
30 1.4.8.2 tls start_rump() {
31 1.4.8.2 tls rump_libs="-l rumpvfs -l rumpdev -l rumpdev_opencrypto"
32 1.4.8.2 tls rump_libs="${rump_libs} -l rumpkern_z -l rumpkern_crypto"
33 1.4.8.2 tls
34 1.4.8.2 tls rump_server ${rump_libs} ${RUMP_SERVER} || \
35 1.4.8.2 tls return 1
36 1.4.8.2 tls
37 1.4.8.2 tls rump.sysctl -w kern.cryptodevallowsoft=-1 && \
38 1.4.8.2 tls return 0
39 1.4.8.2 tls
40 1.4.8.2 tls rump.halt
41 1.4.8.2 tls
42 1.4.8.2 tls return 1
43 1.4.8.2 tls }
44 1.4.8.2 tls
45 1.4.8.2 tls common_head() {
46 1.4.8.2 tls atf_set descr "$1"
47 1.4.8.2 tls atf_set timeout 10
48 1.4.8.2 tls atf_set require.progs rump_server rump.sysctl rump.halt
49 1.4.8.2 tls }
50 1.4.8.2 tls
51 1.4.8.2 tls common_body() {
52 1.4.8.2 tls local status
53 1.4.8.2 tls
54 1.4.8.2 tls start_rump || atf_skip "Cannot set-up rump environment"
55 1.4.8.2 tls LD_PRELOAD="/usr/lib/librumphijack.so" ; export LD_PRELOAD
56 1.4.8.2 tls RUMPHIJACK="blanket=/dev/crypto" ; export RUMPHIJACK
57 1.4.8.2 tls $(atf_get_srcdir)/$1
58 1.4.8.2 tls status=$?
59 1.4.8.2 tls unset RUMPHIJACK
60 1.4.8.2 tls unset LD_PRELOAD
61 1.4.8.2 tls if [ $status -ne 0 ] ; then
62 1.4.8.2 tls atf_fail "$1 returned non-zero status, check output/error"
63 1.4.8.2 tls fi
64 1.4.8.2 tls }
65 1.4.8.2 tls
66 1.4.8.2 tls common_cleanup() {
67 1.4.8.2 tls unset RUMPHIJACK
68 1.4.8.2 tls unset LD_PRELOAD
69 1.4.8.2 tls rump.halt
70 1.4.8.2 tls }
71 1.4.8.2 tls
72 1.4.8.2 tls atf_test_case arc4 cleanup
73 1.4.8.2 tls arc4_head() {
74 1.4.8.2 tls common_head "Test ARC4 crypto"
75 1.4.8.2 tls }
76 1.4.8.2 tls
77 1.4.8.2 tls arc4_body() {
78 1.4.8.2 tls atf_skip "ARC4 not implemented by swcrypto"
79 1.4.8.2 tls common_body h_arc4
80 1.4.8.2 tls }
81 1.4.8.2 tls
82 1.4.8.2 tls arc4_cleanup() {
83 1.4.8.2 tls common_cleanup
84 1.4.8.2 tls }
85 1.4.8.2 tls
86 1.4.8.2 tls atf_test_case camellia cleanup
87 1.4.8.2 tls camellia_head() {
88 1.4.8.2 tls common_head "Test CAMELLIA_CBC crypto"
89 1.4.8.2 tls }
90 1.4.8.2 tls
91 1.4.8.2 tls camellia_body() {
92 1.4.8.2 tls common_body h_camellia
93 1.4.8.2 tls }
94 1.4.8.2 tls
95 1.4.8.2 tls camellia_cleanup() {
96 1.4.8.2 tls common_cleanup
97 1.4.8.2 tls }
98 1.4.8.2 tls
99 1.4.8.2 tls atf_test_case cbcdes cleanup
100 1.4.8.2 tls cbcdes_head() {
101 1.4.8.2 tls common_head "Test ARC4 crypto"
102 1.4.8.2 tls }
103 1.4.8.2 tls
104 1.4.8.2 tls cbcdes_body() {
105 1.4.8.2 tls common_body h_cbcdes
106 1.4.8.2 tls }
107 1.4.8.2 tls
108 1.4.8.2 tls cbcdes_cleanup() {
109 1.4.8.2 tls common_cleanup
110 1.4.8.2 tls }
111 1.4.8.2 tls
112 1.4.8.2 tls atf_test_case comp cleanup
113 1.4.8.2 tls comp_head() {
114 1.4.8.2 tls common_head "Test GZIP_COMP Compression"
115 1.4.8.2 tls }
116 1.4.8.2 tls
117 1.4.8.2 tls comp_body() {
118 1.4.8.2 tls common_body h_comp
119 1.4.8.2 tls }
120 1.4.8.2 tls
121 1.4.8.2 tls comp_cleanup() {
122 1.4.8.2 tls common_cleanup
123 1.4.8.2 tls }
124 1.4.8.2 tls
125 1.4.8.2 tls atf_test_case comp_deflate cleanup
126 1.4.8.2 tls comp_deflate_head() {
127 1.4.8.2 tls common_head "Test DEFLATE_COMP Compression"
128 1.4.8.2 tls }
129 1.4.8.2 tls
130 1.4.8.2 tls comp_deflate_body() {
131 1.4.8.2 tls common_body h_comp_zlib
132 1.4.8.2 tls }
133 1.4.8.2 tls
134 1.4.8.2 tls comp_deflate_cleanup() {
135 1.4.8.2 tls common_cleanup
136 1.4.8.2 tls }
137 1.4.8.2 tls
138 1.4.8.2 tls atf_test_case comp_zlib_rnd cleanup
139 1.4.8.2 tls comp_zlib_rnd_head() {
140 1.4.8.2 tls common_head "Test DEFLATE_COMP Compression with random data"
141 1.4.8.2 tls }
142 1.4.8.2 tls
143 1.4.8.2 tls comp_zlib_rnd_body() {
144 1.4.8.2 tls common_body h_comp_zlib_rnd
145 1.4.8.2 tls }
146 1.4.8.2 tls
147 1.4.8.2 tls comp_zlib_rnd_cleanup() {
148 1.4.8.2 tls common_cleanup
149 1.4.8.2 tls }
150 1.4.8.2 tls
151 1.4.8.2 tls atf_test_case aesctr1 cleanup
152 1.4.8.2 tls aesctr1_head() {
153 1.4.8.2 tls common_head "Test AES_CTR crypto"
154 1.4.8.2 tls }
155 1.4.8.2 tls
156 1.4.8.2 tls aesctr1_body() {
157 1.4.8.2 tls common_body h_aesctr1
158 1.4.8.2 tls }
159 1.4.8.2 tls
160 1.4.8.2 tls aesctr1_cleanup() {
161 1.4.8.2 tls common_cleanup
162 1.4.8.2 tls }
163 1.4.8.2 tls
164 1.4.8.2 tls atf_test_case aesctr2 cleanup
165 1.4.8.2 tls aesctr2_head() {
166 1.4.8.2 tls common_head "Test AES_CTR crypto"
167 1.4.8.2 tls }
168 1.4.8.2 tls
169 1.4.8.2 tls aesctr2_body() {
170 1.4.8.2 tls common_body h_aesctr2
171 1.4.8.2 tls }
172 1.4.8.2 tls
173 1.4.8.2 tls aesctr2_cleanup() {
174 1.4.8.2 tls common_cleanup
175 1.4.8.2 tls }
176 1.4.8.2 tls
177 1.4.8.2 tls atf_test_case gcm cleanup
178 1.4.8.2 tls gcm_head() {
179 1.4.8.2 tls common_head "Test AES_GCM_16 crypto"
180 1.4.8.2 tls }
181 1.4.8.2 tls
182 1.4.8.2 tls gcm_body() {
183 1.4.8.2 tls common_body h_gcm
184 1.4.8.2 tls }
185 1.4.8.2 tls
186 1.4.8.2 tls gcm_cleanup() {
187 1.4.8.2 tls common_cleanup
188 1.4.8.2 tls }
189 1.4.8.2 tls
190 1.4.8.2 tls atf_test_case md5 cleanup
191 1.4.8.2 tls md5_head() {
192 1.4.8.2 tls common_head "Test MD5 crypto"
193 1.4.8.2 tls }
194 1.4.8.2 tls
195 1.4.8.2 tls md5_body() {
196 1.4.8.2 tls common_body h_md5
197 1.4.8.2 tls }
198 1.4.8.2 tls
199 1.4.8.2 tls md5_cleanup() {
200 1.4.8.2 tls common_cleanup
201 1.4.8.2 tls }
202 1.4.8.2 tls
203 1.4.8.2 tls atf_test_case md5_hmac cleanup
204 1.4.8.2 tls md5_hmac_head() {
205 1.4.8.2 tls common_head "Test MD5_HMAC crypto"
206 1.4.8.2 tls }
207 1.4.8.2 tls
208 1.4.8.2 tls md5_hmac_body() {
209 1.4.8.2 tls common_body h_md5hmac
210 1.4.8.2 tls }
211 1.4.8.2 tls
212 1.4.8.2 tls md5_hmac_cleanup() {
213 1.4.8.2 tls common_cleanup
214 1.4.8.2 tls }
215 1.4.8.2 tls
216 1.4.8.2 tls atf_test_case null cleanup
217 1.4.8.2 tls null_head() {
218 1.4.8.2 tls common_head "Test NULL_CBC crypto"
219 1.4.8.2 tls }
220 1.4.8.2 tls
221 1.4.8.2 tls null_body() {
222 1.4.8.2 tls common_body h_null
223 1.4.8.2 tls }
224 1.4.8.2 tls
225 1.4.8.2 tls null_cleanup() {
226 1.4.8.2 tls common_cleanup
227 1.4.8.2 tls }
228 1.4.8.2 tls
229 1.4.8.2 tls atf_test_case sha1_hmac cleanup
230 1.4.8.2 tls sha1_hmac_head() {
231 1.4.8.2 tls common_head "Test SHA1_HMAC crypto"
232 1.4.8.2 tls }
233 1.4.8.2 tls
234 1.4.8.2 tls sha1_hmac_body() {
235 1.4.8.2 tls common_body h_sha1hmac
236 1.4.8.2 tls }
237 1.4.8.2 tls
238 1.4.8.2 tls sha1_hmac_cleanup() {
239 1.4.8.2 tls common_cleanup
240 1.4.8.2 tls }
241 1.4.8.2 tls
242 1.4.8.2 tls atf_test_case xcbcmac cleanup
243 1.4.8.2 tls xcbcmac_head() {
244 1.4.8.2 tls common_head "Test XCBC_MAC_96 crypto"
245 1.4.8.2 tls }
246 1.4.8.2 tls
247 1.4.8.2 tls xcbcmac_body() {
248 1.4.8.2 tls common_body h_xcbcmac
249 1.4.8.2 tls }
250 1.4.8.2 tls
251 1.4.8.2 tls xcbcmac_cleanup() {
252 1.4.8.2 tls common_cleanup
253 1.4.8.2 tls }
254 1.4.8.2 tls
255 1.4.8.2 tls atf_init_test_cases() {
256 1.4.8.2 tls RUMP_SERVER="unix://t_opencrypto_socket" ; export RUMP_SERVER
257 1.4.8.2 tls
258 1.4.8.2 tls atf_add_test_case arc4
259 1.4.8.2 tls atf_add_test_case camellia
260 1.4.8.2 tls atf_add_test_case cbcdes
261 1.4.8.2 tls atf_add_test_case comp
262 1.4.8.2 tls atf_add_test_case comp_deflate
263 1.4.8.2 tls atf_add_test_case comp_zlib_rnd
264 1.4.8.2 tls atf_add_test_case aesctr1
265 1.4.8.2 tls atf_add_test_case aesctr2
266 1.4.8.2 tls atf_add_test_case gcm
267 1.4.8.2 tls atf_add_test_case md5
268 1.4.8.2 tls atf_add_test_case md5_hmac
269 1.4.8.2 tls atf_add_test_case null
270 1.4.8.2 tls atf_add_test_case sha1_hmac
271 1.4.8.2 tls atf_add_test_case xcbcmac
272 1.4.8.2 tls }
273