{-# OPTIONS_GHC -fno-warn-incomplete-patterns #-} {-# LANGUAGE OverloadedLists #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE ScopedTypeVariables #-} module HaskellWorks.Data.Bits.FromBitTextByteStringSpec (spec) where import qualified Data.ByteString as BS import qualified Data.Vector.Storable as DVS import Data.Word import HaskellWorks.Data.Bits.FromBitTextByteString import Test.Hspec {-# ANN module ("HLint: Ignore Redundant do" :: String) #-} spec :: Spec spec = describe "HaskellWorks.Data.Bits.FromBitTextByteStringSpec" $ do describe "For (DVS.Vector Word8)" $ do it "fromBitTextByteString (BS.unpack []) :: DVS.Vector Word8" $ let w = fromBitTextByteString (BS.pack []) ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [] it "fromBitTextByteString (BS.unpack \"0\") :: DVS.Vector Word8" $ let w = fromBitTextByteString "0" ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [0x0] it "fromBitTextByteString (BS.unpack \"1\") :: DVS.Vector Word8" $ let w = fromBitTextByteString "1" ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [0x1] it "fromBitTextByteString (BS.unpack \"11110000\") :: DVS.Vector Word8" $ let w = fromBitTextByteString "11110000" ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [0x0f] it "fromBitTextByteString (BS.unpack \"111100000\") :: DVS.Vector Word8" $ let w = fromBitTextByteString "111100000" ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [0x0f, 0x0] it "fromBitTextByteString (BS.unpack \"111100001\") :: DVS.Vector Word8" $ let w = fromBitTextByteString "111100001" ::DVS.Vector Word8 in w `shouldBe` DVS.fromList [0x0f, 0x1] describe "For (DVS.Vector Word16)" $ do it "fromBitTextByteString (BS.unpack []) :: DVS.Vector Word16" $ let w = fromBitTextByteString (BS.pack []) ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [] it "fromBitTextByteString (BS.unpack \"0\") :: DVS.Vector Word16" $ let w = fromBitTextByteString "0" ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [0x0] it "fromBitTextByteString (BS.unpack \"1\") :: DVS.Vector Word16" $ let w = fromBitTextByteString "1" ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [0x1] it "fromBitTextByteString (BS.unpack \"1111000011110000\") :: DVS.Vector Word16" $ let w = fromBitTextByteString "1111000011110000" ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [0x0f0f] it "fromBitTextByteString (BS.unpack \"11110000111100000\") :: DVS.Vector Word16" $ let w = fromBitTextByteString "11110000111100000" ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [0x0f0f, 0x0] it "fromBitTextByteString (BS.unpack \"11110000111100001\") :: DVS.Vector Word16" $ let w = fromBitTextByteString "11110000111100001" ::DVS.Vector Word16 in w `shouldBe` DVS.fromList [0x0f0f, 0x1] describe "For (DVS.Vector Word32)" $ do it "fromBitTextByteString (BS.unpack []) :: DVS.Vector Word32" $ let w = fromBitTextByteString (BS.pack []) ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [] it "fromBitTextByteString (BS.unpack \"0\") :: DVS.Vector Word32" $ let w = fromBitTextByteString "0" ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [0x0] it "fromBitTextByteString (BS.unpack \"1\") :: DVS.Vector Word32" $ let w = fromBitTextByteString "1" ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [0x1] it "fromBitTextByteString (BS.unpack \"11110000111100001111000011110000\") :: DVS.Vector Word32" $ let w = fromBitTextByteString "11110000111100001111000011110000" ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [0x0f0f0f0f] it "fromBitTextByteString (BS.unpack \"111100001111000011110000111100000\") :: DVS.Vector Word32" $ let w = fromBitTextByteString "111100001111000011110000111100000" ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [0x0f0f0f0f, 0x0] it "fromBitTextByteString (BS.unpack \"111100001111000011110000111100001\") :: DVS.Vector Word32" $ let w = fromBitTextByteString "111100001111000011110000111100001" ::DVS.Vector Word32 in w `shouldBe` DVS.fromList [0x0f0f0f0f, 0x1] describe "For (DVS.Vector Word64)" $ do it "fromBitTextByteString (BS.unpack []) :: DVS.Vector Word64" $ let w = fromBitTextByteString (BS.pack []) ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [] it "fromBitTextByteString (BS.unpack \"0\") :: DVS.Vector Word64" $ let w = fromBitTextByteString "0" ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [0x0] it "fromBitTextByteString (BS.unpack \"1\") :: DVS.Vector Word64" $ let w = fromBitTextByteString "1" ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [0x1] it "fromBitTextByteString (BS.unpack \"1111000011110000111100001111000011110000111100001111000011110000\") :: DVS.Vector Word64" $ let w = fromBitTextByteString "1111000011110000111100001111000011110000111100001111000011110000" ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [0x0f0f0f0f0f0f0f0f] it "fromBitTextByteString (BS.unpack \"11110000111100001111000011110000111100001111000011110000111100000\") :: DVS.Vector Word64" $ let w = fromBitTextByteString "11110000111100001111000011110000111100001111000011110000111100000" ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [0x0f0f0f0f0f0f0f0f, 0x0] it "fromBitTextByteString (BS.unpack \"11110000111100001111000011110000111100001111000011110000111100001\") :: DVS.Vector Word64" $ let w = fromBitTextByteString "11110000111100001111000011110000111100001111000011110000111100001" ::DVS.Vector Word64 in w `shouldBe` DVS.fromList [0x0f0f0f0f0f0f0f0f, 0x1]