2013-01-23 17:47:43 +01:00
|
|
|
{-# LANGUAGE TypeSynonymInstances, FlexibleInstances #-}
|
2011-01-13 20:11:55 +01:00
|
|
|
-- Utility functions for the test suite.
|
|
|
|
|
2013-01-23 17:47:43 +01:00
|
|
|
module Tests.Helpers ( test
|
2011-01-22 21:18:59 +01:00
|
|
|
, (=?>)
|
2016-11-27 11:52:42 +01:00
|
|
|
, purely
|
2011-01-22 21:18:59 +01:00
|
|
|
, property
|
|
|
|
, ToString(..)
|
|
|
|
, ToPandoc(..)
|
|
|
|
)
|
|
|
|
where
|
2011-01-12 14:16:35 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
import Text.Pandoc.Definition
|
|
|
|
import Text.Pandoc.Builder (Inlines, Blocks, doc, plain)
|
2016-11-27 11:52:42 +01:00
|
|
|
import Text.Pandoc.Class
|
2011-01-12 14:16:35 +01:00
|
|
|
import Test.Framework
|
|
|
|
import Test.Framework.Providers.HUnit
|
2011-01-22 21:18:59 +01:00
|
|
|
import Test.Framework.Providers.QuickCheck2
|
|
|
|
import Test.HUnit (assertBool)
|
2016-12-11 22:09:33 +01:00
|
|
|
import Text.Pandoc.Shared (trimr)
|
2012-07-27 07:59:56 +02:00
|
|
|
import Text.Pandoc.Options
|
2011-01-22 05:50:18 +01:00
|
|
|
import Text.Pandoc.Writers.Native (writeNative)
|
2011-01-22 21:18:59 +01:00
|
|
|
import qualified Test.QuickCheck.Property as QP
|
2011-01-22 23:58:32 +01:00
|
|
|
import Data.Algorithm.Diff
|
2013-05-11 07:53:35 +02:00
|
|
|
import qualified Data.Map as M
|
2011-01-12 14:16:35 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
test :: (ToString a, ToString b, ToString c)
|
|
|
|
=> (a -> b) -- ^ function to test
|
|
|
|
-> String -- ^ name of test case
|
|
|
|
-> (a, c) -- ^ (input, expected value)
|
|
|
|
-> Test
|
|
|
|
test fn name (input, expected) =
|
|
|
|
testCase name $ assertBool msg (actual' == expected')
|
2011-01-22 23:58:32 +01:00
|
|
|
where msg = nl ++ dashes "input" ++ nl ++ input' ++ nl ++
|
2013-01-12 19:21:07 +01:00
|
|
|
dashes "result" ++ nl ++
|
|
|
|
unlines (map vividize diff) ++
|
2011-01-22 05:50:18 +01:00
|
|
|
dashes ""
|
2011-01-22 23:58:32 +01:00
|
|
|
nl = "\n"
|
2011-01-22 05:50:18 +01:00
|
|
|
input' = toString input
|
2013-01-12 19:21:07 +01:00
|
|
|
actual' = lines $ toString $ fn input
|
|
|
|
expected' = lines $ toString expected
|
|
|
|
diff = getDiff expected' actual'
|
2011-01-22 23:58:32 +01:00
|
|
|
dashes "" = replicate 72 '-'
|
|
|
|
dashes x = replicate (72 - length x - 5) '-' ++ " " ++ x ++ " ---"
|
|
|
|
|
2013-01-02 20:41:22 +01:00
|
|
|
vividize :: Diff String -> String
|
2013-01-12 19:21:07 +01:00
|
|
|
vividize (Both s _) = " " ++ s
|
|
|
|
vividize (First s) = "- " ++ s
|
|
|
|
vividize (Second s) = "+ " ++ s
|
2011-01-21 19:23:41 +01:00
|
|
|
|
2011-01-22 21:18:59 +01:00
|
|
|
property :: QP.Testable a => TestName -> a -> Test
|
|
|
|
property = testProperty
|
|
|
|
|
2016-11-27 11:52:42 +01:00
|
|
|
purely :: (b -> PandocPure a) -> b -> a
|
|
|
|
purely f = either (error . show) id . runPure . f
|
|
|
|
|
2012-02-05 22:23:06 +01:00
|
|
|
infix 5 =?>
|
2011-01-22 05:50:18 +01:00
|
|
|
(=?>) :: a -> b -> (a,b)
|
|
|
|
x =?> y = (x, y)
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
class ToString a where
|
|
|
|
toString :: a -> String
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
instance ToString Pandoc where
|
2016-11-27 11:52:42 +01:00
|
|
|
toString d = purely (writeNative def{ writerTemplate = s }) $ toPandoc d
|
2011-01-22 05:50:18 +01:00
|
|
|
where s = case d of
|
2013-05-11 07:53:35 +02:00
|
|
|
(Pandoc (Meta m) _)
|
2016-11-30 15:34:58 +01:00
|
|
|
| M.null m -> Nothing
|
|
|
|
| otherwise -> Just "" -- need this to get meta output
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
instance ToString Blocks where
|
2016-11-27 11:52:42 +01:00
|
|
|
toString = purely (writeNative def) . toPandoc
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
instance ToString Inlines where
|
2016-11-27 11:52:42 +01:00
|
|
|
toString = trimr . purely (writeNative def) . toPandoc
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
instance ToString String where
|
|
|
|
toString = id
|
2011-01-19 08:34:34 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
class ToPandoc a where
|
|
|
|
toPandoc :: a -> Pandoc
|
2011-01-12 14:16:35 +01:00
|
|
|
|
2011-01-22 05:50:18 +01:00
|
|
|
instance ToPandoc Pandoc where
|
2016-12-11 22:09:33 +01:00
|
|
|
toPandoc = id
|
2011-01-22 05:50:18 +01:00
|
|
|
|
|
|
|
instance ToPandoc Blocks where
|
2016-12-11 22:09:33 +01:00
|
|
|
toPandoc = doc
|
2011-01-22 05:50:18 +01:00
|
|
|
|
|
|
|
instance ToPandoc Inlines where
|
2016-12-11 22:09:33 +01:00
|
|
|
toPandoc = doc . plain
|