2013-01-23 17:47:43 +01:00
|
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
2011-01-27 07:09:09 +01:00
|
|
|
|
module Tests.Readers.Markdown (tests) where
|
|
|
|
|
|
|
|
|
|
import Text.Pandoc.Definition
|
|
|
|
|
import Test.Framework
|
|
|
|
|
import Tests.Helpers
|
|
|
|
|
import Tests.Arbitrary()
|
|
|
|
|
import Text.Pandoc.Builder
|
2012-08-09 08:18:19 +02:00
|
|
|
|
import qualified Data.Set as Set
|
2011-02-05 03:33:08 +01:00
|
|
|
|
-- import Text.Pandoc.Shared ( normalize )
|
2011-01-27 07:09:09 +01:00
|
|
|
|
import Text.Pandoc
|
|
|
|
|
|
|
|
|
|
markdown :: String -> Pandoc
|
2012-07-26 07:35:41 +02:00
|
|
|
|
markdown = readMarkdown def
|
2011-01-27 07:09:09 +01:00
|
|
|
|
|
2011-07-26 08:49:45 +02:00
|
|
|
|
markdownSmart :: String -> Pandoc
|
2012-07-26 07:35:41 +02:00
|
|
|
|
markdownSmart = readMarkdown def { readerSmart = True }
|
2011-07-26 08:49:45 +02:00
|
|
|
|
|
2012-02-05 22:23:06 +01:00
|
|
|
|
infix 4 =:
|
2011-01-27 07:09:09 +01:00
|
|
|
|
(=:) :: ToString c
|
|
|
|
|
=> String -> (String, c) -> Test
|
|
|
|
|
(=:) = test markdown
|
|
|
|
|
|
2013-01-15 21:28:31 +01:00
|
|
|
|
testBareLink :: (String, Inlines) -> Test
|
|
|
|
|
testBareLink (inp, ils) =
|
|
|
|
|
test (readMarkdown def{ readerExtensions =
|
2013-09-02 00:18:56 +02:00
|
|
|
|
Set.fromList [Ext_autolink_bare_uris, Ext_raw_html] })
|
2013-01-15 21:28:31 +01:00
|
|
|
|
inp (inp, doc $ para ils)
|
|
|
|
|
|
|
|
|
|
autolink :: String -> Inlines
|
|
|
|
|
autolink s = link s "" (str s)
|
|
|
|
|
|
|
|
|
|
bareLinkTests :: [(String, Inlines)]
|
|
|
|
|
bareLinkTests =
|
|
|
|
|
[ ("http://google.com is a search engine.",
|
|
|
|
|
autolink "http://google.com" <> " is a search engine.")
|
2013-09-02 00:18:56 +02:00
|
|
|
|
, ("<a href=\"http://foo.bar.baz\">http://foo.bar.baz</a>",
|
|
|
|
|
rawInline "html" "<a href=\"http://foo.bar.baz\">" <>
|
|
|
|
|
"http://foo.bar.baz" <> rawInline "html" "</a>")
|
2013-01-15 21:28:31 +01:00
|
|
|
|
, ("Try this query: http://google.com?search=fish&time=hour.",
|
|
|
|
|
"Try this query: " <> autolink "http://google.com?search=fish&time=hour" <> ".")
|
|
|
|
|
, ("HTTPS://GOOGLE.COM,",
|
|
|
|
|
autolink "HTTPS://GOOGLE.COM" <> ",")
|
|
|
|
|
, ("http://el.wikipedia.org/wiki/Τεχνολογία,",
|
|
|
|
|
autolink "http://el.wikipedia.org/wiki/Τεχνολογία" <> ",")
|
|
|
|
|
, ("doi:10.1000/182,",
|
|
|
|
|
autolink "doi:10.1000/182" <> ",")
|
|
|
|
|
, ("git://github.com/foo/bar.git,",
|
|
|
|
|
autolink "git://github.com/foo/bar.git" <> ",")
|
|
|
|
|
, ("file:///Users/joe/joe.txt, and",
|
|
|
|
|
autolink "file:///Users/joe/joe.txt" <> ", and")
|
|
|
|
|
, ("mailto:someone@somedomain.com.",
|
|
|
|
|
autolink "mailto:someone@somedomain.com" <> ".")
|
|
|
|
|
, ("Use http: this is not a link!",
|
|
|
|
|
"Use http: this is not a link!")
|
|
|
|
|
, ("(http://google.com).",
|
|
|
|
|
"(" <> autolink "http://google.com" <> ").")
|
|
|
|
|
, ("http://en.wikipedia.org/wiki/Sprite_(computer_graphics)",
|
|
|
|
|
autolink "http://en.wikipedia.org/wiki/Sprite_(computer_graphics)")
|
|
|
|
|
, ("http://en.wikipedia.org/wiki/Sprite_[computer_graphics]",
|
|
|
|
|
autolink "http://en.wikipedia.org/wiki/Sprite_[computer_graphics]")
|
|
|
|
|
, ("http://en.wikipedia.org/wiki/Sprite_{computer_graphics}",
|
|
|
|
|
autolink "http://en.wikipedia.org/wiki/Sprite_{computer_graphics}")
|
|
|
|
|
, ("http://example.com/Notification_Center-GitHub-20101108-140050.jpg",
|
|
|
|
|
autolink "http://example.com/Notification_Center-GitHub-20101108-140050.jpg")
|
|
|
|
|
, ("https://github.com/github/hubot/blob/master/scripts/cream.js#L20-20",
|
|
|
|
|
autolink "https://github.com/github/hubot/blob/master/scripts/cream.js#L20-20")
|
|
|
|
|
, ("http://www.rubyonrails.com",
|
|
|
|
|
autolink "http://www.rubyonrails.com")
|
|
|
|
|
, ("http://www.rubyonrails.com:80",
|
|
|
|
|
autolink "http://www.rubyonrails.com:80")
|
|
|
|
|
, ("http://www.rubyonrails.com/~minam",
|
|
|
|
|
autolink "http://www.rubyonrails.com/~minam")
|
|
|
|
|
, ("https://www.rubyonrails.com/~minam",
|
|
|
|
|
autolink "https://www.rubyonrails.com/~minam")
|
|
|
|
|
, ("http://www.rubyonrails.com/~minam/url%20with%20spaces",
|
|
|
|
|
autolink "http://www.rubyonrails.com/~minam/url%20with%20spaces")
|
|
|
|
|
, ("http://www.rubyonrails.com/foo.cgi?something=here",
|
|
|
|
|
autolink "http://www.rubyonrails.com/foo.cgi?something=here")
|
|
|
|
|
, ("http://www.rubyonrails.com/foo.cgi?something=here&and=here",
|
|
|
|
|
autolink "http://www.rubyonrails.com/foo.cgi?something=here&and=here")
|
|
|
|
|
, ("http://www.rubyonrails.com/contact;new",
|
|
|
|
|
autolink "http://www.rubyonrails.com/contact;new")
|
|
|
|
|
, ("http://www.rubyonrails.com/contact;new%20with%20spaces",
|
|
|
|
|
autolink "http://www.rubyonrails.com/contact;new%20with%20spaces")
|
|
|
|
|
, ("http://www.rubyonrails.com/contact;new?with=query&string=params",
|
|
|
|
|
autolink "http://www.rubyonrails.com/contact;new?with=query&string=params")
|
|
|
|
|
, ("http://www.rubyonrails.com/~minam/contact;new?with=query&string=params",
|
|
|
|
|
autolink "http://www.rubyonrails.com/~minam/contact;new?with=query&string=params")
|
|
|
|
|
, ("http://en.wikipedia.org/wiki/Wikipedia:Today%27s_featured_picture_%28animation%29/January_20%2C_2007",
|
|
|
|
|
autolink "http://en.wikipedia.org/wiki/Wikipedia:Today%27s_featured_picture_%28animation%29/January_20%2C_2007")
|
|
|
|
|
, ("http://www.mail-archive.com/rails@lists.rubyonrails.org/",
|
|
|
|
|
autolink "http://www.mail-archive.com/rails@lists.rubyonrails.org/")
|
|
|
|
|
, ("http://www.amazon.com/Testing-Equal-Sign-In-Path/ref=pd_bbs_sr_1?ie=UTF8&s=books&qid=1198861734&sr=8-1",
|
|
|
|
|
autolink "http://www.amazon.com/Testing-Equal-Sign-In-Path/ref=pd_bbs_sr_1?ie=UTF8&s=books&qid=1198861734&sr=8-1")
|
|
|
|
|
, ("http://en.wikipedia.org/wiki/Texas_hold%27em",
|
|
|
|
|
autolink "http://en.wikipedia.org/wiki/Texas_hold%27em")
|
|
|
|
|
, ("https://www.google.com/doku.php?id=gps:resource:scs:start",
|
|
|
|
|
autolink "https://www.google.com/doku.php?id=gps:resource:scs:start")
|
|
|
|
|
, ("http://www.rubyonrails.com",
|
|
|
|
|
autolink "http://www.rubyonrails.com")
|
|
|
|
|
, ("http://manuals.ruby-on-rails.com/read/chapter.need_a-period/103#page281",
|
|
|
|
|
autolink "http://manuals.ruby-on-rails.com/read/chapter.need_a-period/103#page281")
|
|
|
|
|
, ("http://foo.example.com/controller/action?parm=value&p2=v2#anchor123",
|
|
|
|
|
autolink "http://foo.example.com/controller/action?parm=value&p2=v2#anchor123")
|
|
|
|
|
, ("http://foo.example.com:3000/controller/action",
|
|
|
|
|
autolink "http://foo.example.com:3000/controller/action")
|
|
|
|
|
, ("http://foo.example.com:3000/controller/action+pack",
|
|
|
|
|
autolink "http://foo.example.com:3000/controller/action+pack")
|
|
|
|
|
, ("http://business.timesonline.co.uk/article/0,,9065-2473189,00.html",
|
|
|
|
|
autolink "http://business.timesonline.co.uk/article/0,,9065-2473189,00.html")
|
|
|
|
|
, ("http://www.mail-archive.com/ruby-talk@ruby-lang.org/",
|
|
|
|
|
autolink "http://www.mail-archive.com/ruby-talk@ruby-lang.org/")
|
|
|
|
|
]
|
|
|
|
|
|
2011-02-05 03:33:08 +01:00
|
|
|
|
{-
|
|
|
|
|
p_markdown_round_trip :: Block -> Bool
|
|
|
|
|
p_markdown_round_trip b = matches d' d''
|
|
|
|
|
where d' = normalize $ Pandoc (Meta [] [] []) [b]
|
|
|
|
|
d'' = normalize
|
2012-07-26 07:35:41 +02:00
|
|
|
|
$ readMarkdown def { readerSmart = True }
|
2012-07-27 07:59:56 +02:00
|
|
|
|
$ writeMarkdown def d'
|
2011-02-05 03:33:08 +01:00
|
|
|
|
matches (Pandoc _ [Plain []]) (Pandoc _ []) = True
|
|
|
|
|
matches (Pandoc _ [Para []]) (Pandoc _ []) = True
|
|
|
|
|
matches (Pandoc _ [Plain xs]) (Pandoc _ [Para xs']) = xs == xs'
|
|
|
|
|
matches x y = x == y
|
|
|
|
|
-}
|
|
|
|
|
|
2011-01-27 07:09:09 +01:00
|
|
|
|
tests :: [Test]
|
|
|
|
|
tests = [ testGroup "inline code"
|
|
|
|
|
[ "with attribute" =:
|
|
|
|
|
"`document.write(\"Hello\");`{.javascript}"
|
|
|
|
|
=?> para
|
|
|
|
|
(codeWith ("",["javascript"],[]) "document.write(\"Hello\");")
|
|
|
|
|
, "with attribute space" =:
|
|
|
|
|
"`*` {.haskell .special x=\"7\"}"
|
|
|
|
|
=?> para (codeWith ("",["haskell","special"],[("x","7")]) "*")
|
|
|
|
|
]
|
2013-11-23 04:41:08 +01:00
|
|
|
|
, testGroup "emph and strong"
|
|
|
|
|
[ "two strongs in emph" =:
|
|
|
|
|
"***a**b **c**d*" =?> para (emph (strong (str "a") <> str "b" <> space
|
|
|
|
|
<> strong (str "c") <> str "d"))
|
|
|
|
|
]
|
2012-09-22 22:00:59 +02:00
|
|
|
|
, testGroup "raw LaTeX"
|
|
|
|
|
[ "in URL" =:
|
|
|
|
|
"\\begin\n" =?> para (text "\\begin")
|
|
|
|
|
]
|
2012-09-22 22:59:30 +02:00
|
|
|
|
, "unbalanced brackets" =:
|
|
|
|
|
"[[[[[[[[[[[[[[[hi" =?> para (text "[[[[[[[[[[[[[[[hi")
|
2011-12-02 04:47:25 +01:00
|
|
|
|
, testGroup "backslash escapes"
|
|
|
|
|
[ "in URL" =:
|
|
|
|
|
"[hi](/there\\))"
|
2011-12-06 06:13:06 +01:00
|
|
|
|
=?> para (link "/there)" "" "hi")
|
2011-12-05 07:37:28 +01:00
|
|
|
|
, "in title" =:
|
2011-12-06 06:16:30 +01:00
|
|
|
|
"[hi](/there \"a\\\"a\")"
|
2011-12-06 06:13:06 +01:00
|
|
|
|
=?> para (link "/there" "a\"a" "hi")
|
2011-12-06 04:07:17 +01:00
|
|
|
|
, "in reference link title" =:
|
|
|
|
|
"[hi]\n\n[hi]: /there (a\\)a)"
|
2011-12-06 06:13:06 +01:00
|
|
|
|
=?> para (link "/there" "a)a" "hi")
|
2011-12-06 04:07:17 +01:00
|
|
|
|
, "in reference link URL" =:
|
2011-12-06 06:16:30 +01:00
|
|
|
|
"[hi]\n\n[hi]: /there\\.0"
|
|
|
|
|
=?> para (link "/there.0" "" "hi")
|
2011-12-02 04:47:25 +01:00
|
|
|
|
]
|
2013-01-15 21:28:31 +01:00
|
|
|
|
, testGroup "bare URIs"
|
|
|
|
|
(map testBareLink bareLinkTests)
|
2013-06-19 18:27:11 +02:00
|
|
|
|
, testGroup "Headers"
|
|
|
|
|
[ "blank line before header" =:
|
|
|
|
|
"\n# Header\n"
|
|
|
|
|
=?> headerWith ("header",[],[]) 1 "Header"
|
|
|
|
|
]
|
2011-07-26 08:49:45 +02:00
|
|
|
|
, testGroup "smart punctuation"
|
|
|
|
|
[ test markdownSmart "quote before ellipses"
|
|
|
|
|
("'...hi'"
|
2013-12-20 02:43:25 +01:00
|
|
|
|
=?> para (singleQuoted "…hi"))
|
2011-12-27 08:03:20 +01:00
|
|
|
|
, test markdownSmart "apostrophe before emph"
|
|
|
|
|
("D'oh! A l'*aide*!"
|
|
|
|
|
=?> para ("D’oh! A l’" <> emph "aide" <> "!"))
|
|
|
|
|
, test markdownSmart "apostrophe in French"
|
|
|
|
|
("À l'arrivée de la guerre, le thème de l'«impossibilité du socialisme»"
|
2013-12-20 02:43:25 +01:00
|
|
|
|
=?> para "À l’arrivée de la guerre, le thème de l’«impossibilité du socialisme»")
|
2011-07-26 08:49:45 +02:00
|
|
|
|
]
|
2011-06-23 05:37:57 +02:00
|
|
|
|
, testGroup "mixed emphasis and strong"
|
|
|
|
|
[ "emph and strong emph alternating" =:
|
2011-06-23 05:18:32 +02:00
|
|
|
|
"*xxx* ***xxx*** xxx\n*xxx* ***xxx*** xxx"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
=?> para (emph "xxx" <> space <> strong (emph "xxx") <>
|
|
|
|
|
space <> "xxx" <> space <>
|
|
|
|
|
emph "xxx" <> space <> strong (emph "xxx") <>
|
|
|
|
|
space <> "xxx")
|
2011-06-23 05:37:57 +02:00
|
|
|
|
, "emph with spaced strong" =:
|
|
|
|
|
"*x **xx** x*"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
=?> para (emph ("x" <> space <> strong "xx" <> space <> "x"))
|
2011-06-23 05:18:32 +02:00
|
|
|
|
]
|
2011-02-01 05:05:11 +01:00
|
|
|
|
, testGroup "footnotes"
|
2011-02-01 16:37:22 +01:00
|
|
|
|
[ "indent followed by newline and flush-left text" =:
|
2011-02-01 05:42:49 +01:00
|
|
|
|
"[^1]\n\n[^1]: my note\n\n \nnot in note\n"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
=?> para (note (para "my note")) <> para "not in note"
|
2011-02-01 16:37:22 +01:00
|
|
|
|
, "indent followed by newline and indented text" =:
|
2011-02-02 07:35:27 +01:00
|
|
|
|
"[^1]\n\n[^1]: my note\n \n in note\n"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
=?> para (note (para "my note" <> para "in note"))
|
2011-04-20 20:42:27 +02:00
|
|
|
|
, "recursive note" =:
|
|
|
|
|
"[^1]\n\n[^1]: See [^1]\n"
|
|
|
|
|
=?> para (note (para "See [^1]"))
|
2011-02-01 05:05:11 +01:00
|
|
|
|
]
|
2011-03-02 20:18:38 +01:00
|
|
|
|
, testGroup "lhs"
|
2012-08-09 08:18:19 +02:00
|
|
|
|
[ test (readMarkdown def{ readerExtensions = Set.insert
|
|
|
|
|
Ext_literate_haskell $ readerExtensions def })
|
2011-03-02 20:18:38 +01:00
|
|
|
|
"inverse bird tracks and html" $
|
|
|
|
|
"> a\n\n< b\n\n<div>\n"
|
|
|
|
|
=?> codeBlockWith ("",["sourceCode","literate","haskell"],[]) "a"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
<>
|
2011-03-02 20:18:38 +01:00
|
|
|
|
codeBlockWith ("",["sourceCode","haskell"],[]) "b"
|
2011-12-13 23:29:07 +01:00
|
|
|
|
<>
|
2011-03-02 20:18:38 +01:00
|
|
|
|
rawBlock "html" "<div>\n\n"
|
|
|
|
|
]
|
2011-02-05 03:33:08 +01:00
|
|
|
|
-- the round-trip properties frequently fail
|
|
|
|
|
-- , testGroup "round trip"
|
|
|
|
|
-- [ property "p_markdown_round_trip" p_markdown_round_trip
|
|
|
|
|
-- ]
|
2014-05-04 17:19:48 +02:00
|
|
|
|
, testGroup "lists"
|
|
|
|
|
[ "issue #1154" =:
|
|
|
|
|
" - <div>\n first div breaks\n </div>\n\n <button>if this button exists</button>\n\n <div>\n with this div too.\n </div>\n"
|
|
|
|
|
=?> bulletList [divWith nullAttr (plain $ text "first div breaks") <>
|
|
|
|
|
rawBlock "html" "<button>" <>
|
|
|
|
|
plain (text "if this button exists") <>
|
2014-07-07 23:47:51 +02:00
|
|
|
|
rawBlock "html" "</button>" <>
|
2014-05-04 17:19:48 +02:00
|
|
|
|
divWith nullAttr (plain $ text "with this div too.")]
|
|
|
|
|
]
|
2011-01-27 07:09:09 +01:00
|
|
|
|
]
|