2018-02-25 03:34:17 +03:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
|
|
module Tests.Readers.Man (tests) where
|
|
|
|
|
2018-05-09 20:40:37 +03:00
|
|
|
import Prelude
|
2018-02-25 03:34:17 +03:00
|
|
|
import Data.Text (Text)
|
|
|
|
import Test.Tasty
|
|
|
|
import Tests.Helpers
|
|
|
|
import Text.Pandoc
|
|
|
|
import Text.Pandoc.Arbitrary ()
|
|
|
|
import Text.Pandoc.Builder
|
2018-05-09 03:24:45 +03:00
|
|
|
import Text.Pandoc.Readers.Man
|
2018-02-25 03:34:17 +03:00
|
|
|
|
2018-05-09 03:24:45 +03:00
|
|
|
man :: Text -> Pandoc
|
|
|
|
man = purely $ readMan def
|
|
|
|
|
|
|
|
infix 4 =:
|
|
|
|
(=:) :: ToString c
|
|
|
|
=> String -> (Text, c) -> TestTree
|
|
|
|
(=:) = test man
|
2018-02-25 03:34:17 +03:00
|
|
|
|
|
|
|
tests :: [TestTree]
|
2018-05-09 03:24:45 +03:00
|
|
|
tests = [
|
|
|
|
-- .SH "HEllo bbb" "aaa"" as"
|
|
|
|
testGroup "Macros" [
|
2018-10-14 00:57:15 +03:00
|
|
|
"Bold" =:
|
|
|
|
".B foo"
|
2018-10-20 15:57:34 -07:00
|
|
|
=?> para (strong "foo")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "Italic" =:
|
|
|
|
".I bar\n"
|
2018-10-20 15:57:34 -07:00
|
|
|
=?> para (emph "bar")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "BoldItalic" =:
|
|
|
|
".BI foo bar"
|
2018-10-20 15:57:34 -07:00
|
|
|
=?> para (strong (str "foo") <> emph (str "bar"))
|
2018-10-14 00:57:15 +03:00
|
|
|
, "H1" =:
|
|
|
|
".SH The header\n"
|
2018-10-19 23:27:04 -07:00
|
|
|
=?> header 1 (text "The header")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "H2" =:
|
|
|
|
".SS \"The header 2\""
|
2018-10-19 23:27:04 -07:00
|
|
|
=?> header 2 (text "The header 2")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "Macro args" =:
|
|
|
|
".B \"single arg with \"\"Q\"\"\""
|
2018-10-19 14:59:11 -07:00
|
|
|
=?> (para $ strong $ text "single arg with \"Q\"")
|
2018-10-20 16:40:44 -07:00
|
|
|
, "Argument from next line" =:
|
|
|
|
".B\nsingle arg with \"Q\""
|
|
|
|
=?> (para $ strong $ text "single arg with \"Q\"")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "comment" =:
|
|
|
|
".\\\"bla\naaa"
|
2018-10-19 15:16:05 -07:00
|
|
|
=?> (para $ str "aaa")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "link" =:
|
|
|
|
".BR aa (1)"
|
2018-10-20 16:40:44 -07:00
|
|
|
=?> para (strong (str "aa") <> str "(1)")
|
2018-10-14 00:57:15 +03:00
|
|
|
],
|
|
|
|
testGroup "Escapes" [
|
|
|
|
"fonts" =:
|
|
|
|
"aa\\fIbb\\fRcc"
|
|
|
|
=?> (para $ str "aa" <> (emph $ str "bb") <> str "cc")
|
2018-10-20 22:40:49 -07:00
|
|
|
, "nested fonts" =:
|
|
|
|
"\\f[BI]hi\\f[I] there\\f[R]"
|
|
|
|
=?> para (emph (strong (text "hi") <> text " there"))
|
|
|
|
, "nested fonts 2" =:
|
|
|
|
"\\f[R]hi \\f[I]there \\f[BI]bold\\f[R] ok"
|
|
|
|
=?> para (text "hi " <> emph (text "there " <> strong (text "bold")) <>
|
|
|
|
text " ok")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "skip" =:
|
|
|
|
"a\\%\\{\\}\\\n\\:b\\0"
|
2018-10-16 03:12:06 +03:00
|
|
|
=?> (para $ str "ab")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "replace" =:
|
|
|
|
"\\-\\ \\\\\\[lq]\\[rq]\\[em]\\[en]\\*(lq\\*(rq"
|
2018-10-19 14:59:11 -07:00
|
|
|
=?> (para $ text "- \\“”—–“”")
|
2018-10-14 00:57:15 +03:00
|
|
|
, "replace2" =:
|
2018-10-19 15:36:43 -07:00
|
|
|
"\\t\\e\\`\\^\\|\\'" =?> (para $ text "\\` `")
|
2018-10-19 15:16:05 -07:00
|
|
|
, "comment with \\\"" =:
|
2018-10-19 15:36:43 -07:00
|
|
|
"Foo \\\" bar\n" =?> (para $ text "Foo")
|
2018-10-19 15:16:05 -07:00
|
|
|
, "comment with \\#" =:
|
2018-10-19 15:36:43 -07:00
|
|
|
"Foo\\#\nbar\n" =?> (para $ text "Foobar")
|
|
|
|
, "two letter escapes" =:
|
|
|
|
"\\(oA\\(~O" =?> (para $ text "ÅÕ")
|
|
|
|
, "bracketed escapes" =:
|
|
|
|
"\\[oA]\\[~O]\\[Do]\\[Ye]\\[product]" =?> (para $ text "ÅÕ$¥∏")
|
|
|
|
, "unicode escapes" =:
|
|
|
|
"\\[u2020]" =?> (para $ text "†")
|
|
|
|
, "unicode escapes (combined)" =:
|
|
|
|
"\\[u0075_u0301]" =?> (para $ text "ú")
|
2018-10-14 00:57:15 +03:00
|
|
|
],
|
|
|
|
testGroup "Lists" [
|
|
|
|
"bullet" =:
|
2018-10-20 09:30:06 -07:00
|
|
|
".IP \"\\[bu]\"\nfirst\n.IP \"\\[bu]\"\nsecond"
|
2018-10-19 22:54:05 -07:00
|
|
|
=?> bulletList [para $ str "first", para $ str "second"]
|
2018-10-18 23:53:33 -07:00
|
|
|
, "ordered" =:
|
2018-10-20 09:30:06 -07:00
|
|
|
".IP 2 a\nfirst\n.IP 3 a\nsecond"
|
|
|
|
=?> orderedListWith (2,Decimal,DefaultDelim) [para $ str "first", para $ str "second"]
|
2018-10-14 00:57:15 +03:00
|
|
|
, "upper" =:
|
2018-10-20 09:30:06 -07:00
|
|
|
".IP A) a\nfirst\n.IP B) a\nsecond"
|
|
|
|
=?> orderedListWith (1,UpperAlpha,OneParen) [para $ str "first", para $ str "second"]
|
2018-10-14 00:57:15 +03:00
|
|
|
, "nested" =:
|
2018-10-20 09:30:06 -07:00
|
|
|
".IP \"\\[bu]\"\nfirst\n.RS\n.IP \"\\[bu]\"\n1a\n.IP \"\\[bu]\"\n1b\n.RE"
|
2018-10-19 22:54:05 -07:00
|
|
|
=?> bulletList [(para $ str "first") <> (bulletList [para $ str "1a", para $ str "1b"])]
|
2018-10-20 09:30:06 -07:00
|
|
|
, "change in list style" =:
|
|
|
|
".IP \\[bu]\nfirst\n.IP 1\nsecond"
|
|
|
|
=?> bulletList [para (str "first")] <>
|
|
|
|
orderedListWith (1,Decimal,DefaultDelim) [para (str "second")]
|
2018-10-14 00:57:15 +03:00
|
|
|
],
|
|
|
|
testGroup "CodeBlocks" [
|
|
|
|
"cb1"=:
|
|
|
|
".nf\naa\n\tbb\n.fi"
|
|
|
|
=?> codeBlock "aa\n\tbb"
|
|
|
|
]
|
2018-05-09 03:24:45 +03:00
|
|
|
]
|