From 9435083465a487553b21c599c1340aa5e5ed8a1c Mon Sep 17 00:00:00 2001 From: Gregor Kleen Date: Mon, 18 Jan 2016 11:39:51 +0000 Subject: First tests for Printout.BBCode --- spec/test/Thermoprint/Printout/BBCodeSpec.hs | 42 ++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 spec/test/Thermoprint/Printout/BBCodeSpec.hs (limited to 'spec') diff --git a/spec/test/Thermoprint/Printout/BBCodeSpec.hs b/spec/test/Thermoprint/Printout/BBCodeSpec.hs new file mode 100644 index 0000000..f3f1840 --- /dev/null +++ b/spec/test/Thermoprint/Printout/BBCodeSpec.hs @@ -0,0 +1,42 @@ +{-# LANGUAGE OverloadedStrings, OverloadedLists #-} +{-# LANGUAGE StandaloneDeriving #-} + +module Thermoprint.Printout.BBCodeSpec (spec) where + +import Test.Hspec +import Test.Hspec.QuickCheck (prop) +import Test.QuickCheck.Instances + +import Thermoprint.Printout.BBCode +import Thermoprint.Printout + +import Data.Text (Text) + +import Control.Monad (zipWithM_) +import Data.Monoid ((<>)) +import Data.Function (on) + +import qualified Data.Sequence as Seq (fromList) + +instance Eq Block where + (==) = (==) `on` cotext +deriving instance Eq Chunk + +spec :: Spec +spec = do + zipWithM_ example [1..] examples + where + example n (s, ts) = let str = "Example " <> show n + in specify str $ bbcode s == (pOut <$> ts) + +pOut :: [Block] -> Printout +pOut = pure . Seq.fromList . map Cooked + +examples :: [(Text, Either BBCodeError [Block])] +examples = [ ("Hello World!" + , Right [Line (JuxtaPos [word "Hello", HSpace 1, word "World!"])]) + , ("Hello [hspace width=2/] World!" + , Right [Line (JuxtaPos [word "Hello", HSpace 4, word "World!"])]) + ] + where + word = (\(Right l) -> l) . text -- cgit v1.2.3