2013-01-23 08:47:43 -08:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
2015-03-03 03:28:56 +02:00
|
|
|
{-# OPTIONS_GHC -fno-warn-name-shadowing #-}
|
2011-06-22 19:46:54 -07:00
|
|
|
module Tests.Writers.Markdown (tests) where
|
|
|
|
|
|
|
|
import Test.Framework
|
|
|
|
import Text.Pandoc.Builder
|
|
|
|
import Text.Pandoc
|
|
|
|
import Tests.Helpers
|
|
|
|
import Tests.Arbitrary()
|
|
|
|
|
2016-07-14 08:54:06 -07:00
|
|
|
markdown :: (ToPandoc a) => a -> String
|
2012-07-26 22:59:56 -07:00
|
|
|
markdown = writeMarkdown def . toPandoc
|
2011-06-22 19:46:54 -07:00
|
|
|
|
|
|
|
{-
|
|
|
|
"my test" =: X =?> Y
|
|
|
|
|
|
|
|
is shorthand for
|
|
|
|
|
|
|
|
test markdown "my test" $ X =?> Y
|
|
|
|
|
|
|
|
which is in turn shorthand for
|
|
|
|
|
|
|
|
test markdown "my test" (X,Y)
|
|
|
|
-}
|
|
|
|
|
2012-02-05 13:23:06 -08:00
|
|
|
infix 4 =:
|
2011-06-22 19:46:54 -07:00
|
|
|
(=:) :: (ToString a, ToPandoc a)
|
|
|
|
=> String -> (a, String) -> Test
|
|
|
|
(=:) = test markdown
|
|
|
|
|
|
|
|
tests :: [Test]
|
|
|
|
tests = [ "indented code after list"
|
2011-12-13 14:29:07 -08:00
|
|
|
=: (orderedList [ para "one" <> para "two" ] <> codeBlock "test")
|
2011-06-22 19:46:54 -07:00
|
|
|
=?> "1. one\n\n two\n\n<!-- -->\n\n test"
|
2013-11-30 17:59:28 -08:00
|
|
|
, "list with tight sublist"
|
|
|
|
=: bulletList [ plain "foo" <> bulletList [ plain "bar" ],
|
|
|
|
plain "baz" ]
|
|
|
|
=?> "- foo\n - bar\n- baz\n"
|
2015-03-03 03:28:56 +02:00
|
|
|
] ++ [shortcutLinkRefsTests]
|
|
|
|
|
|
|
|
shortcutLinkRefsTests :: Test
|
|
|
|
shortcutLinkRefsTests =
|
|
|
|
let infix 4 =:
|
|
|
|
(=:) :: (ToString a, ToPandoc a)
|
|
|
|
=> String -> (a, String) -> Test
|
|
|
|
(=:) = test (writeMarkdown (def {writerReferenceLinks = True}) . toPandoc)
|
|
|
|
in testGroup "Shortcut reference links"
|
|
|
|
[ "Simple link (shortcutable)"
|
|
|
|
=: (para (link "/url" "title" "foo"))
|
|
|
|
=?> "[foo]\n\n [foo]: /url \"title\""
|
|
|
|
, "Followed by another link (unshortcutable)"
|
|
|
|
=: (para ((link "/url1" "title1" "first")
|
|
|
|
<> (link "/url2" "title2" "second")))
|
|
|
|
=?> unlines [ "[first][][second]"
|
|
|
|
, ""
|
|
|
|
, " [first]: /url1 \"title1\""
|
|
|
|
, " [second]: /url2 \"title2\""
|
|
|
|
]
|
|
|
|
, "Followed by space and another link (unshortcutable)"
|
|
|
|
=: (para ((link "/url1" "title1" "first") <> " "
|
|
|
|
<> (link "/url2" "title2" "second")))
|
|
|
|
=?> unlines [ "[first][] [second]"
|
|
|
|
, ""
|
|
|
|
, " [first]: /url1 \"title1\""
|
|
|
|
, " [second]: /url2 \"title2\""
|
|
|
|
]
|
|
|
|
, "Reference link is used multiple times (unshortcutable)"
|
|
|
|
=: (para ((link "/url1" "" "foo") <> (link "/url2" "" "foo")
|
|
|
|
<> (link "/url3" "" "foo")))
|
|
|
|
=?> unlines [ "[foo][][foo][1][foo][2]"
|
|
|
|
, ""
|
|
|
|
, " [foo]: /url1"
|
|
|
|
, " [1]: /url2"
|
|
|
|
, " [2]: /url3"
|
|
|
|
]
|
|
|
|
, "Reference link is used multiple times (unshortcutable)"
|
|
|
|
=: (para ((link "/url1" "" "foo") <> " " <> (link "/url2" "" "foo")
|
|
|
|
<> " " <> (link "/url3" "" "foo")))
|
|
|
|
=?> unlines [ "[foo][] [foo][1] [foo][2]"
|
|
|
|
, ""
|
|
|
|
, " [foo]: /url1"
|
|
|
|
, " [1]: /url2"
|
|
|
|
, " [2]: /url3"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by text in brackets"
|
|
|
|
=: (para ((link "/url" "" "link") <> "[text in brackets]"))
|
2015-04-18 10:45:46 -07:00
|
|
|
=?> unlines [ "[link][]\\[text in brackets\\]"
|
2015-03-03 03:28:56 +02:00
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by space and text in brackets"
|
|
|
|
=: (para ((link "/url" "" "link") <> " [text in brackets]"))
|
2015-04-18 10:45:46 -07:00
|
|
|
=?> unlines [ "[link][] \\[text in brackets\\]"
|
2015-03-03 03:28:56 +02:00
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by RawInline"
|
|
|
|
=: (para ((link "/url" "" "link") <> rawInline "markdown" "[rawText]"))
|
|
|
|
=?> unlines [ "[link][][rawText]"
|
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by space and RawInline"
|
|
|
|
=: (para ((link "/url" "" "link") <> space <> rawInline "markdown" "[rawText]"))
|
|
|
|
=?> unlines [ "[link][] [rawText]"
|
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by RawInline with space"
|
|
|
|
=: (para ((link "/url" "" "link") <> rawInline "markdown" " [rawText]"))
|
|
|
|
=?> unlines [ "[link][] [rawText]"
|
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by citation"
|
|
|
|
=: (para ((link "/url" "" "link") <> cite [Citation "author" [] [] NormalCitation 0 0] (str "[@author]")))
|
|
|
|
=?> unlines [ "[link][][@author]"
|
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
, "Reference link is followed by space and citation"
|
|
|
|
=: (para ((link "/url" "" "link") <> space <> cite [Citation "author" [] [] NormalCitation 0 0] (str "[@author]")))
|
|
|
|
=?> unlines [ "[link][] [@author]"
|
|
|
|
, ""
|
|
|
|
, " [link]: /url"
|
|
|
|
]
|
|
|
|
]
|