ripemd160

Pure Haskell RIPEMD-160, HMAC-RIPEMD160 (docs.ppad.tech/ripemd160).
git clone git://git.ppad.tech/ripemd160.git
Log | Files | Refs | README | LICENSE

commit 8c974a227235135075ae1435dac6d6f3c6e745f1
parent dd90925d5ed246f29a299f2f2b6f47b04342358c
Author: Jared Tobin <jared@jtobin.io>
Date:   Tue, 12 Nov 2024 12:17:43 +0400

test: suite

Diffstat:
Mtest/Main.hs | 183++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 182 insertions(+), 1 deletion(-)

diff --git a/test/Main.hs b/test/Main.hs @@ -1,5 +1,186 @@ +{-# LANGUAGE OverloadedStrings #-} +{-# LANGUAGE ViewPatterns #-} module Main where +import qualified Crypto.Hash.RIPEMD160 as RIPEMD160 +import qualified Data.ByteString as BS +import qualified Data.ByteString.Lazy as BL +import qualified Data.ByteString.Base16 as B16 +import Test.Tasty +import Test.Tasty.HUnit + main :: IO () -main = pure () +main = defaultMain $ testGroup "ppad-ripemd160" [ + unit_tests + ] + +unit_tests :: TestTree +unit_tests = testGroup "unit tests" [ + testGroup "hash" [ + cmp_hash "hv0" hv0_put hv0_pec + , cmp_hash "hv1" hv1_put hv1_pec + , cmp_hash "hv2" hv2_put hv2_pec + , cmp_hash "hv3" hv3_put hv3_pec + , cmp_hash "hv4" hv4_put hv4_pec + , cmp_hash "hv5" hv5_put hv5_pec + , cmp_hash "hv6" hv6_put hv6_pec + , cmp_hash "hv7" hv7_put hv7_pec + , cmp_hash "hv8" hv8_put hv8_pec + ] + , testGroup "hash_lazy" [ + cmp_hash_lazy "hv0" hv0_put hv0_pec + , cmp_hash_lazy "hv1" hv1_put hv1_pec + , cmp_hash_lazy "hv2" hv2_put hv2_pec + , cmp_hash_lazy "hv3" hv3_put hv3_pec + , cmp_hash_lazy "hv4" hv4_put hv4_pec + , cmp_hash_lazy "hv5" hv5_put hv5_pec + , cmp_hash_lazy "hv6" hv6_put hv6_pec + , cmp_hash_lazy "hv7" hv7_put hv7_pec + , cmp_hash_lazy "hv8" hv8_put hv8_pec + ] + , testGroup "hmac" [ + cmp_hmac "hmv1" hmv1_key hmv1_put hmv1_pec + , cmp_hmac "hmv2" hmv2_key hmv2_put hmv2_pec + , cmp_hmac "hmv3" hmv3_key hmv3_put hmv3_pec + , cmp_hmac "hmv4" hmv4_key hmv4_put hmv4_pec + , cmp_hmac "hmv5" hmv5_key hmv5_put hmv5_pec + , cmp_hmac "hmv6" hmv6_key hmv6_put hmv6_pec + , cmp_hmac "hmv7" hmv7_key hmv7_put hmv7_pec + ] + , testGroup "hmac_lazy" [ + cmp_hmac_lazy "hmv1" hmv1_key hmv1_put hmv1_pec + , cmp_hmac_lazy "hmv2" hmv2_key hmv2_put hmv2_pec + , cmp_hmac_lazy "hmv3" hmv3_key hmv3_put hmv3_pec + , cmp_hmac_lazy "hmv4" hmv4_key hmv4_put hmv4_pec + , cmp_hmac_lazy "hmv5" hmv5_key hmv5_put hmv5_pec + , cmp_hmac_lazy "hmv6" hmv6_key hmv6_put hmv6_pec + , cmp_hmac_lazy "hmv7" hmv7_key hmv7_put hmv7_pec + ] + ] + +cmp_hash :: String -> BS.ByteString -> BS.ByteString -> TestTree +cmp_hash msg put pec = testCase msg $ do + let out = B16.encode (RIPEMD160.hash put) + assertEqual mempty pec out + +cmp_hash_lazy :: String -> BS.ByteString -> BS.ByteString -> TestTree +cmp_hash_lazy msg (BL.fromStrict -> put) pec = testCase msg $ do + let out = B16.encode (RIPEMD160.hash_lazy put) + assertEqual mempty pec out + +hv0_put, hv0_pec :: BS.ByteString +hv0_put = mempty +hv0_pec = "9c1185a5c5e9fc54612808977ee8f548b2258d31" + +hv1_put, hv1_pec :: BS.ByteString +hv1_put = "a" +hv1_pec = "0bdc9d2d256b3ee9daae347be6f4dc835a467ffe" + +hv2_put, hv2_pec :: BS.ByteString +hv2_put = "abc" +hv2_pec = "8eb208f7e05d987a9b044a8e98c6b087f15a0bfc" + +hv3_put, hv3_pec :: BS.ByteString +hv3_put = "message digest" +hv3_pec = "5d0689ef49d2fae572b881b123a85ffa21595f36" + +hv4_put, hv4_pec :: BS.ByteString +hv4_put = "abcdefghijklmnopqrstuvwxyz" +hv4_pec = "f71c27109c692c1b56bbdceb5b9d2865b3708dbc" + +hv5_put, hv5_pec :: BS.ByteString +hv5_put = "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq" +hv5_pec = "12a053384a9c0c88e405a06c27dcf49ada62eb2b" + +hv6_put, hv6_pec :: BS.ByteString +hv6_put = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" +hv6_pec = "b0e20b6e3116640286ed3a87a5713079b21f5189" + +hv7_put, hv7_pec :: BS.ByteString +hv7_put = "12345678901234567890123456789012345678901234567890123456789012345678901234567890" +hv7_pec = "9b752e45573d4b39f4dbd3323cab82bf63326bfb" + +hv8_put, hv8_pec :: BS.ByteString +hv8_put = BS.replicate 1000000 0x61 +hv8_pec = "52783243c1697bdbe16d37f97f68f08325dc1528" + +-- vectors from +-- +-- https://www.rfc-editor.org/rfc/rfc2286.html#section-2 + +cmp_hmac + :: String -> BS.ByteString -> BS.ByteString -> BS.ByteString -> TestTree +cmp_hmac msg key put pec = testCase msg $ do + let out = B16.encode (RIPEMD160.hmac key put) + assertEqual mempty pec out + +cmp_hmac_lazy + :: String -> BS.ByteString -> BS.ByteString -> BS.ByteString -> TestTree +cmp_hmac_lazy msg key (BL.fromStrict -> put) pec = testCase msg $ do + let out = B16.encode (RIPEMD160.hmac_lazy key put) + assertEqual mempty pec out + +hmv1_key :: BS.ByteString +hmv1_key = B16.decodeLenient "0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b" + +hmv1_put :: BS.ByteString +hmv1_put = "Hi There" + +hmv1_pec :: BS.ByteString +hmv1_pec = "24cb4bd67d20fc1a5d2ed7732dcc39377f0a5668" + +hmv2_key :: BS.ByteString +hmv2_key = "Jefe" + +hmv2_put :: BS.ByteString +hmv2_put = "what do ya want for nothing?" + +hmv2_pec :: BS.ByteString +hmv2_pec = "dda6c0213a485a9e24f4742064a7f033b43c4069" + +hmv3_key :: BS.ByteString +hmv3_key = B16.decodeLenient "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + +hmv3_put :: BS.ByteString +hmv3_put = B16.decodeLenient "dddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd" + +hmv3_pec :: BS.ByteString +hmv3_pec = "b0b105360de759960ab4f35298e116e295d8e7c1" + +hmv4_key :: BS.ByteString +hmv4_key = B16.decodeLenient "0102030405060708090a0b0c0d0e0f10111213141516171819" + +hmv4_put :: BS.ByteString +hmv4_put = B16.decodeLenient "cdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcd" + +hmv4_pec :: BS.ByteString +hmv4_pec = "d5ca862f4d21d5e610e18b4cf1beb97a4365ecf4" + +hmv5_key :: BS.ByteString +hmv5_key = B16.decodeLenient "0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c" + +hmv5_put :: BS.ByteString +hmv5_put = "Test With Truncation" + +hmv5_pec :: BS.ByteString +hmv5_pec = "7619693978f91d90539ae786500ff3d8e0518e39" + +hmv6_key :: BS.ByteString +hmv6_key = B16.decodeLenient "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + +hmv6_put :: BS.ByteString +hmv6_put = "Test Using Larger Than Block-Size Key - Hash Key First" + +hmv6_pec :: BS.ByteString +hmv6_pec = "6466ca07ac5eac29e1bd523e5ada7605b791fd8b" + +hmv7_key :: BS.ByteString +hmv7_key = hmv6_key + +hmv7_put :: BS.ByteString +hmv7_put = "Test Using Larger Than Block-Size Key and Larger Than One Block-Size Data" + +hmv7_pec :: BS.ByteString +hmv7_pec = "69ea60798d71616cce5fd0871e23754cd75d5a0a" +