35 lines
1.4 KiB
Haskell
35 lines
1.4 KiB
Haskell
|
{-# LANGUAGE OverloadedStrings #-}
|
|||
|
module Tests.Writers.FB2 (tests) where
|
|||
|
|
|||
|
import Test.Tasty
|
|||
|
import Tests.Helpers
|
|||
|
import Text.Pandoc
|
|||
|
import Text.Pandoc.Arbitrary ()
|
|||
|
import Text.Pandoc.Builder
|
|||
|
|
|||
|
fb2 :: String -> String
|
|||
|
fb2 x = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" ++
|
|||
|
"<FictionBook xmlns=\"http://www.gribuser.ru/xml/fictionbook/2.0\" xmlns:l=\"http://www.w3.org/1999/xlink\"><description><title-info /><document-info><program-used>pandoc</program-used></document-info></description><body><title><p /></title><annotation><p></p></annotation><section>" ++ x ++ "</section></body></FictionBook>"
|
|||
|
|
|||
|
infix 4 =:
|
|||
|
(=:) :: (ToString a, ToPandoc a)
|
|||
|
=> String -> (a, String) -> TestTree
|
|||
|
(=:) = test (purely (writeFB2 def) . toPandoc)
|
|||
|
|
|||
|
tests :: [TestTree]
|
|||
|
tests = [ testGroup "block elements"
|
|||
|
["para" =: para "Lorem ipsum cetera."
|
|||
|
=?> fb2 "<p>Lorem ipsum cetera.</p>"
|
|||
|
]
|
|||
|
, testGroup "inlines"
|
|||
|
[
|
|||
|
"Emphasis" =: emph ("emphasized")
|
|||
|
=?> fb2 "<emphasis>emphasized</emphasis>"
|
|||
|
]
|
|||
|
, "bullet list" =: bulletList [ plain $ text "first"
|
|||
|
, plain $ text "second"
|
|||
|
, plain $ text "third"
|
|||
|
]
|
|||
|
=?> fb2 "<p>\x2022 first</p><p>\x2022 second</p><p>\x2022 third</p>"
|
|||
|
]
|