Drop main() prototype. Syncs with NetBSD-8
[minix.git] / tests / crypto / opencrypto / t_opencrypto.sh
blob141836becb6caa8041864e192ebbc165d88cebe9
1 # $NetBSD: t_opencrypto.sh,v 1.5 2015/03/16 16:42:27 prlw1 Exp $
3 # Copyright (c) 2014 The NetBSD Foundation, Inc.
4 # All rights reserved.
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions
8 # are met:
9 # 1. Redistributions of source code must retain the above copyright
10 # notice, this list of conditions and the following disclaimer.
11 # 2. Redistributions in binary form must reproduce the above copyright
12 # notice, this list of conditions and the following disclaimer in the
13 # documentation and/or other materials provided with the distribution.
15 # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
16 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
19 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 # POSSIBILITY OF SUCH DAMAGE.
28 # Start a rumpserver, load required modules, and set requires sysctl vars
30 start_rump() {
31 rump_libs="-l rumpvfs -l rumpdev -l rumpdev_opencrypto"
32 rump_libs="${rump_libs} -l rumpkern_z -l rumpkern_crypto"
34 rump_server ${rump_libs} ${RUMP_SERVER} || \
35 return 1
37 rump.sysctl -w kern.cryptodevallowsoft=-1 && \
38 return 0
40 rump.halt
42 return 1
45 common_head() {
46 atf_set descr "$1"
47 atf_set timeout 10
48 atf_set require.progs rump_server rump.sysctl rump.halt
51 common_body() {
52 local status
54 start_rump || atf_skip "Cannot set-up rump environment"
55 LD_PRELOAD="/usr/lib/librumphijack.so" ; export LD_PRELOAD
56 RUMPHIJACK="blanket=/dev/crypto" ; export RUMPHIJACK
57 $(atf_get_srcdir)/$1
58 status=$?
59 unset RUMPHIJACK
60 unset LD_PRELOAD
61 if [ $status -ne 0 ] ; then
62 atf_fail "$1 returned non-zero status, check output/error"
66 common_cleanup() {
67 unset RUMPHIJACK
68 unset LD_PRELOAD
69 rump.halt
72 atf_test_case arc4 cleanup
73 arc4_head() {
74 common_head "Test ARC4 crypto"
77 arc4_body() {
78 atf_skip "ARC4 not implemented by swcrypto"
79 common_body h_arc4
82 arc4_cleanup() {
83 common_cleanup
86 atf_test_case camellia cleanup
87 camellia_head() {
88 common_head "Test CAMELLIA_CBC crypto"
91 camellia_body() {
92 common_body h_camellia
95 camellia_cleanup() {
96 common_cleanup
99 atf_test_case cbcdes cleanup
100 cbcdes_head() {
101 common_head "Test DES_CBC crypto"
104 cbcdes_body() {
105 common_body h_cbcdes
108 cbcdes_cleanup() {
109 common_cleanup
112 atf_test_case comp cleanup
113 comp_head() {
114 common_head "Test GZIP_COMP Compression"
117 comp_body() {
118 common_body h_comp
121 comp_cleanup() {
122 common_cleanup
125 atf_test_case comp_deflate cleanup
126 comp_deflate_head() {
127 common_head "Test DEFLATE_COMP Compression"
130 comp_deflate_body() {
131 common_body h_comp_zlib
134 comp_deflate_cleanup() {
135 common_cleanup
138 atf_test_case comp_zlib_rnd cleanup
139 comp_zlib_rnd_head() {
140 common_head "Test DEFLATE_COMP Compression with random data"
143 comp_zlib_rnd_body() {
144 common_body h_comp_zlib_rnd
147 comp_zlib_rnd_cleanup() {
148 common_cleanup
151 atf_test_case aesctr1 cleanup
152 aesctr1_head() {
153 common_head "Test AES_CTR crypto"
156 aesctr1_body() {
157 common_body h_aesctr1
160 aesctr1_cleanup() {
161 common_cleanup
164 atf_test_case aesctr2 cleanup
165 aesctr2_head() {
166 common_head "Test AES_CTR crypto"
169 aesctr2_body() {
170 common_body h_aesctr2
173 aesctr2_cleanup() {
174 common_cleanup
177 atf_test_case gcm cleanup
178 gcm_head() {
179 common_head "Test AES_GCM_16 crypto"
182 gcm_body() {
183 common_body h_gcm
186 gcm_cleanup() {
187 common_cleanup
190 atf_test_case md5 cleanup
191 md5_head() {
192 common_head "Test MD5 crypto"
195 md5_body() {
196 common_body h_md5
199 md5_cleanup() {
200 common_cleanup
203 atf_test_case md5_hmac cleanup
204 md5_hmac_head() {
205 common_head "Test MD5_HMAC crypto"
208 md5_hmac_body() {
209 common_body h_md5hmac
212 md5_hmac_cleanup() {
213 common_cleanup
216 atf_test_case null cleanup
217 null_head() {
218 common_head "Test NULL_CBC crypto"
221 null_body() {
222 common_body h_null
225 null_cleanup() {
226 common_cleanup
229 atf_test_case sha1_hmac cleanup
230 sha1_hmac_head() {
231 common_head "Test SHA1_HMAC crypto"
234 sha1_hmac_body() {
235 common_body h_sha1hmac
238 sha1_hmac_cleanup() {
239 common_cleanup
242 atf_test_case xcbcmac cleanup
243 xcbcmac_head() {
244 common_head "Test XCBC_MAC_96 crypto"
247 xcbcmac_body() {
248 common_body h_xcbcmac
251 xcbcmac_cleanup() {
252 common_cleanup
255 atf_init_test_cases() {
256 RUMP_SERVER="unix://t_opencrypto_socket" ; export RUMP_SERVER
258 atf_add_test_case arc4
259 atf_add_test_case camellia
260 atf_add_test_case cbcdes
261 atf_add_test_case comp
262 atf_add_test_case comp_deflate
263 atf_add_test_case comp_zlib_rnd
264 atf_add_test_case aesctr1
265 atf_add_test_case aesctr2
266 atf_add_test_case gcm
267 atf_add_test_case md5
268 atf_add_test_case md5_hmac
269 atf_add_test_case null
270 atf_add_test_case sha1_hmac
271 atf_add_test_case xcbcmac