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
|
2016-10-14 08:45:36 -04:00
|
|
|
import Text.Pandoc.Arbitrary()
|
2011-06-22 19:46:54 -07:00
|
|
|
|
2017-01-15 20:42:00 +01:00
|
|
|
defopts :: WriterOptions
|
|
|
|
defopts = def{ writerExtensions = pandocExtensions }
|
|
|
|
|
2016-07-14 08:54:06 -07:00
|
|
|
markdown :: (ToPandoc a) => a -> String
|
2017-01-15 20:42:00 +01:00
|
|
|
markdown = purely (writeMarkdown defopts) . toPandoc
|
2011-06-22 19:46:54 -07:00
|
|
|
|
2016-10-11 22:26:03 -04:00
|
|
|
markdownWithOpts :: (ToPandoc a) => WriterOptions -> a -> String
|
2016-11-27 11:52:42 +01:00
|
|
|
markdownWithOpts opts x = purely (writeMarkdown opts) $ toPandoc x
|
2016-10-11 22:26:03 -04:00
|
|
|
|
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"
|
2016-10-11 22:26:03 -04:00
|
|
|
] ++ [noteTests] ++ [shortcutLinkRefsTests]
|
|
|
|
|
|
|
|
{-
|
|
|
|
|
|
|
|
Testing with the following text:
|
|
|
|
|
|
|
|
First Header
|
|
|
|
============
|
|
|
|
|
|
|
|
This is a footnote.[^1] And this is a [link](https://www.google.com).
|
|
|
|
|
|
|
|
> A note inside a block quote.[^2]
|
|
|
|
>
|
|
|
|
> A second paragraph.
|
|
|
|
|
|
|
|
Second Header
|
|
|
|
=============
|
|
|
|
|
|
|
|
Some more text.
|
|
|
|
|
|
|
|
|
|
|
|
[^1]: Down here.
|
|
|
|
|
|
|
|
[^2]: The second note.
|
|
|
|
|
|
|
|
-}
|
|
|
|
|
|
|
|
noteTestDoc :: Blocks
|
|
|
|
noteTestDoc =
|
|
|
|
header 1 "First Header" <>
|
|
|
|
para ("This is a footnote." <>
|
|
|
|
note (para "Down here.") <>
|
|
|
|
" And this is a " <>
|
|
|
|
link "https://www.google.com" "" "link" <>
|
|
|
|
".") <>
|
|
|
|
blockQuote (para ("A note inside a block quote." <>
|
|
|
|
note (para "The second note.")) <>
|
|
|
|
para ("A second paragraph.")) <>
|
|
|
|
header 1 "Second Header" <>
|
|
|
|
para "Some more text."
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
noteTests :: Test
|
|
|
|
noteTests = testGroup "note and reference location"
|
2017-01-15 20:42:00 +01:00
|
|
|
[ test (markdownWithOpts defopts)
|
2016-10-11 22:26:03 -04:00
|
|
|
"footnotes at the end of a document" $
|
|
|
|
noteTestDoc =?>
|
|
|
|
(unlines $ [ "First Header"
|
|
|
|
, "============"
|
|
|
|
, ""
|
|
|
|
, "This is a footnote.[^1] And this is a [link](https://www.google.com)."
|
|
|
|
, ""
|
|
|
|
, "> A note inside a block quote.[^2]"
|
|
|
|
, ">"
|
|
|
|
, "> A second paragraph."
|
|
|
|
, ""
|
|
|
|
, "Second Header"
|
|
|
|
, "============="
|
|
|
|
, ""
|
|
|
|
, "Some more text."
|
|
|
|
, ""
|
|
|
|
, "[^1]: Down here."
|
|
|
|
, ""
|
|
|
|
, "[^2]: The second note."
|
|
|
|
])
|
2017-01-15 20:42:00 +01:00
|
|
|
, test (markdownWithOpts defopts{writerReferenceLocation=EndOfBlock})
|
2016-10-11 22:26:03 -04:00
|
|
|
"footnotes at the end of blocks" $
|
|
|
|
noteTestDoc =?>
|
|
|
|
(unlines $ [ "First Header"
|
|
|
|
, "============"
|
|
|
|
, ""
|
|
|
|
, "This is a footnote.[^1] And this is a [link](https://www.google.com)."
|
|
|
|
, ""
|
|
|
|
, "[^1]: Down here."
|
|
|
|
, ""
|
|
|
|
, "> A note inside a block quote.[^2]"
|
|
|
|
, ">"
|
|
|
|
, "> A second paragraph."
|
|
|
|
, ""
|
|
|
|
, "[^2]: The second note."
|
|
|
|
, ""
|
|
|
|
, "Second Header"
|
|
|
|
, "============="
|
|
|
|
, ""
|
|
|
|
, "Some more text."
|
|
|
|
])
|
2017-01-15 20:42:00 +01:00
|
|
|
, test (markdownWithOpts defopts{writerReferenceLocation=EndOfBlock, writerReferenceLinks=True})
|
2016-10-11 22:26:03 -04:00
|
|
|
"footnotes and reference links at the end of blocks" $
|
|
|
|
noteTestDoc =?>
|
|
|
|
(unlines $ [ "First Header"
|
|
|
|
, "============"
|
|
|
|
, ""
|
|
|
|
, "This is a footnote.[^1] And this is a [link]."
|
|
|
|
, ""
|
|
|
|
, "[^1]: Down here."
|
|
|
|
, ""
|
|
|
|
, " [link]: https://www.google.com"
|
|
|
|
, ""
|
|
|
|
, "> A note inside a block quote.[^2]"
|
|
|
|
, ">"
|
|
|
|
, "> A second paragraph."
|
|
|
|
, ""
|
|
|
|
, "[^2]: The second note."
|
|
|
|
, ""
|
|
|
|
, "Second Header"
|
|
|
|
, "============="
|
|
|
|
, ""
|
|
|
|
, "Some more text."
|
|
|
|
])
|
2017-01-15 20:42:00 +01:00
|
|
|
, test (markdownWithOpts defopts{writerReferenceLocation=EndOfSection})
|
2016-10-11 22:26:03 -04:00
|
|
|
"footnotes at the end of section" $
|
|
|
|
noteTestDoc =?>
|
|
|
|
(unlines $ [ "First Header"
|
|
|
|
, "============"
|
|
|
|
, ""
|
|
|
|
, "This is a footnote.[^1] And this is a [link](https://www.google.com)."
|
|
|
|
, ""
|
|
|
|
, "> A note inside a block quote.[^2]"
|
|
|
|
, ">"
|
|
|
|
, "> A second paragraph."
|
|
|
|
, ""
|
|
|
|
, "[^1]: Down here."
|
|
|
|
, ""
|
|
|
|
, "[^2]: The second note."
|
|
|
|
, ""
|
|
|
|
, "Second Header"
|
|
|
|
, "============="
|
|
|
|
, ""
|
|
|
|
, "Some more text."
|
|
|
|
])
|
|
|
|
|
|
|
|
]
|
2015-03-03 03:28:56 +02:00
|
|
|
|
|
|
|
shortcutLinkRefsTests :: Test
|
|
|
|
shortcutLinkRefsTests =
|
|
|
|
let infix 4 =:
|
|
|
|
(=:) :: (ToString a, ToPandoc a)
|
2016-10-11 22:26:03 -04:00
|
|
|
|
|
|
|
=> String -> (a, String) -> Test
|
2017-01-15 20:42:00 +01:00
|
|
|
(=:) = test (purely (writeMarkdown defopts{writerReferenceLinks = True}) . toPandoc)
|
2015-03-03 03:28:56 +02:00
|
|
|
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"
|
|
|
|
]
|
|
|
|
]
|