onetime_test.sh revision 172031
1#!/bin/sh
2# $FreeBSD: head/tools/regression/geom_eli/onetime.t 172031 2007-09-01 06:33:02Z pjd $
3
4base=`basename $0`
5no=45
6sectors=100
7
8echo "1..220"
9
10i=1
11for cipher in aes:0 aes:128 aes:192 aes:256 \
12    3des:0 3des:192 \
13    blowfish:0 blowfish:128 blowfish:160 blowfish:192 blowfish:224 \
14    blowfish:256 blowfish:288 blowfish:320 blowfish:352 blowfish:384 \
15    blowfish:416 blowfish:448 \
16    camellia:0 camellia:128 camellia:192 camellia:256; do
17	ealgo=${cipher%%:*}
18	keylen=${cipher##*:}
19	for secsize in 512 1024 2048 4096 8192; do
20		rnd=`mktemp /tmp/$base.XXXXXX` || exit 1
21		mdconfig -a -t malloc -s `expr $secsize \* $sectors`b -u $no || exit 1
22
23		geli onetime -e $ealgo -l $keylen -s $secsize md${no}
24
25		secs=`diskinfo /dev/md${no}.eli | awk '{print $4}'`
26
27		dd if=/dev/random of=${rnd} bs=${secsize} count=${secs} >/dev/null 2>&1
28		dd if=${rnd} of=/dev/md${no}.eli bs=${secsize} count=${secs} 2>/dev/null
29
30		md_rnd=`dd if=${rnd} bs=${secsize} count=${secs} 2>/dev/null | md5`
31		md_ddev=`dd if=/dev/md${no}.eli bs=${secsize} count=${secs} 2>/dev/null | md5`
32		md_edev=`dd if=/dev/md${no} bs=${secsize} count=${secs} 2>/dev/null | md5`
33
34		if [ ${md_rnd} = ${md_ddev} ]; then
35			echo "ok $i - ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
36		else
37			echo "not ok $i - ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
38		fi
39		i=$((i+1))
40		if [ ${md_rnd} != ${md_edev} ]; then
41			echo "ok $i - ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
42		else
43			echo "not ok $i - ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
44		fi
45		i=$((i+1))
46
47		geli detach md${no}
48		rm -f $rnd
49		mdconfig -d -u $no
50	done
51done
52