-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathQuickTest.hs
62 lines (51 loc) · 1.84 KB
/
QuickTest.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
{-# LANGUAGE TypeSynonymInstances, FlexibleInstances #-}
module Main where
import Codec.Utils
import Codec.Encryption.Blowfish as Blowfish
import Codec.Encryption.AES as AES
import Codec.Encryption.Modes
import Codec.Encryption.Padding
import Data.LargeWord
import Data.Word
import Data.Bits
import Numeric
import Data.Char
import Test.QuickCheck
instance Arbitrary Word128 where
arbitrary =
do n <- choose ((fromIntegral (minBound::Word128))::Integer,
(fromIntegral (maxBound::Word128))::Integer)
return (fromIntegral n)
prop_decryptEncrypt k b = b == Blowfish.decrypt k (Blowfish.encrypt k b)
where types = (k :: Word8, b :: Word64)
prop_AESIdempotent k b = b == AES.decrypt k (AES.encrypt k b)
where types = (k :: Word128, b :: Word128)
prop_unCbcCbc iv k bs =
bs == (unPkcs5 $ unCbc Blowfish.decrypt iv k $ cbc Blowfish.encrypt iv k $ pkcs5 bs)
where types =(k :: Word8, iv :: Word64, bs :: [Octet])
prop_unPkcs5Pkcs5 os =
os == (unPkcs5 $ ((pkcs5 os)::[Word64]))
where types = (os :: [Octet])
prop_unNullsNulls os =
all (/=0) os ==>
os == (unPadNulls $ ((padNulls os)::[Word64]))
where types = (os :: [Octet])
prop_fromOctetsToOctets k n =
k >= 0 && n > 1 ==>
k == (fromOctets n $ toOctets n k)
where types = (k :: Int, n :: Word8)
prop_unTwosCompTwosComp n =
n < (0) ==>
collect n $
forAll g $
\n -> n == (fromTwosComp $ toTwosComp n)
where types = (n::Int)
g = do n <- choose (minBound::Int,maxBound::Int)
return (13*n)
main = do quickCheck prop_decryptEncrypt
quickCheck prop_AESIdempotent
quickCheck prop_unCbcCbc
quickCheck prop_unPkcs5Pkcs5
quickCheck prop_unNullsNulls
quickCheck prop_fromOctetsToOctets
quickCheck prop_unTwosCompTwosComp