pandoc/test/Tests/Readers/Man.hs

146 lines
4.5 KiB
Haskell
Raw Normal View History

2018-02-25 01:34:17 +01:00
{-# LANGUAGE OverloadedStrings #-}
{- |
Module : Tests.Readers.Man
Copyright : © 2018-2019 Yan Pas <yanp.bugz@gmail.com>,
2022-01-01 20:02:31 +01:00
2018-2022 John MacFarlane
License : GNU GPL, version 2 or above
Maintainer : John MacFarlane <jgm@berkeley.edu>
Stability : alpha
Portability : portable
Tests for the Man reader.
-}
2018-02-25 01:34:17 +01:00
module Tests.Readers.Man (tests) where
import Data.Text (Text)
import Test.Tasty
import Test.Tasty.HUnit (HasCallStack)
2018-02-25 01:34:17 +01:00
import Tests.Helpers
import Text.Pandoc
import Text.Pandoc.Arbitrary ()
import Text.Pandoc.Builder
2018-05-09 02:24:45 +02:00
import Text.Pandoc.Readers.Man
2018-02-25 01:34:17 +01:00
2018-05-09 02:24:45 +02:00
man :: Text -> Pandoc
man = purely $ readMan def
infix 4 =:
(=:) :: (ToString c, HasCallStack)
2018-05-09 02:24:45 +02:00
=> String -> (Text, c) -> TestTree
(=:) = test man
2018-02-25 01:34:17 +01:00
toRow :: [Blocks] -> Row
toRow = Row nullAttr . map simpleCell
2018-02-25 01:34:17 +01:00
tests :: [TestTree]
2018-05-09 02:24:45 +02:00
tests = [
-- .SH "HEllo bbb" "aaa"" as"
testGroup "Macros" [
2018-10-13 23:57:15 +02:00
"Bold" =:
".B foo"
=?> para (strong "foo")
2018-10-13 23:57:15 +02:00
, "Italic" =:
".I bar\n"
=?> para (emph "bar")
2018-10-13 23:57:15 +02:00
, "BoldItalic" =:
".BI foo bar"
=?> para (strong (str "foo") <> emph (str "bar"))
2018-10-13 23:57:15 +02:00
, "H1" =:
".SH The header\n"
=?> header 1 (text "The header")
2018-10-13 23:57:15 +02:00
, "H2" =:
".SS \"The header 2\""
=?> header 2 (text "The header 2")
2018-10-13 23:57:15 +02:00
, "Macro args" =:
".B \"single arg with \"\"Q\"\"\""
=?>para (strong $ text "single arg with \"Q\"")
2018-10-21 01:40:44 +02:00
, "Argument from next line" =:
".B\nsingle arg with \"Q\""
=?>para (strong $ text "single arg with \"Q\"")
2018-10-13 23:57:15 +02:00
, "comment" =:
".\\\"bla\naaa"
=?>para (str "aaa")
2018-10-13 23:57:15 +02:00
, "link" =:
".BR aa (1)"
2018-10-21 01:40:44 +02:00
=?> para (strong (str "aa") <> str "(1)")
2018-10-13 23:57:15 +02:00
],
testGroup "Escapes" [
"fonts" =:
"aa\\fIbb\\fRcc"
=?>para (str "aa" <> emph (str "bb") <> str "cc")
, "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-13 23:57:15 +02:00
, "skip" =:
"a\\%\\\n\\:b\\0"
=?>para (str "ab\8199")
2018-10-13 23:57:15 +02:00
, "replace" =:
"\\-\\ \\\\\\[lq]\\[rq]\\[em]\\[en]\\*(lq\\*(rq"
=?>para (text "- \\“”—–“”")
2018-10-13 23:57:15 +02:00
, "replace2" =:
"\\t\\e\\`\\^\\|\\'" =?>para (text "\\`\8202\8198'")
, "comment with \\\"" =:
"Foo \\\" bar\n" =?>para (text "Foo")
, "comment with \\#" =:
"Foo\\#\nbar\n" =?>para (text "Foobar")
, "two letter escapes" =:
"\\(oA\\(~O" =?>para (text "ÅÕ")
, "bracketed escapes" =:
"\\[oA]\\[~O]\\[Do]\\[Ye]\\[product]\\[ul]" =?>para (text "ÅÕ$¥∏_")
, "unicode escapes" =:
"\\[u2020]" =?>para (text "")
, "unicode escapes (combined)" =:
"\\[u0075_u0301]" =?>para (text "\250")
, "unknown escape (#5034)" =:
"\\9" =?>para (text "9")
2018-10-13 23:57:15 +02:00
],
testGroup "Lists" [
"bullet" =:
".IP \"\\[bu]\"\nfirst\n.IP \"\\[bu]\"\nsecond"
=?> bulletList [para $ str "first", para $ str "second"]
2018-10-19 08:53:33 +02:00
, "ordered" =:
".IP 2 a\nfirst\n.IP 3 a\nsecond"
=?> orderedListWith (2,Decimal,DefaultDelim) [para $ str "first", para $ str "second"]
2018-10-13 23:57:15 +02:00
, "upper" =:
".IP A) a\nfirst\n.IP B) a\nsecond"
=?> orderedListWith (1,UpperAlpha,OneParen) [para $ str "first", para $ str "second"]
2018-10-13 23:57:15 +02:00
, "nested" =:
".IP \"\\[bu]\"\nfirst\n.RS\n.IP \"\\[bu]\"\n1a\n.IP \"\\[bu]\"\n1b\n.RE"
=?> bulletList [para (str "first") <> bulletList [para $ str "1a", para $ str "1b"]]
, "change in list style" =:
".IP \\[bu]\nfirst\n.IP 1\nsecond"
=?> bulletList [para (str "first")] <>
orderedListWith (1,Decimal,DefaultDelim) [para (str "second")]
2018-10-13 23:57:15 +02:00
],
testGroup "CodeBlocks" [
"cb1"=:
".nf\naa\n\tbb\n.fi"
=?> codeBlock "aa\n\tbb"
2018-11-02 22:26:12 +01:00
],
testGroup "Tables" [
"t1" =:
".TS\nallbox;\nl l l.\na\tb\tc\nd\te\tf\n.TE"
=?> table
emptyCaption
(replicate 3 (AlignLeft, ColWidthDefault))
(TableHead nullAttr [])
[TableBody nullAttr 0 [] $ map toRow
[map (plain . str ) ["a", "b", "c"],
map (plain . str ) ["d", "e", "f"]]]
(TableFoot nullAttr []),
2018-11-02 22:26:12 +01:00
"longcell" =:
".TS\n;\nr.\nT{\na\nb\nc d\nT}\nf\n.TE"
=?> table
emptyCaption
[(AlignRight, ColWidthDefault)]
(TableHead nullAttr [])
[TableBody nullAttr 0 [] $ map toRow [[plain $ text "a b c d"], [plain $ str "f"]]]
(TableFoot nullAttr [])
2018-10-13 23:57:15 +02:00
]
2018-05-09 02:24:45 +02:00
]