" $ "
hello
" =?> - doc (divWith ("", [], [("role", "main")]) (plain (text "hello"))) - , test htmlNativeDivs "
becomes
" $ "
hello
" =?> - doc (divWith ("", [], [("role", "foobar")]) (plain (text "hello"))) - , test htmlNativeDivs "
has attributes preserved" $ "
hello
" =?> - doc (divWith ("foo", ["bar"], [("role", "main"), ("data-baz", "qux")]) (plain (text "hello"))) - , test htmlNativeDivs "
closes

" $ "

hello

main content
" =?> - doc (para (text "hello") <> divWith ("", [], [("role", "main")]) (plain (text "main content"))) - , test htmlNativeDivs "
followed by text" $ "
main content
non-main content" =?> - doc (divWith ("", [], [("role", "main")]) (plain (text "main content")) <> plain (text "non-main content")) - ] - ] diff --git a/test/Tests/Readers/JATS.hs.orig b/test/Tests/Readers/JATS.hs.orig deleted file mode 100644 index 5c7dfa77c..000000000 --- a/test/Tests/Readers/JATS.hs.orig +++ /dev/null @@ -1,116 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.JATS (tests) where - -import Data.Text (Text) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -jats :: Text -> Pandoc -jats = purely $ readJATS def - -tests :: [TestTree] -tests = [ testGroup "inline code" - [ test jats "basic" $ "

\n @&\n

" =?> para (code "@&") - , test jats "lang" $ "

\n @&\n

" =?> para (codeWith ("", ["c"], []) "@&") - ] - , testGroup "block code" - [ test jats "basic" $ "@&" =?> codeBlock "@&" - , test jats "lang" $ "@&" =?> codeBlockWith ("", ["c"], []) "@&" - ] - , testGroup "images" - [ test jats "basic" $ "" - =?> para (image "/url" "title" mempty) - ] - , test jats "bullet list" $ - "\n\ - \ \n\ - \

\n\ - \ first\n\ - \

\n\ - \
\n\ - \ \n\ - \

\n\ - \ second\n\ - \

\n\ - \
\n\ - \ \n\ - \

\n\ - \ third\n\ - \

\n\ - \
\n\ - \
" - =?> bulletList [ para $ text "first" - , para $ text "second" - , para $ text "third" - ] - , testGroup "definition lists" - [ test jats "with internal link" $ - "\n\ - \ \n\ - \ \n\ - \ testing\n\ - \ \n\ - \ \n\ - \

\n\ - \ hi there\n\ - \

\n\ - \
\n\ - \
\n\ - \
" - =?> definitionList [(link "#go" "" (str "testing"), - [para (text "hi there")])] - ] - , testGroup "math" - [ test jats "escape |" $ - "

\n\ - \ \n\ - \ \n\ - \ σ|{x}\n\ - \

" - =?> para (math "\\sigma|_{\\{x\\}}") - , test jats "tex-math only" $ - "

\n\ - \ \n\ - \ \n\ - \

" - =?> para (math "\\sigma|_{\\{x\\}}") - , test jats "math ml only" $ - "

\n\ - \ \n\ - \ σ|{x}\n\ - \

" - =?> para (math "\\sigma|_{\\{ x\\}}") - ] - , testGroup "headers" --- TODO fix footnotes in headers --- [ test jats "unnumbered header" $ --- "\n\ --- \ Header 1<fn>\n\ --- \ <p>\n\ --- \ note\n\ --- \ </p>\n\ --- \ </fn>\n\ --- \" --- =?> header 1 --- (text "Header 1" <> note (plain $ text "note")) - [ test jats "unnumbered sub header" $ - "\n\ - \ Header\n\ - \ \n\ - \ Sub-Header\n\ - \ \n\ - \" - =?> headerWith ("foo", [], []) 1 - (text "Header") - <> headerWith ("foo2", [], []) 2 - (text "Sub-Header") - , test jats "containing image" $ - "\n\ - \ <inline-graphic mimetype=\"image\" mime-subtype=\"jpeg\" xlink:href=\"imgs/foo.jpg\" />\n\ - \" - =?> header 1 (image "imgs/foo.jpg" "" mempty) - ] - ] diff --git a/test/Tests/Readers/LaTeX.hs.orig b/test/Tests/Readers/LaTeX.hs.orig deleted file mode 100644 index 4396d550f..000000000 --- a/test/Tests/Readers/LaTeX.hs.orig +++ /dev/null @@ -1,341 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.LaTeX (tests) where - -import Data.Text (Text) -import qualified Data.Text as T -import qualified Text.Pandoc.UTF8 as UTF8 -import Text.Pandoc.Readers.LaTeX (tokenize, untokenize) -import Test.Tasty -import Test.Tasty.HUnit -import Test.Tasty.QuickCheck -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -latex :: Text -> Pandoc -latex = purely $ readLaTeX def{ - readerExtensions = getDefaultExtensions "latex" } - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test latex - -simpleTable' :: [Alignment] -> [[Blocks]] -> Blocks -simpleTable' aligns = table "" (zip aligns (repeat 0.0)) - (map (const mempty) aligns) - -tokUntokRt :: String -> Bool -tokUntokRt s = untokenize (tokenize "random" t) == t - where t = T.pack s - -tests :: [TestTree] -tests = [ testGroup "tokenization" - [ testCase "tokenizer round trip on test case" $ do - orig <- T.pack <$> UTF8.readFile "../test/latex-reader.latex" - let new = untokenize $ tokenize "../test/latex-reader.latex" - orig - assertEqual "untokenize . tokenize is identity" orig new - , testProperty "untokenize . tokenize is identity" tokUntokRt - ] - - , testGroup "basic" - [ "simple" =: - "word" =?> para "word" - , "space" =: - "some text" =?> para "some text" - , "emphasized" =: - "\\emph{emphasized}" =?> para (emph "emphasized") - ] - - , testGroup "headers" - [ "level 1" =: - "\\section{header}" =?> headerWith ("header",[],[]) 1 "header" - , "level 2" =: - "\\subsection{header}" =?> headerWith ("header",[],[]) 2 "header" - , "level 3" =: - "\\subsubsection{header}" =?> headerWith ("header",[],[]) 3 "header" - , "emph" =: - "\\section{text \\emph{emph}}" =?> - headerWith ("text-emph",[],[]) 1 ("text" <> space <> emph "emph") - , "link" =: - "\\section{text \\href{/url}{link}}" =?> - headerWith ("text-link",[],[]) 1 ("text" <> space <> link "/url" "" "link") - ] - - , testGroup "math" - [ "escaped $" =: - "$x=\\$4$" =?> para (math "x=\\$4") - ] - - , testGroup "space and comments" - [ "blank lines + space at beginning" =: - "\n \n hi" =?> para "hi" - , "blank lines + space + comments" =: - "% my comment\n\n \n % another\n\nhi" =?> para "hi" - , "comment in paragraph" =: - "hi % this is a comment\nthere\n" =?> - para ("hi" <> softbreak <> "there") - ] - - , testGroup "code blocks" - [ "identifier" =: - "\\begin{lstlisting}[label=test]\\end{lstlisting}" =?> codeBlockWith ("test", [], [("label","test")]) "" - , "no identifier" =: - "\\begin{lstlisting}\\end{lstlisting}" =?> codeBlock "" - ] - - , testGroup "tables" - [ "Single cell table" =: - "\\begin{tabular}{|l|}Test\\\\\\end{tabular}" =?> - simpleTable' [AlignLeft] [[plain "Test"]] - , "Multi cell table" =: - "\\begin{tabular}{|rl|}One & Two\\\\ \\end{tabular}" =?> - simpleTable' [AlignRight,AlignLeft] [[plain "One", plain "Two"]] - , "Multi line table" =: - T.unlines [ "\\begin{tabular}{|c|}" - , "One\\\\" - , "Two\\\\" - , "Three\\\\" - , "\\end{tabular}" ] =?> - simpleTable' [AlignCenter] - [[plain "One"], [plain "Two"], [plain "Three"]] - , "Empty table" =: - "\\begin{tabular}{}\\end{tabular}" =?> - simpleTable' [] [] - , "Table with fixed column width" =: - "\\begin{tabular}{|p{5cm}r|}One & Two\\\\ \\end{tabular}" =?> - simpleTable' [AlignLeft,AlignRight] [[plain "One", plain "Two"]] - , "Table with empty column separators" =: - "\\begin{tabular}{@{}r@{}l}One & Two\\\\ \\end{tabular}" =?> - simpleTable' [AlignRight,AlignLeft] [[plain "One", plain "Two"]] - , "Table with custom column separators" =: - T.unlines [ "\\begin{tabular}{@{($\\to$)}r@{\\hspace{2cm}}l}" - , "One&Two\\\\" - , "\\end{tabular}" ] =?> - simpleTable' [AlignRight,AlignLeft] [[plain "One", plain "Two"]] - , "Table with vertical alignment argument" =: - "\\begin{tabular}[t]{r|r}One & Two\\\\ \\end{tabular}" =?> - simpleTable' [AlignRight,AlignRight] [[plain "One", plain "Two"]] - ] - - , testGroup "citations" - [ natbibCitations - , biblatexCitations - ] - - , testGroup "images" - [ "Basic image" =: - "\\includegraphics{foo.png}" =?> - para (image "foo.png" "" (text "image")) - , "Basic image with blank options" =: - "\\includegraphics[]{foo.png}" =?> - para (image "foo.png" "" (text "image")) - , "Image with both width and height" =: - "\\includegraphics[width=17cm,height=5cm]{foo.png}" =?> - para (imageWith ("", [], [("width", "17cm"), ("height", "5cm")]) "foo.png" "" "image") - , "Image with width and height and a bunch of other options" =: - "\\includegraphics[width=17cm,height=5cm,clip,keepaspectratio]{foo.png}" =?> - para (imageWith ("", [], [("width", "17cm"), ("height", "5cm")]) "foo.png" "" "image") - , "Image with just width" =: - "\\includegraphics[width=17cm]{foo.png}" =?> - para (imageWith ("", [], [("width", "17cm")]) "foo.png" "" "image") - , "Image with just height" =: - "\\includegraphics[height=17cm]{foo.png}" =?> - para (imageWith ("", [], [("height", "17cm")]) "foo.png" "" "image") - , "Image width relative to textsize" =: - "\\includegraphics[width=0.6\\textwidth]{foo.png}" =?> - para (imageWith ("", [], [("width", "60%")]) "foo.png" "" "image") - , "Image with options with spaces" =: - "\\includegraphics[width=12cm, height = 5cm]{foo.png}" =?> - para (imageWith ("", [], [("width", "12cm"), ("height", "5cm")]) "foo.png" "" "image") - ] - - , let hex = ['0'..'9']++['a'..'f'] in - testGroup "Character Escapes" - [ "Two-character escapes" =: - mconcat ["^^" <> T.pack [i,j] | i <- hex, j <- hex] =?> - para (str ['\0'..'\255']) - , "One-character escapes" =: - mconcat ["^^" <> T.pack [i] | i <- hex] =?> - para (str $ ['p'..'y']++['!'..'&']) - ] - , testGroup "memoir scene breaks" - [ "plainbreak" =: - "hello\\plainbreak{2}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "plainbreak*" =: - "hello\\plainbreak*{2}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "fancybreak" =: - "hello\\fancybreak{b r e a k}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "fancybreak*" =: - "hello\\fancybreak*{b r e a k}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "plainfancybreak" =: - "hello\\plainfancybreak{4}{2}{b r e a k}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "plainfancybreak*" =: - "hello\\plainfancybreak*{4}{2}{b r e a k}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "pfbreak" =: - "hello\\pfbreak{}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - , "pfbreak*" =: - "hello\\pfbreak*{}goodbye" =?> - para (str "hello") <> horizontalRule <> para (str "goodbye") - ] - , testGroup "biblatex roman numerals" - [ "upper" =: - "number \\RN{12}" =?> - para (str "number" <> space <> str "XII") - , "lower" =: - "number \\Rn{29}" =?> - para (str "number" <> space <> str "xxix") - , "leading zero" =: - "\\Rn{014}" =?> - para (str "xiv") - , "surrounding spaces" =: - "number \\Rn{ 41 }" =?> - para (str "number" <> space <> str "xli") - , "zero" =: - "\\RN{0}" =?> - para (str "") - , "space then unbraced argument" =: - "\\RN 7 ok" =?> - para (str "VII" <> space <> str "ok") - , "space before braced argument" =: - "\\Rn {13}ok" =?> - para (str "xiiiok") - ] - , testGroup "polyglossia language spans" - [ "french" =: - "hello \\textfrench{bonjour}" =?> - para (str "hello" <> space <> spanWith ("", [], [("lang", "fr")]) (str "bonjour")) - , "nested" =: - "\\textfrench{quelle c'est \\textlatin{primus}?}" =?> - para (spanWith ("", [], [("lang", "fr")]) $ - str "quelle" <> space <> str "c\8217est" <> space <> - spanWith ("", [], [("lang", "la")]) (str "primus") <> str "?") - , "with formatting" =: - "\\textgerman{wie \\emph{spaet} ist es?}" =?> - para (spanWith ("", [], [("lang", "de")]) $ - str "wie" <> space <> emph (str "spaet") <> space <> str "ist" <> space <> str "es?") - , "language options" =: - "\\textgerman[variant=swiss]{hoechdeutsche}" =?> - para (spanWith ("", [], [("lang", "de-CH")]) $ str "hoechdeutsche") - , "unknown option fallback" =: - "\\textgerman[variant=moon]{ueberhoechdeutsche}" =?> - para (spanWith ("", [], [("lang", "de")]) $ str "ueberhoechdeutsche") - ] - ] - -baseCitation :: Citation -baseCitation = Citation{ citationId = "item1" - , citationPrefix = [] - , citationSuffix = [] - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - -rt :: String -> Inlines -rt = rawInline "latex" - -natbibCitations :: TestTree -natbibCitations = testGroup "natbib" - [ "citet" =: "\\citet{item1}" - =?> para (cite [baseCitation] (rt "\\citet{item1}")) - , "suffix" =: "\\citet[p.~30]{item1}" - =?> para - (cite [baseCitation{ citationSuffix = toList $ text "p.\160\&30" }] (rt "\\citet[p.~30]{item1}")) - , "suffix long" =: "\\citet[p.~30, with suffix]{item1}" - =?> para (cite [baseCitation{ citationSuffix = - toList $ text "p.\160\&30, with suffix" }] (rt "\\citet[p.~30, with suffix]{item1}")) - , "multiple" =: "\\citeauthor{item1} \\citetext{\\citeyear{item1}; \\citeyear[p.~30]{item2}; \\citealp[see also][]{item3}}" - =?> para (cite [baseCitation{ citationMode = AuthorInText } - ,baseCitation{ citationMode = SuppressAuthor - , citationSuffix = [Str "p.\160\&30"] - , citationId = "item2" } - ,baseCitation{ citationId = "item3" - , citationPrefix = [Str "see",Space,Str "also"] - , citationMode = NormalCitation } - ] (rt "\\citetext{\\citeyear{item1}; \\citeyear[p.~30]{item2}; \\citealp[see also][]{item3}}")) - , "group" =: "\\citetext{\\citealp[see][p.~34--35]{item1}; \\citealp[also][chap. 3]{item3}}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationPrefix = [Str "see"] - , citationSuffix = [Str "p.\160\&34\8211\&35"] } - ,baseCitation{ citationMode = NormalCitation - , citationId = "item3" - , citationPrefix = [Str "also"] - , citationSuffix = [Str "chap.",Space,Str "3"] } - ] (rt "\\citetext{\\citealp[see][p.~34--35]{item1}; \\citealp[also][chap. 3]{item3}}")) - , "suffix and locator" =: "\\citep[pp.~33, 35--37, and nowhere else]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationSuffix = [Str "pp.\160\&33,",Space,Str "35\8211\&37,",Space,Str "and",Space,Str "nowhere",Space, Str "else"] }] (rt "\\citep[pp.~33, 35--37, and nowhere else]{item1}")) - , "suffix only" =: "\\citep[and nowhere else]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationSuffix = toList $ text "and nowhere else" }] (rt "\\citep[and nowhere else]{item1}")) - , "no author" =: "\\citeyearpar{item1}, and now Doe with a locator \\citeyearpar[p.~44]{item2}" - =?> para (cite [baseCitation{ citationMode = SuppressAuthor }] (rt "\\citeyearpar{item1}") <> - text ", and now Doe with a locator " <> - cite [baseCitation{ citationMode = SuppressAuthor - , citationSuffix = [Str "p.\160\&44"] - , citationId = "item2" }] (rt "\\citeyearpar[p.~44]{item2}")) - , "markup" =: "\\citep[\\emph{see}][p. \\textbf{32}]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationPrefix = [Emph [Str "see"]] - , citationSuffix = [Str "p.",Space, - Strong [Str "32"]] }] (rt "\\citep[\\emph{see}][p. \\textbf{32}]{item1}")) - ] - -biblatexCitations :: TestTree -biblatexCitations = testGroup "biblatex" - [ "textcite" =: "\\textcite{item1}" - =?> para (cite [baseCitation] (rt "\\textcite{item1}")) - , "suffix" =: "\\textcite[p.~30]{item1}" - =?> para - (cite [baseCitation{ citationSuffix = toList $ text "p.\160\&30" }] (rt "\\textcite[p.~30]{item1}")) - , "suffix long" =: "\\textcite[p.~30, with suffix]{item1}" - =?> para (cite [baseCitation{ citationSuffix = - toList $ text "p.\160\&30, with suffix" }] (rt "\\textcite[p.~30, with suffix]{item1}")) - , "multiple" =: "\\textcites{item1}[p.~30]{item2}[see also][]{item3}" - =?> para (cite [baseCitation{ citationMode = AuthorInText } - ,baseCitation{ citationMode = NormalCitation - , citationSuffix = [Str "p.\160\&30"] - , citationId = "item2" } - ,baseCitation{ citationId = "item3" - , citationPrefix = [Str "see",Space,Str "also"] - , citationMode = NormalCitation } - ] (rt "\\textcites{item1}[p.~30]{item2}[see also][]{item3}")) - , "group" =: "\\autocites[see][p.~34--35]{item1}[also][chap. 3]{item3}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationPrefix = [Str "see"] - , citationSuffix = [Str "p.\160\&34\8211\&35"] } - ,baseCitation{ citationMode = NormalCitation - , citationId = "item3" - , citationPrefix = [Str "also"] - , citationSuffix = [Str "chap.",Space,Str "3"] } - ] (rt "\\autocites[see][p.~34--35]{item1}[also][chap. 3]{item3}")) - , "suffix and locator" =: "\\autocite[pp.~33, 35--37, and nowhere else]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationSuffix = [Str "pp.\160\&33,",Space,Str "35\8211\&37,",Space,Str "and",Space,Str "nowhere",Space, Str "else"] }] (rt "\\autocite[pp.~33, 35--37, and nowhere else]{item1}")) - , "suffix only" =: "\\autocite[and nowhere else]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationSuffix = toList $ text "and nowhere else" }] (rt "\\autocite[and nowhere else]{item1}")) - , "no author" =: "\\autocite*{item1}, and now Doe with a locator \\autocite*[p.~44]{item2}" - =?> para (cite [baseCitation{ citationMode = SuppressAuthor }] (rt "\\autocite*{item1}") <> - text ", and now Doe with a locator " <> - cite [baseCitation{ citationMode = SuppressAuthor - , citationSuffix = [Str "p.\160\&44"] - , citationId = "item2" }] (rt "\\autocite*[p.~44]{item2}")) - , "markup" =: "\\autocite[\\emph{see}][p. \\textbf{32}]{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation - , citationPrefix = [Emph [Str "see"]] - , citationSuffix = [Str "p.",Space, - Strong [Str "32"]] }] (rt "\\autocite[\\emph{see}][p. \\textbf{32}]{item1}")) - , "parencite" =: "\\parencite{item1}" - =?> para (cite [baseCitation{ citationMode = NormalCitation }] (rt "\\parencite{item1}")) - ] diff --git a/test/Tests/Readers/Markdown.hs.orig b/test/Tests/Readers/Markdown.hs.orig deleted file mode 100644 index 1cd32b87d..000000000 --- a/test/Tests/Readers/Markdown.hs.orig +++ /dev/null @@ -1,462 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Markdown (tests) where - -import Data.Text (Text, unpack) -import qualified Data.Text as T -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -markdown :: Text -> Pandoc -markdown = purely $ readMarkdown def { readerExtensions = - disableExtension Ext_smart pandocExtensions } - -markdownSmart :: Text -> Pandoc -markdownSmart = purely $ readMarkdown def { readerExtensions = - enableExtension Ext_smart pandocExtensions } - -markdownCDL :: Text -> Pandoc -markdownCDL = purely $ readMarkdown def { readerExtensions = enableExtension - Ext_compact_definition_lists pandocExtensions } - -markdownGH :: Text -> Pandoc -markdownGH = purely $ readMarkdown def { - readerExtensions = githubMarkdownExtensions } - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test markdown - -testBareLink :: (Text, Inlines) -> TestTree -testBareLink (inp, ils) = - test (purely $ readMarkdown def{ readerExtensions = - extensionsFromList [Ext_autolink_bare_uris, Ext_raw_html] }) - (unpack inp) (inp, doc $ para ils) - -autolink :: String -> Inlines -autolink = autolinkWith nullAttr - -autolinkWith :: Attr -> String -> Inlines -autolinkWith attr s = linkWith attr s "" (str s) - -bareLinkTests :: [(Text, Inlines)] -bareLinkTests = - [ ("http://google.com is a search engine.", - autolink "http://google.com" <> " is a search engine.") - , ("
http://foo.bar.baz", - rawInline "html" "" <> - "http://foo.bar.baz" <> rawInline "html" "") - , ("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]", - link "http://en.wikipedia.org/wiki/Sprite_%5Bcomputer_graphics%5D" "" - (str "http://en.wikipedia.org/wiki/Sprite_[computer_graphics]")) - , ("http://en.wikipedia.org/wiki/Sprite_{computer_graphics}", - link "http://en.wikipedia.org/wiki/Sprite_%7Bcomputer_graphics%7D" "" - (str "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/") - , ("https://example.org/?anchor=lala-", - autolink "https://example.org/?anchor=lala-") - , ("https://example.org/?anchor=-lala", - autolink "https://example.org/?anchor=-lala") - ] - -{- -p_markdown_round_trip :: Block -> Bool -p_markdown_round_trip b = matches d' d'' - where d' = normalize $ Pandoc (Meta [] [] []) [b] - d'' = normalize - $ readMarkdown def { readerSmart = True } - $ writeMarkdown def d' - matches (Pandoc _ [Plain []]) (Pandoc _ []) = True - matches (Pandoc _ [Para []]) (Pandoc _ []) = True - matches (Pandoc _ [Plain xs]) (Pandoc _ [Para xs']) = xs == xs' - matches x y = x == y --} - -tests :: [TestTree] -tests = [ testGroup "inline code" - [ "with attribute" =: - "`document.write(\"Hello\");`{.javascript}" - =?> para - (codeWith ("",["javascript"],[]) "document.write(\"Hello\");") - , "with attribute space" =: - "`*` {.haskell .special x=\"7\"}" - =?> para (code "*" <> space <> str "{.haskell" <> space <> - str ".special" <> space <> str "x=\"7\"}") - ] - , 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")) - , "emph and strong emph alternating" =: - "*xxx* ***xxx*** xxx\n*xxx* ***xxx*** xxx" - =?> para (emph "xxx" <> space <> strong (emph "xxx") <> - space <> "xxx" <> softbreak <> - emph "xxx" <> space <> strong (emph "xxx") <> - space <> "xxx") - , "emph with spaced strong" =: - "*x **xx** x*" - =?> para (emph ("x" <> space <> strong "xx" <> space <> "x")) - , "intraword underscore with opening underscore (#1121)" =: - "_foot_ball_" =?> para (emph (text "foot_ball")) - ] - , testGroup "raw LaTeX" - [ "in URL" =: - "\\begin\n" =?> para (text "\\begin") - ] - , testGroup "raw HTML" - [ "nesting (issue #1330)" =: - "test" =?> - rawBlock "html" "" <> plain (str "test") <> - rawBlock "html" "" - , "invalid tag (issue #1820" =: - "" =?> - para (text "") - , "technically invalid comment" =: - "" =?> - rawBlock "html" "" - , test markdownGH "issue 2469" $ - "<\n\na>" =?> - para (text "<") <> para (text "a>") - ] - , testGroup "raw email addresses" - [ test markdownGH "issue 2940" $ - "**@user**" =?> - para (strong (text "@user")) - ] - , testGroup "emoji" - [ test markdownGH "emoji symbols" $ - ":smile: and :+1:" =?> para (text "😄 and 👍") - ] - , "unbalanced brackets" =: - "[[[[[[[[[[[[hi" =?> para (text "[[[[[[[[[[[[hi") - , testGroup "backslash escapes" - [ "in URL" =: - "[hi](/there\\))" - =?> para (link "/there)" "" "hi") - , "in title" =: - "[hi](/there \"a\\\"a\")" - =?> para (link "/there" "a\"a" "hi") - , "in reference link title" =: - "[hi]\n\n[hi]: /there (a\\)a)" - =?> para (link "/there" "a)a" "hi") - , "in reference link URL" =: - "[hi]\n\n[hi]: /there\\.0" - =?> para (link "/there.0" "" "hi") - ] - , testGroup "bare URIs" - (map testBareLink bareLinkTests) - , testGroup "autolinks" - [ "with unicode dash following" =: - "\8212" =?> para (autolink "http://foo.bar" <> - str "\8212") - , "a partial URL (#2277)" =: - "" =?> - para (text "") - , "with some attributes" =: - "{#i .j .z k=v}" =?> - para (autolinkWith ("i", ["j", "z"], [("k", "v")]) "http://foo.bar") - , "with some attributes and spaces" =: - " {#i .j .z k=v}" =?> - para (autolink "http://foo.bar" <> space <> text "{#i .j .z k=v}") - ] - , testGroup "links" - [ "no autolink inside link" =: - "[](url)" =?> - para (link "url" "" (text "")) - , "no inline link inside link" =: - "[[a](url2)](url)" =?> - para (link "url" "" (text "[a](url2)")) - , "no bare URI inside link" =: - "[https://example.org(](url)" =?> - para (link "url" "" (text "https://example.org(")) - ] - , testGroup "Headers" - [ "blank line before header" =: - "\n# Header\n" - =?> headerWith ("header",[],[]) 1 "Header" - , "bracketed text (#2062)" =: - "# [hi]\n" - =?> headerWith ("hi",[],[]) 1 "[hi]" - , "ATX header without trailing #s" =: - "# Foo bar\n\n" =?> - headerWith ("foo-bar",[],[]) 1 "Foo bar" - , "ATX header without trailing #s" =: - "# Foo bar with # #" =?> - headerWith ("foo-bar-with",[],[]) 1 "Foo bar with #" - , "setext header" =: - "Foo bar\n=\n\n Foo bar 2 \n=" =?> - headerWith ("foo-bar",[],[]) 1 "Foo bar" - <> headerWith ("foo-bar-2",[],[]) 1 "Foo bar 2" - ] - , testGroup "Implicit header references" - [ "ATX header without trailing #s" =: - "# Header\n[header]\n\n[header ]\n\n[ header]" =?> - headerWith ("header",[],[]) 1 "Header" - <> para (link "#header" "" (text "header")) - <> para (link "#header" "" (text "header")) - <> para (link "#header" "" (text "header")) - , "ATX header with trailing #s" =: - "# Foo bar #\n[foo bar]\n\n[foo bar ]\n\n[ foo bar]" =?> - headerWith ("foo-bar",[],[]) 1 "Foo bar" - <> para (link "#foo-bar" "" (text "foo bar")) - <> para (link "#foo-bar" "" (text "foo bar")) - <> para (link "#foo-bar" "" (text "foo bar")) - , "setext header" =: - " Header \n=\n\n[header]\n\n[header ]\n\n[ header]" =?> - headerWith ("header",[],[]) 1 "Header" - <> para (link "#header" "" (text "header")) - <> para (link "#header" "" (text "header")) - <> para (link "#header" "" (text "header")) - ] - , testGroup "smart punctuation" - [ test markdownSmart "quote before ellipses" - ("'...hi'" - =?> para (singleQuoted "…hi")) - , 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»" - =?> para "À l’arrivée de la guerre, le thème de l’«impossibilité du socialisme»") - , test markdownSmart "apostrophe after math" $ -- issue #1909 - "The value of the $x$'s and the systems' condition." =?> - para (text "The value of the " <> math "x" <> text "\8217s and the systems\8217 condition.") - ] - , testGroup "footnotes" - [ "indent followed by newline and flush-left text" =: - "[^1]\n\n[^1]: my note\n\n \nnot in note\n" - =?> para (note (para "my note")) <> para "not in note" - , "indent followed by newline and indented text" =: - "[^1]\n\n[^1]: my note\n \n in note\n" - =?> para (note (para "my note" <> para "in note")) - , "recursive note" =: - "[^1]\n\n[^1]: See [^1]\n" - =?> para (note (para "See [^1]")) - ] - , testGroup "lhs" - [ test (purely $ readMarkdown def{ readerExtensions = enableExtension - Ext_literate_haskell pandocExtensions }) - "inverse bird tracks and html" $ - "> a\n\n< b\n\n
\n" - =?> codeBlockWith ("",["sourceCode","literate","haskell"],[]) "a" - <> - codeBlockWith ("",["sourceCode","haskell"],[]) "b" - <> - rawBlock "html" "
\n\n" - ] --- the round-trip properties frequently fail --- , testGroup "round trip" --- [ property "p_markdown_round_trip" p_markdown_round_trip --- ] - , testGroup "definition lists" - [ "no blank space" =: - "foo1\n : bar\n\nfoo2\n : bar2\n : bar3\n" =?> - definitionList [ (text "foo1", [plain (text "bar")]) - , (text "foo2", [plain (text "bar2"), - plain (text "bar3")]) - ] - , "blank space before first def" =: - "foo1\n\n : bar\n\nfoo2\n\n : bar2\n : bar3\n" =?> - definitionList [ (text "foo1", [para (text "bar")]) - , (text "foo2", [para (text "bar2"), - plain (text "bar3")]) - ] - , "blank space before second def" =: - "foo1\n : bar\n\nfoo2\n : bar2\n\n : bar3\n" =?> - definitionList [ (text "foo1", [plain (text "bar")]) - , (text "foo2", [plain (text "bar2"), - para (text "bar3")]) - ] - , "laziness" =: - "foo1\n : bar\nbaz\n : bar2\n" =?> - definitionList [ (text "foo1", [plain (text "bar" <> - softbreak <> text "baz"), - plain (text "bar2")]) - ] - , "no blank space before first of two paragraphs" =: - "foo1\n : bar\n\n baz\n" =?> - definitionList [ (text "foo1", [para (text "bar") <> - para (text "baz")]) - ] - , "first line not indented" =: - "foo\n: bar\n" =?> - definitionList [ (text "foo", [plain (text "bar")]) ] - , "list in definition" =: - "foo\n: - bar\n" =?> - definitionList [ (text "foo", [bulletList [plain (text "bar")]]) ] - , "in div" =: - "
foo\n: - bar\n
" =?> - divWith nullAttr (definitionList - [ (text "foo", [bulletList [plain (text "bar")]]) ]) - ] - , testGroup "+compact_definition_lists" - [ test markdownCDL "basic compact list" $ - "foo1\n: bar\n baz\nfoo2\n: bar2\n" =?> - definitionList [ (text "foo1", [plain (text "bar" <> softbreak <> - text "baz")]) - , (text "foo2", [plain (text "bar2")]) - ] - ] - , testGroup "lists" - [ "issue #1154" =: - " -
\n first div breaks\n
\n\n \n\n
\n with this div too.\n
\n" - =?> bulletList [divWith nullAttr (para $ text "first div breaks") <> - rawBlock "html" "" <> - divWith nullAttr (para $ text "with this div too.")] - , test markdownGH "issue #1636" $ - T.unlines [ "* a" - , "* b" - , "* c" - , " * d" ] - =?> - bulletList [ plain "a" - , plain "b" - , plain "c" <> bulletList [plain "d"] ] - ] - , testGroup "entities" - [ "character references" =: - "⟨ ö" =?> para (text "\10216 ö") - , "numeric" =: - ",DD" =?> para (text ",DD") - , "in link title" =: - "[link](/url \"title ⟨ ö ,\")" =?> - para (link "/url" "title \10216 ö ," (text "link")) - ] - , testGroup "citations" - [ "simple" =: - "@item1" =?> para (cite [ - Citation{ citationId = "item1" - , citationPrefix = [] - , citationSuffix = [] - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - ] "@item1") - , "key starts with digit" =: - "@1657:huyghens" =?> para (cite [ - Citation{ citationId = "1657:huyghens" - , citationPrefix = [] - , citationSuffix = [] - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - ] "@1657:huyghens") - ] - , let citation = cite [Citation "cita" [] [] AuthorInText 0 0] (str "@cita") - in testGroup "footnote/link following citation" -- issue #2083 - [ "footnote" =: - T.unlines [ "@cita[^note]" - , "" - , "[^note]: note" ] =?> - para ( - citation <> note (para $ str "note") - ) - , "normal link" =: - "@cita [link](http://www.com)" =?> - para ( - citation <> space <> link "http://www.com" "" (str "link") - ) - , "reference link" =: - T.unlines [ "@cita [link][link]" - , "" - , "[link]: http://www.com" ] =?> - para ( - citation <> space <> link "http://www.com" "" (str "link") - ) - , "short reference link" =: - T.unlines [ "@cita [link]" - , "" - , "[link]: http://www.com" ] =?> - para ( - citation <> space <> link "http://www.com" "" (str "link") - ) - , "implicit header link" =: - T.unlines [ "# Header" - , "@cita [Header]" ] =?> - headerWith ("header",[],[]) 1 (str "Header") <> para ( - citation <> space <> link "#header" "" (str "Header") - ) - , "regular citation" =: - "@cita [foo]" =?> - para ( - cite [Citation "cita" [] [Str "foo"] AuthorInText 0 0] - (str "@cita" <> space <> str "[foo]") - ) - ] - ] diff --git a/test/Tests/Readers/Muse.hs.orig b/test/Tests/Readers/Muse.hs.orig deleted file mode 100644 index 89dbbc345..000000000 --- a/test/Tests/Readers/Muse.hs.orig +++ /dev/null @@ -1,1262 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Muse (tests) where - -import Data.List (intersperse) -import Data.Text (Text) -import qualified Data.Text as T -import Test.Tasty -import Test.Tasty.QuickCheck -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder -import Text.Pandoc.Shared (underlineSpan) -import Text.Pandoc.Walk (walk) - -amuse :: Text -> Pandoc -amuse = purely $ readMuse def { readerExtensions = extensionsFromList [Ext_amuse]} - -emacsMuse :: Text -> Pandoc -emacsMuse = purely $ readMuse def { readerExtensions = emptyExtensions } - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test amuse - -spcSep :: [Inlines] -> Inlines -spcSep = mconcat . intersperse space - --- Tables don't round-trip yet --- -makeRoundTrip :: Block -> Block -makeRoundTrip Table{} = Para [Str "table was here"] -makeRoundTrip (OrderedList (start, LowerAlpha, _) items) = OrderedList (start, Decimal, Period) items -makeRoundTrip (OrderedList (start, UpperAlpha, _) items) = OrderedList (start, Decimal, Period) items -makeRoundTrip x = x - --- Demand that any AST produced by Muse reader and written by Muse writer can be read back exactly the same way. --- Currently we remove tables and compare first rewrite to the second. -roundTrip :: Block -> Bool -roundTrip b = d' == d'' - where d = walk makeRoundTrip $ Pandoc nullMeta [b] - d' = rewrite d - d'' = rewrite d' - rewrite = amuse . T.pack . (++ "\n") . T.unpack . - purely (writeMuse def { writerExtensions = extensionsFromList [Ext_amuse] - , writerWrapText = WrapPreserve - }) - -tests :: [TestTree] -tests = - [ testGroup "Inlines" - [ "Plain String" =: - "Hello, World" =?> - para "Hello, World" - - , "Muse is not XML" =: "<" =?> para "<" - - , "Emphasis" =: - "*Foo bar*" =?> - para (emph . spcSep $ ["Foo", "bar"]) - - , "Comma after closing *" =: - "Foo *bar*, baz" =?> - para ("Foo " <> emph "bar" <> ", baz") - - , "Letter after closing *" =: - "Foo *bar*x baz" =?> - para "Foo *bar*x baz" - - , "Letter before opening *" =: - "Foo x*bar* baz" =?> - para "Foo x*bar* baz" - - , "Emphasis tag" =: - "Foo bar" =?> - para (emph . spcSep $ ["Foo", "bar"]) - - , "Strong" =: - "**Cider**" =?> - para (strong "Cider") - - , "Strong tag" =: "Strong" =?> para (strong "Strong") - - , "Strong Emphasis" =: - "***strength***" =?> - para (strong . emph $ "strength") - - , test emacsMuse "Underline" - ("_Underline_" =?> para (underlineSpan "Underline")) - - , "Superscript tag" =: "Superscript" =?> para (superscript "Superscript") - - , "Subscript tag" =: "Subscript" =?> para (subscript "Subscript") - - , "Strikeout tag" =: "Strikeout" =?> para (strikeout "Strikeout") - - , "Opening inline tags" =: "foo bar baz" =?> para "foo bar baz" - - , "Closing inline tags" =: "foo bar baz" =?> para "foo bar baz" - - , "Tag soup" =: "foo bar baz" =?> para "foo bar baz" - - -- Both inline tags must be within the same paragraph - , "No multiparagraph inline tags" =: - T.unlines [ "First line" - , "Second line" - , "" - , "Fourth line" - ] =?> - para "First line\nSecond line" <> - para "Fourth line" - - , "Linebreak" =: "Line
break" =?> para ("Line" <> linebreak <> "break") - - , "Trailing whitespace inside paragraph" =: - T.unlines [ "First line " -- trailing whitespace here - , "second line" - ] - =?> para "First line\nsecond line" - - , "Non-breaking space" =: "Foo~~bar" =?> para "Foo\160bar" - , "Single ~" =: "Foo~bar" =?> para "Foo~bar" - - , testGroup "Code markup" - [ "Code" =: "=foo(bar)=" =?> para (code "foo(bar)") - - , "Not code" =: "a=b= =c=d" =?> para (text "a=b= =c=d") - - -- Emacs Muse 3.20 parses this as code, we follow Amusewiki - , "Not code if closing = is detached" =: "=this is not a code =" =?> para "=this is not a code =" - - , "Not code if opening = is detached" =: "= this is not a code=" =?> para "= this is not a code=" - - , "Code if followed by comma" =: - "Foo =bar=, baz" =?> - para (text "Foo " <> code "bar" <> text ", baz") - - , "One character code" =: "=c=" =?> para (code "c") - - , "Three = characters is not a code" =: "===" =?> para "===" - - , "Multiline code markup" =: - "foo =bar\nbaz= end of code" =?> - para (text "foo " <> code "bar\nbaz" <> text " end of code") - -{- Emacs Muse 3.20 has a bug: it publishes - -

foo bar - - - - baz foo

- - which is displayed as one paragraph by browsers. - - We follow Amusewiki here and avoid joining paragraphs. - -} - , "No multiparagraph code" =: - T.unlines [ "foo =bar" - , "" - , "baz= foo" - ] =?> - para "foo =bar" <> - para "baz= foo" - - , "Code at the beginning of paragraph but not first column" =: - " - =foo=" =?> bulletList [ para $ code "foo" ] - ] - - , "Code tag" =: "foo(bar)" =?> para (code "foo(bar)") - - , "Verbatim tag" =: "***" =?> para (emph "*") - - , "Verbatim inside code" =: "foo" =?> para (code "foo") - - , "Verbatim tag after text" =: "Foo bar" =?> para "Foo bar" - - , "Class tag" =: "bar" =?> para (spanWith ("", ["foo"], []) "bar") - , "Class tag without name" =: "foobar" =?> para (spanWith ("", [], []) "foobar") - - -- tag should match with the last tag, not verbatim one - , "Nested \"
\" inside em tag" =: "foobar
" =?> para (emph "foobar") - - , testGroup "Links" - [ "Link without description" =: - "[[https://amusewiki.org/]]" =?> - para (link "https://amusewiki.org/" "" (str "https://amusewiki.org/")) - , "Link with description" =: - "[[https://amusewiki.org/][A Muse Wiki]]" =?> - para (link "https://amusewiki.org/" "" (text "A Muse Wiki")) - , "Image" =: - "[[image.jpg]]" =?> - para (image "image.jpg" "" mempty) - , "Image with description" =: - "[[image.jpg][Image]]" =?> - para (image "image.jpg" "" (text "Image")) - , "Image link" =: - "[[URL:image.jpg]]" =?> - para (link "image.jpg" "" (str "image.jpg")) - , "Image link with description" =: - "[[URL:image.jpg][Image]]" =?> - para (link "image.jpg" "" (text "Image")) - -- Implicit links are supported in Emacs Muse, but not in Amusewiki: - -- https://github.com/melmothx/text-amuse/issues/18 - -- - -- This test also makes sure '=' without whitespace is not treated as code markup - , "No implicit links" =: "http://example.org/index.php?action=view&id=1" - =?> para "http://example.org/index.php?action=view&id=1" - ] - - , testGroup "Literal" - [ test emacsMuse "Inline literal" - ("Foolitbar" =?> - para (text "Foo" <> rawInline "html" "lit" <> text "bar")) - ] - ] - - , testGroup "Blocks" - [ testProperty "Round trip" roundTrip, - "Block elements end paragraphs" =: - T.unlines [ "First paragraph" - , "----" - , "Second paragraph" - ] =?> para (text "First paragraph") <> horizontalRule <> para (text "Second paragraph") - , testGroup "Horizontal rule" - [ "Less than 4 dashes is not a horizontal rule" =: "---" =?> para (text "---") - , "4 dashes is a horizontal rule" =: "----" =?> horizontalRule - , "5 dashes is a horizontal rule" =: "-----" =?> horizontalRule - , "4 dashes with spaces is a horizontal rule" =: "---- " =?> horizontalRule - ] - , testGroup "Paragraphs" - [ "Simple paragraph" =: - T.unlines [ "First line" - , "second line." - ] =?> - para "First line\nsecond line." - , "Indented paragraph" =: - T.unlines [ " First line" - , "second line." - ] =?> - para "First line\nsecond line." - -- Emacs Muse starts a blockquote on the second line. - -- We copy Amusewiki behavior and require a blank line to start a blockquote. - , "Indentation in the middle of paragraph" =: - T.unlines [ "First line" - , " second line" - , "third line" - ] =?> - para "First line\nsecond line\nthird line" - , "Quote" =: - " This is a quotation\n" =?> - blockQuote (para "This is a quotation") - , "Indentation does not indicate quote inside quote tag" =: - T.unlines [ "" - , " Not a nested quote" - , "" - ] =?> - blockQuote (para "Not a nested quote") - , "Multiline quote" =: - T.unlines [ " This is a quotation" - , " with a continuation" - ] =?> - blockQuote (para "This is a quotation\nwith a continuation") - , testGroup "Div" - [ "Div without id" =: - T.unlines [ "
" - , "Foo bar" - , "
" - ] =?> - divWith nullAttr (para "Foo bar") - , "Div with id" =: - T.unlines [ "
" - , "Foo bar" - , "
" - ] =?> - divWith ("foo", [], []) (para "Foo bar") - ] - , "Verse" =: - T.unlines [ "> This is" - , "> First stanza" - , ">" -- Emacs produces verbatim ">" here, we follow Amusewiki - , "> And this is" - , "> Second stanza" - , ">" - , "" - , ">" - , "" - , "> Another verse" - , "> is here" - ] =?> - lineBlock [ "This is" - , "First stanza" - , "" - , "And this is" - , "\160\160Second stanza" - , "" - ] <> - lineBlock [ "" ] <> - lineBlock [ "Another verse" - , "\160\160\160is here" - ] - ] - , "Verse in list" =: " - > foo" =?> bulletList [ lineBlock [ "foo" ] ] - , "Verse line starting with emphasis" =: "> *foo* bar" =?> lineBlock [ emph "foo" <> text " bar" ] - , "Multiline verse in list" =: - T.unlines [ " - > foo" - , " > bar" - ] =?> - bulletList [ lineBlock [ "foo", "bar" ] ] - , "Paragraph after verse in list" =: - T.unlines [ " - > foo" - , " bar" - ] =?> - bulletList [ lineBlock [ "foo" ] <> para "bar" ] - , "Empty quote tag" =: - T.unlines [ "" - , "" - ] - =?> blockQuote mempty - , "Quote tag" =: - T.unlines [ "" - , "Hello, world" - , "" - ] - =?> blockQuote (para $ text "Hello, world") - , "Nested quote tag" =: - T.unlines [ "" - , "foo" - , "" - , "bar" - , "" - , "baz" - , "" - ] =?> - blockQuote (para "foo" <> blockQuote (para "bar") <> para "baz") - , "Indented quote inside list" =: - T.unlines [ " - " - , " foo" - , " " - ] =?> - bulletList [ blockQuote (para "foo") ] - , "Verse tag" =: - T.unlines [ "" - , "" - , "Foo bar baz" - , " One two three" - , "" - , "" - ] =?> - lineBlock [ "" - , text "Foo bar baz" - , text "\160\160One two three" - , "" - ] - , "Verse tag with empty line inside" =: - T.unlines [ "" - , "" - , "" - ] =?> - lineBlock [ "" ] - , testGroup "Example" - [ "Braces on separate lines" =: - T.unlines [ "{{{" - , "Example line" - , "}}}" - ] =?> - codeBlock "Example line" - , "Spaces after opening braces" =: - T.unlines [ "{{{ " - , "Example line" - , "}}}" - ] =?> - codeBlock "Example line" - , "One blank line in the beginning" =: - T.unlines [ "{{{" - , "" - , "Example line" - , "}}}" - ] =?> - codeBlock "\nExample line" - , "One blank line in the end" =: - T.unlines [ "{{{" - , "Example line" - , "" - , "}}}" - ] =?> - codeBlock "Example line\n" - -- Amusewiki requires braces to be on separate line, - -- this is an extension. - , "One line" =: - "{{{Example line}}}" =?> - codeBlock "Example line" - ] - , testGroup "Example tag" - [ "Tags on separate lines" =: - T.unlines [ "" - , "Example line" - , "" - ] =?> - codeBlock "Example line" - , "One line" =: - "Example line" =?> - codeBlock "Example line" - , "One blank line in the beginning" =: - T.unlines [ "" - , "" - , "Example line" - , "" - ] =?> - codeBlock "\nExample line" - , "One blank line in the end" =: - T.unlines [ "" - , "Example line" - , "" - , "" - ] =?> - codeBlock "Example line\n" - , "Example inside list" =: - T.unlines [ " - " - , " foo" - , " " - ] =?> - bulletList [ codeBlock "foo" ] - , "Empty example inside list" =: - T.unlines [ " - " - , " " - ] =?> - bulletList [ codeBlock "" ] - , "Example inside list with empty lines" =: - T.unlines [ " - " - , " foo" - , " " - , "" - , " bar" - , "" - , " " - , " baz" - , " " - ] =?> - bulletList [ codeBlock "foo" <> para "bar" <> codeBlock "baz" ] - , "Indented example inside list" =: - T.unlines [ " - " - , " foo" - , " " - ] =?> - bulletList [ codeBlock "foo" ] - , "Example inside definition list" =: - T.unlines [ " foo :: " - , " bar" - , " " - ] =?> - definitionList [ ("foo", [codeBlock "bar"]) ] - , "Example inside list definition with empty lines" =: - T.unlines [ " term :: " - , " foo" - , " " - , "" - , " bar" - , "" - , " " - , " baz" - , " " - ] =?> - definitionList [ ("term", [codeBlock "foo" <> para "bar" <> codeBlock "baz"]) ] - , "Example inside note" =: - T.unlines [ "Foo[1]" - , "" - , "[1] " - , " bar" - , " " - ] =?> - para ("Foo" <> note (codeBlock "bar")) - ] - , testGroup "Literal blocks" - [ test emacsMuse "Literal block" - (T.unlines [ "" - , "\\newpage" - , "" - ] =?> - rawBlock "latex" "\\newpage") - ] - , "Center" =: - T.unlines [ "
" - , "Hello, world" - , "
" - ] =?> - para (text "Hello, world") - , "Right" =: - T.unlines [ "" - , "Hello, world" - , "" - ] =?> - para (text "Hello, world") - , testGroup "Comments" - [ "Comment tag" =: "\nThis is a comment\n" =?> (mempty::Blocks) - , "Line comment" =: "; Comment" =?> (mempty::Blocks) - , "Empty comment" =: ";" =?> (mempty::Blocks) - , "Text after empty comment" =: ";\nfoo" =?> para "foo" -- Make sure we don't consume newline while looking for whitespace - , "Not a comment (does not start with a semicolon)" =: " ; Not a comment" =?> para (text "; Not a comment") - , "Not a comment (has no space after semicolon)" =: ";Not a comment" =?> para (text ";Not a comment") - ] - , testGroup "Headers" - [ "Part" =: - "* First level" =?> - header 1 "First level" - , "Chapter" =: - "** Second level" =?> - header 2 "Second level" - , "Section" =: - "*** Third level" =?> - header 3 "Third level" - , "Subsection" =: - "**** Fourth level" =?> - header 4 "Fourth level" - , "Subsubsection" =: - "***** Fifth level" =?> - header 5 "Fifth level" - , "Whitespace is required after *" =: "**Not a header" =?> para "**Not a header" - , "No headers in footnotes" =: - T.unlines [ "Foo[1]" - , "[1] * Bar" - ] =?> - para (text "Foo" <> - note (para "* Bar")) - , "No headers in quotes" =: - T.unlines [ "" - , "* Hi" - , "" - ] =?> - blockQuote (para "* Hi") - , "Headers consume anchors" =: - T.unlines [ "** Foo" - , "#bar" - ] =?> - headerWith ("bar",[],[]) 2 "Foo" - , "Headers don't consume anchors separated with a blankline" =: - T.unlines [ "** Foo" - , "" - , "#bar" - ] =?> - header 2 "Foo" <> - para (spanWith ("bar", [], []) mempty) - , "Headers terminate lists" =: - T.unlines [ " - foo" - , "* bar" - ] =?> - bulletList [ para "foo" ] <> - header 1 "bar" - ] - , testGroup "Directives" - [ "Title" =: - "#title Document title" =?> - let titleInline = toList "Document title" - meta = setMeta "title" (MetaInlines titleInline) nullMeta - in Pandoc meta mempty - -- Emacs Muse documentation says that "You can use any combination - -- of uppercase and lowercase letters for directives", - -- but also allows '-', which is not documented, but used for disable-tables. - , test emacsMuse "Disable tables" - ("#disable-tables t" =?> - Pandoc (setMeta "disable-tables" (MetaInlines $ toList "t") nullMeta) mempty) - , "Multiple directives" =: - T.unlines [ "#title Document title" - , "#subtitle Document subtitle" - ] =?> - Pandoc (setMeta "title" (MetaInlines $ toList "Document title") $ - setMeta "subtitle" (MetaInlines $ toList "Document subtitle") nullMeta) mempty - , "Multiline directive" =: - T.unlines [ "#title Document title" - , "#notes First line" - , "and second line" - , "#author Name" - ] =?> - Pandoc (setMeta "title" (MetaInlines $ toList "Document title") $ - setMeta "notes" (MetaInlines $ toList "First line\nand second line") $ - setMeta "author" (MetaInlines $ toList "Name") nullMeta) mempty - ] - , testGroup "Anchors" - [ "Anchor" =: - T.unlines [ "; A comment to make sure anchor is not parsed as a directive" - , "#anchor Target" - ] =?> - para (spanWith ("anchor", [], []) mempty <> "Target") - , "Anchor cannot start with a number" =: - T.unlines [ "; A comment to make sure anchor is not parsed as a directive" - , "#0notanchor Target" - ] =?> - para "#0notanchor Target" - , "Not anchor if starts with a space" =: - " #notanchor Target" =?> - para "#notanchor Target" - , "Anchor inside a paragraph" =: - T.unlines [ "Paragraph starts here" - , "#anchor and ends here." - ] =?> - para ("Paragraph starts here\n" <> spanWith ("anchor", [], []) mempty <> "and ends here.") - ] - , testGroup "Footnotes" - [ "Simple footnote" =: - T.unlines [ "Here is a footnote[1]." - , "" - , "[1] Footnote contents" - ] =?> - para (text "Here is a footnote" <> - note (para "Footnote contents") <> - str ".") - , "Recursive footnote" =: - T.unlines [ "Start recursion here[1]" - , "" - , "[1] Recursion continues here[1]" - ] =?> - para (text "Start recursion here" <> - note (para "Recursion continues here[1]")) - , "No zero footnotes" =: - T.unlines [ "Here is a footnote[0]." - , "" - , "[0] Footnote contents" - ] =?> - para "Here is a footnote[0]." <> - para "[0] Footnote contents" - , "Footnotes can't start with zero" =: - T.unlines [ "Here is a footnote[01]." - , "" - , "[01] Footnote contents" - ] =?> - para "Here is a footnote[01]." <> - para "[01] Footnote contents" - , testGroup "Multiparagraph footnotes" - [ "Amusewiki multiparagraph footnotes" =: - T.unlines [ "Multiparagraph[1] footnotes[2]" - , "" - , "[1] First footnote paragraph" - , "" - , " Second footnote paragraph" - , "with continuation" - , "" - , "Not a note" - , "[2] Second footnote" - ] =?> - para (text "Multiparagraph" <> - note (para "First footnote paragraph" <> - para "Second footnote paragraph\nwith continuation") <> - text " footnotes" <> - note (para "Second footnote")) <> - para (text "Not a note") - - -- Verse requires precise indentation, so it is good to test indentation requirements - , "Note continuation with verse" =: - T.unlines [ "Foo[1]" - , "" - , "[1] Bar" - , "" - , " > Baz" - ] =?> - para ("Foo" <> note (para "Bar" <> lineBlock ["Baz"])) - , test emacsMuse "Emacs multiparagraph footnotes" - (T.unlines - [ "First footnote reference[1] and second footnote reference[2]." - , "" - , "[1] First footnote paragraph" - , "" - , "Second footnote" - , "paragraph" - , "" - , "[2] Third footnote paragraph" - , "" - , "Fourth footnote paragraph" - ] =?> - para (text "First footnote reference" <> - note (para "First footnote paragraph" <> - para "Second footnote\nparagraph") <> - text " and second footnote reference" <> - note (para "Third footnote paragraph" <> - para "Fourth footnote paragraph") <> - text ".")) - ] - ] - ] - , testGroup "Tables" - [ "Two cell table" =: - "One | Two" =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [] - [[plain "One", plain "Two"]] - , "Table with multiple words" =: - "One two | three four" =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [] - [[plain "One two", plain "three four"]] - , "Not a table" =: - "One| Two" =?> - para (text "One| Two") - , "Not a table again" =: - "One |Two" =?> - para (text "One |Two") - , "Two line table" =: - T.unlines - [ "One | Two" - , "Three | Four" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [] - [[plain "One", plain "Two"], - [plain "Three", plain "Four"]] - , "Table with one header" =: - T.unlines - [ "First || Second" - , "Third | Fourth" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [plain "First", plain "Second"] - [[plain "Third", plain "Fourth"]] - , "Table with two headers" =: - T.unlines - [ "First || header" - , "Second || header" - , "Foo | bar" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [plain "First", plain "header"] - [[plain "Second", plain "header"], - [plain "Foo", plain "bar"]] - , "Header and footer reordering" =: - T.unlines - [ "Foo ||| bar" - , "Baz || foo" - , "Bar | baz" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [plain "Baz", plain "foo"] - [[plain "Bar", plain "baz"], - [plain "Foo", plain "bar"]] - , "Table with caption" =: - T.unlines - [ "Foo || bar || baz" - , "First | row | here" - , "Second | row | there" - , "|+ Table caption +|" - ] =?> - table (text "Table caption") (replicate 3 (AlignDefault, 0.0)) - [plain "Foo", plain "bar", plain "baz"] - [[plain "First", plain "row", plain "here"], - [plain "Second", plain "row", plain "there"]] - , "Caption without table" =: - "|+ Foo bar baz +|" =?> - table (text "Foo bar baz") [] [] [] - , "Table indented with space" =: - T.unlines - [ " Foo | bar" - , " Baz | foo" - , " Bar | baz" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [] - [[plain "Foo", plain "bar"], - [plain "Baz", plain "foo"], - [plain "Bar", plain "baz"]] - , "Empty cells" =: - T.unlines - [ " | Foo" - , " |" - , " bar |" - , " || baz" - ] =?> - table mempty [(AlignDefault, 0.0), (AlignDefault, 0.0)] - [plain "", plain "baz"] - [[plain "", plain "Foo"], - [plain "", plain ""], - [plain "bar", plain ""]] - ] - , testGroup "Lists" - [ "Bullet list" =: - T.unlines - [ " - Item1" - , "" - , " - Item2" - ] =?> - bulletList [ para "Item1" - , para "Item2" - ] - , "Ordered list" =: - T.unlines - [ " 1. Item1" - , "" - , " 2. Item2" - ] =?> - orderedListWith (1, Decimal, Period) [ para "Item1" - , para "Item2" - ] - , "Ordered list with implicit numbers" =: - T.unlines - [ " 1. Item1" - , "" - , " 1. Item2" - , "" - , " 1. Item3" - ] =?> - orderedListWith (1, Decimal, Period) [ para "Item1" - , para "Item2" - , para "Item3" - ] - , "Ordered list with roman numerals" =: - T.unlines - [ " i. First" - , " ii. Second" - , " iii. Third" - , " iv. Fourth" - ] =?> - orderedListWith (1, LowerRoman, Period) [ para "First" - , para "Second" - , para "Third" - , para "Fourth" - ] - , "Bullet list with empty items" =: - T.unlines - [ " -" - , "" - , " - Item2" - ] =?> - bulletList [ mempty - , para "Item2" - ] - , "Ordered list with empty items" =: - T.unlines - [ " 1." - , "" - , " 2." - , "" - , " 3. Item3" - ] =?> - orderedListWith (1, Decimal, Period) [ mempty - , mempty - , para "Item3" - ] - , "Bullet list with last item empty" =: - T.unlines - [ " -" - , "" - , "foo" - ] =?> - bulletList [ mempty ] <> - para "foo" - , testGroup "Nested lists" - [ "Nested bullet list" =: - T.unlines [ " - Item1" - , " - Item2" - , " - Item3" - , " - Item4" - , " - Item5" - , " - Item6" - ] =?> - bulletList [ para "Item1" <> - bulletList [ para "Item2" <> - bulletList [ para "Item3" ] - , para "Item4" <> - bulletList [ para "Item5" ] - ] - , para "Item6" - ] - , "Nested ordered list" =: - T.unlines [ " 1. Item1" - , " 1. Item2" - , " 1. Item3" - , " 2. Item4" - , " 1. Item5" - , " 2. Item6" - ] =?> - orderedListWith (1, Decimal, Period) [ para "Item1" <> - orderedListWith (1, Decimal, Period) [ para "Item2" <> - orderedListWith (1, Decimal, Period) [ para "Item3" ] - , para "Item4" <> - orderedListWith (1, Decimal, Period) [ para "Item5" ] - ] - , para "Item6" - ] - , "Mixed nested list" =: - T.unlines - [ " - Item1" - , " - Item2" - , " - Item3" - , " - Item4" - , " 1. Nested" - , " 2. Ordered" - , " 3. List" - ] =?> - bulletList [ mconcat [ para "Item1" - , bulletList [ para "Item2" - , para "Item3" - ] - ] - , mconcat [ para "Item4" - , orderedListWith (1, Decimal, Period) [ para "Nested" - , para "Ordered" - , para "List" - ] - ] - ] - , "Text::Amuse includes only one space in list marker" =: - T.unlines - [ " - First item" - , " - Nested item" - ] =?> - bulletList [ para "First item" <> bulletList [ para "Nested item"]] - ] - , "List continuation" =: - T.unlines - [ " - a" - , "" - , " b" - , "" - , " c" - ] =?> - bulletList [ mconcat [ para "a" - , para "b" - , para "c" - ] - ] - , "List continuation afeter nested list" =: - T.unlines - [ " - - foo" - , "" - , " bar" - ] =?> - bulletList [ bulletList [ para "foo" ] <> - para "bar" - ] - -- Emacs Muse allows to separate lists with two or more blank lines. - -- Text::Amuse (Amusewiki engine) always creates a single list as of version 0.82. - -- pandoc follows Emacs Muse behavior - , testGroup "Blank lines" - [ "Blank lines between list items are not required" =: - T.unlines - [ " - Foo" - , " - Bar" - ] =?> - bulletList [ para "Foo" - , para "Bar" - ] - , "One blank line between list items is allowed" =: - T.unlines - [ " - Foo" - , "" - , " - Bar" - ] =?> - bulletList [ para "Foo" - , para "Bar" - ] - , "Two blank lines separate lists" =: - T.unlines - [ " - Foo" - , "" - , "" - , " - Bar" - ] =?> - bulletList [ para "Foo" ] <> bulletList [ para "Bar" ] - , "No blank line after multiline first item" =: - T.unlines - [ " - Foo" - , " bar" - , " - Baz" - ] =?> - bulletList [ para "Foo\nbar" - , para "Baz" - ] - , "One blank line after multiline first item" =: - T.unlines - [ " - Foo" - , " bar" - , "" - , " - Baz" - ] =?> - bulletList [ para "Foo\nbar" - , para "Baz" - ] - , "Two blank lines after multiline first item" =: - T.unlines - [ " - Foo" - , " bar" - , "" - , "" - , " - Baz" - ] =?> - bulletList [ para "Foo\nbar" ] <> bulletList [ para "Baz" ] - , "No blank line after list continuation" =: - T.unlines - [ " - Foo" - , "" - , " bar" - , " - Baz" - ] =?> - bulletList [ para "Foo" <> para "bar" - , para "Baz" - ] - , "One blank line after list continuation" =: - T.unlines - [ " - Foo" - , "" - , " bar" - , "" - , " - Baz" - ] =?> - bulletList [ para "Foo" <> para "bar" - , para "Baz" - ] - , "Two blank lines after list continuation" =: - T.unlines - [ " - Foo" - , "" - , " bar" - , "" - , "" - , " - Baz" - ] =?> - bulletList [ para "Foo" <> para "bar" ] <> bulletList [ para "Baz" ] - , "No blank line after blockquote" =: - T.unlines - [ " - " - , " foo" - , " " - , " - bar" - ] =?> - bulletList [ blockQuote $ para "foo", para "bar" ] - , "One blank line after blockquote" =: - T.unlines - [ " - " - , " foo" - , " " - , "" - , " - bar" - ] =?> - bulletList [ blockQuote $ para "foo", para "bar" ] - , "Two blank lines after blockquote" =: - T.unlines - [ " - " - , " foo" - , " " - , "" - , "" - , " - bar" - ] =?> - bulletList [ blockQuote $ para "foo" ] <> bulletList [ para "bar" ] - , "No blank line after verse" =: - T.unlines - [ " - > foo" - , " - bar" - ] =?> - bulletList [ lineBlock [ "foo" ], para "bar" ] - , "One blank line after verse" =: - T.unlines - [ " - > foo" - , "" - , " - bar" - ] =?> - bulletList [ lineBlock [ "foo" ], para "bar" ] - , "Two blank lines after verse" =: - T.unlines - [ " - > foo" - , "" - , "" - , " - bar" - ] =?> - bulletList [ lineBlock [ "foo" ] ] <> bulletList [ para "bar" ] - ] - -- Test that definition list requires a leading space. - -- Emacs Muse does not require a space, we follow Amusewiki here. - , "Not a definition list" =: - T.unlines - [ "First :: second" - , "Foo :: bar" - ] =?> - para "First :: second\nFoo :: bar" - , test emacsMuse "Emacs Muse definition list" - (T.unlines - [ "First :: second" - , "Foo :: bar" - ] =?> - definitionList [ ("First", [ para "second" ]) - , ("Foo", [ para "bar" ]) - ]) - , "Definition list" =: - T.unlines - [ " First :: second" - , " Foo :: bar" - ] =?> - definitionList [ ("First", [ para "second" ]) - , ("Foo", [ para "bar" ]) - ] - , "Definition list term cannot include newline" =: - T.unlines - [ " Foo" -- "Foo" is not a part of the definition list term - , " Bar :: baz" - ] =?> - para "Foo" <> - definitionList [ ("Bar", [ para "baz" ]) ] - , "One-line definition list" =: " foo :: bar" =?> - definitionList [ ("foo", [ para "bar" ]) ] - , "Definition list term may include single colon" =: - " foo:bar :: baz" =?> - definitionList [ ("foo:bar", [ para "baz" ]) ] - , "Definition list term with emphasis" =: " *Foo* :: bar\n" =?> - definitionList [ (emph "Foo", [ para "bar" ]) ] - , "Definition list term with :: inside code" =: " foo :: :: bar :: baz\n" =?> - definitionList [ ("foo " <> code " :: ", [ para $ "bar " <> code " :: " <> " baz" ]) ] - , "Multi-line definition lists" =: - T.unlines - [ " First term :: Definition of first term" - , "and its continuation." - , " Second term :: Definition of second term." - ] =?> - definitionList [ ("First term", [ para "Definition of first term\nand its continuation." ]) - , ("Second term", [ para "Definition of second term." ]) - ] - , test emacsMuse "Multi-line definition lists from Emacs Muse manual" - (T.unlines - [ "Term1 ::" - , " This is a first definition" - , " And it has two lines;" - , "no, make that three." - , "" - , "Term2 :: This is a second definition" - ] =?> - definitionList [ ("Term1", [ para "This is a first definition\nAnd it has two lines;\nno, make that three."]) - , ("Term2", [ para "This is a second definition"]) - ]) - -- Text::Amuse requires indentation with one space - , "Multi-line definition lists from Emacs Muse manual with initial space" =: - (T.unlines - [ " Term1 ::" - , " This is a first definition" - , " And it has two lines;" - , "no, make that three." - , "" - , " Term2 :: This is a second definition" - ] =?> - definitionList [ ("Term1", [ para "This is a first definition\nAnd it has two lines;\nno, make that three."]) - , ("Term2", [ para "This is a second definition"]) - ]) - , "One-line nested definition list" =: - " Foo :: bar :: baz" =?> - definitionList [ ("Foo", [ definitionList [ ("bar", [ para "baz" ])]])] - , "Nested definition list" =: - T.unlines - [ " First :: Second :: Third" - , " Fourth :: Fifth :: Sixth" - , " Seventh :: Eighth" - ] =?> - definitionList [ ("First", [ definitionList [ ("Second", [ para "Third" ]), - ("Fourth", [ definitionList [ ("Fifth", [ para "Sixth"] ) ] ] ) ] ] ) - , ("Seventh", [ para "Eighth" ]) - ] - , testGroup "Definition lists with multiple descriptions" - [ "Correctly indented second description" =: - T.unlines - [ " First term :: first description" - , " :: second description" - ] =?> - definitionList [ ("First term", [ para "first description" - , para "second description" - ]) - ] - , "Incorrectly indented second description" =: - T.unlines - [ " First term :: first description" - , " :: second description" - ] =?> - definitionList [ ("First term", [ para "first description" ]) - , ("", [ para "second description" ]) - ] - ] - , "Two blank lines separate definition lists" =: - T.unlines - [ " First :: list" - , "" - , "" - , " Second :: list" - ] =?> - definitionList [ ("First", [ para "list" ]) ] <> - definitionList [ ("Second", [ para "list" ]) ] - -- Headers in first column of list continuation are not allowed - , "No headers in list continuation" =: - T.unlines - [ " - Foo" - , "" - , " * Bar" - ] =?> - bulletList [ mconcat [ para "Foo" - , para "* Bar" - ] - ] - , "Bullet list inside a tag" =: - T.unlines - [ "" - , " - First" - , "" - , " - Second" - , "" - , " - Third" - , "" - ] =?> - blockQuote (bulletList [ para "First" - , para "Second" - , para "Third" - ]) - , "Ordered list inside a tag" =: - T.unlines - [ "" - , " 1. First" - , "" - , " 2. Second" - , "" - , " 3. Third" - , "" - ] =?> - blockQuote (orderedListWith (1, Decimal, Period) [ para "First" - , para "Second" - , para "Third" - ]) - -- Regression test for a bug caught by round-trip test - , "Do not consume whitespace while looking for end tag" =: - T.unlines - [ "" - , " - " - , " foo" - , " " - , " bar" -- Do not consume whitespace while looking for arbitraritly indented - , "" - ] =?> - blockQuote (bulletList [ blockQuote $ para "foo" ] <> para "bar") - - , "Unclosed quote tag" =: - T.unlines - [ "" - , "" - , "" - , "" - ] =?> - para "" <> lineBlock [ "" ] - - , "Unclosed quote tag inside list" =: - T.unlines - [ " - " - , " " - , " " - , " " - ] =?> - bulletList [ para "" <> lineBlock [ "" ] ] - - -- Allowing indented closing tags is dangerous, - -- as they may terminate lists - , "No indented closing tags" =: - T.unlines - [ "" - , "" - , " - Foo" - , "" - , " " - , "" - , " bar" - , "" - , " " - , " " - , " " - ] =?> - para "" <> bulletList [ para "Foo" <> para "" <> para "bar" <> lineBlock [ "" ] ] - ] - ] diff --git a/test/Tests/Readers/Odt.hs.orig b/test/Tests/Readers/Odt.hs.orig deleted file mode 100644 index 4b7058cf9..000000000 --- a/test/Tests/Readers/Odt.hs.orig +++ /dev/null @@ -1,170 +0,0 @@ -module Tests.Readers.Odt (tests) where - -import Control.Monad (liftM) -import qualified Data.ByteString as BS -import qualified Data.ByteString.Lazy as B -import qualified Data.Map as M -import Data.Text (unpack) -import System.IO.Unsafe (unsafePerformIO) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import qualified Text.Pandoc.UTF8 as UTF8 - -defopts :: ReaderOptions -defopts = def{ readerExtensions = getDefaultExtensions "odt" } - -tests :: [TestTree] -tests = testsComparingToMarkdown ++ testsComparingToNative - -testsComparingToMarkdown :: [TestTree] -testsComparingToMarkdown = map nameToTest namesOfTestsComparingToMarkdown - where nameToTest name = createTest - compareOdtToMarkdown - name - (toOdtPath name) - (toMarkdownPath name) - toOdtPath name = "odt/odt/" ++ name ++ ".odt" - toMarkdownPath name = "odt/markdown/" ++ name ++ ".md" - -testsComparingToNative :: [TestTree] -testsComparingToNative = map nameToTest namesOfTestsComparingToNative - where nameToTest name = createTest - compareOdtToNative - name - (toOdtPath name) - (toNativePath name) - toOdtPath name = "odt/odt/" ++ name ++ ".odt" - toNativePath name = "odt/native/" ++ name ++ ".native" - - -newtype NoNormPandoc = NoNormPandoc {unNoNorm :: Pandoc} - deriving ( Show ) - -instance ToString NoNormPandoc where - toString d = unpack $ - purely (writeNative def{ writerTemplate = s }) $ toPandoc d - where s = case d of - NoNormPandoc (Pandoc (Meta m) _) - | M.null m -> Nothing - | otherwise -> Just "" -- need this for Meta output - -instance ToPandoc NoNormPandoc where - toPandoc = unNoNorm - -getNoNormVia :: (a -> Pandoc) -> String -> Either PandocError a -> NoNormPandoc -getNoNormVia _ readerName (Left _) = error (readerName ++ " reader failed") -getNoNormVia f _ (Right a) = NoNormPandoc (f a) - -type TestCreator = ReaderOptions - -> FilePath -> FilePath - -> IO (NoNormPandoc, NoNormPandoc) - -compareOdtToNative :: TestCreator -compareOdtToNative opts odtPath nativePath = do - nativeFile <- UTF8.toText <$> BS.readFile nativePath - odtFile <- B.readFile odtPath - native <- getNoNormVia id "native" <$> runIO (readNative def nativeFile) - odt <- getNoNormVia id "odt" <$> runIO (readOdt opts odtFile) - return (odt,native) - -compareOdtToMarkdown :: TestCreator -compareOdtToMarkdown opts odtPath markdownPath = do - markdownFile <- UTF8.toText <$> BS.readFile markdownPath - odtFile <- B.readFile odtPath - markdown <- getNoNormVia id "markdown" <$> - runIO (readMarkdown def{ readerExtensions = pandocExtensions } - markdownFile) - odt <- getNoNormVia id "odt" <$> runIO (readOdt opts odtFile) - return (odt,markdown) - - -createTest :: TestCreator - -> TestName - -> FilePath -> FilePath - -> TestTree -createTest creator name path1 path2 = - unsafePerformIO $ liftM (test id name) (creator defopts path1 path2) - -{- --- - -getMedia :: FilePath -> FilePath -> IO (Maybe B.ByteString) -getMedia archivePath mediaPath = do - zf <- B.readFile archivePath >>= return . toArchive - return $ findEntryByPath ("Pictures/" ++ mediaPath) zf >>= (Just . fromEntry) - -compareMediaPathIO :: FilePath -> MediaBag -> FilePath -> IO Bool -compareMediaPathIO mediaPath mediaBag odtPath = do - odtMedia <- getMedia odtPath mediaPath - let mbBS = case lookupMedia mediaPath mediaBag of - Just (_, bs) -> bs - Nothing -> error ("couldn't find " ++ - mediaPath ++ - " in media bag") - odtBS = case odtMedia of - Just bs -> bs - Nothing -> error ("couldn't find " ++ - mediaPath ++ - " in media bag") - return $ mbBS == odtBS - -compareMediaBagIO :: FilePath -> IO Bool -compareMediaBagIO odtFile = do - df <- B.readFile odtFile - let (_, mb) = readOdt def df - bools <- mapM - (\(fp, _, _) -> compareMediaPathIO fp mb odtFile) - (mediaDirectory mb) - return $ and bools - -testMediaBagIO :: String -> FilePath -> IO TestTree -testMediaBagIO name odtFile = do - outcome <- compareMediaBagIO odtFile - return $ testCase name (assertBool - ("Media didn't match media bag in file " ++ odtFile) - outcome) - -testMediaBag :: String -> FilePath -> TestTree -testMediaBag name odtFile = buildTest $ testMediaBagIO name odtFile --} --- - - - -namesOfTestsComparingToMarkdown :: [ String ] -namesOfTestsComparingToMarkdown = [ "bold" --- , "citation" - , "endnote" - , "externalLink" - , "footnote" - , "headers" --- , "horizontalRule" - , "italic" --- , "listBlocks" - , "paragraph" - , "strikeout" --- , "trackedChanges" - , "underlined" - ] - -namesOfTestsComparingToNative :: [ String ] -namesOfTestsComparingToNative = [ "blockquote" - , "image" - , "imageIndex" - , "imageWithCaption" - , "inlinedCode" - , "orderedListMixed" - , "orderedListRoman" - , "orderedListSimple" - , "referenceToChapter" - , "referenceToListItem" - , "referenceToText" - , "simpleTable" - , "simpleTableWithCaption" --- , "table" - , "textMixedStyles" - , "tableWithContents" - , "unicode" - , "unorderedList" - ] diff --git a/test/Tests/Readers/Org.hs.orig b/test/Tests/Readers/Org.hs.orig deleted file mode 100644 index de7f14e32..000000000 --- a/test/Tests/Readers/Org.hs.orig +++ /dev/null @@ -1,16 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org (tests) where - -import Test.Tasty (TestTree, testGroup) -import qualified Tests.Readers.Org.Block as Block -import qualified Tests.Readers.Org.Directive as Directive -import qualified Tests.Readers.Org.Inline as Inline -import qualified Tests.Readers.Org.Meta as Meta - -tests :: [TestTree] -tests = - [ testGroup "Inlines" Inline.tests - , testGroup "Basic Blocks" Block.tests - , testGroup "Meta Information" Meta.tests - , testGroup "Directives" Directive.tests - ] diff --git a/test/Tests/Readers/Org/Block.hs.orig b/test/Tests/Readers/Org/Block.hs.orig deleted file mode 100644 index 15dc63554..000000000 --- a/test/Tests/Readers/Org/Block.hs.orig +++ /dev/null @@ -1,192 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block (tests) where - -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc.Builder -import qualified Data.Text as T -import qualified Tests.Readers.Org.Block.CodeBlock as CodeBlock -import qualified Tests.Readers.Org.Block.Figure as Figure -import qualified Tests.Readers.Org.Block.Header as Header -import qualified Tests.Readers.Org.Block.List as List -import qualified Tests.Readers.Org.Block.Table as Table - -tests :: [TestTree] -tests = - [ "Paragraph" =: - "Paragraph\n" =?> - para "Paragraph" - - , "Paragraph starting with an asterisk" =: - "*five" =?> - para "*five" - - , "Paragraph containing asterisk at beginning of line" =: - T.unlines [ "lucky" - , "*star" - ] =?> - para ("lucky" <> softbreak <> "*star") - - , "Example block" =: - T.unlines [ ": echo hello" - , ": echo dear tester" - ] =?> - codeBlockWith ("", ["example"], []) "echo hello\necho dear tester\n" - - , "Example block surrounded by text" =: - T.unlines [ "Greetings" - , ": echo hello" - , ": echo dear tester" - , "Bye" - ] =?> - mconcat [ para "Greetings" - , codeBlockWith ("", ["example"], []) - "echo hello\necho dear tester\n" - , para "Bye" - ] - - , "Horizontal Rule" =: - T.unlines [ "before" - , "-----" - , "after" - ] =?> - mconcat [ para "before" - , horizontalRule - , para "after" - ] - - , "Not a Horizontal Rule" =: - "----- em and en dash" =?> - para "\8212\8211 em and en dash" - - , "Comment Block" =: - T.unlines [ "#+BEGIN_COMMENT" - , "stuff" - , "bla" - , "#+END_COMMENT"] =?> - (mempty::Blocks) - - , testGroup "Blocks and fragments" - [ "HTML block" =: - T.unlines [ "#+BEGIN_HTML" - , "" - , "#+END_HTML" - ] =?> - rawBlock "html" "\n" - - , "Quote block" =: - T.unlines [ "#+BEGIN_QUOTE" - , "/Niemand/ hat die Absicht, eine Mauer zu errichten!" - , "#+END_QUOTE" - ] =?> - blockQuote (para (spcSep [ emph "Niemand", "hat", "die", "Absicht," - , "eine", "Mauer", "zu", "errichten!" - ])) - - , "Verse block" =: - T.unlines [ "The first lines of Goethe's /Faust/:" - , "#+begin_verse" - , "Habe nun, ach! Philosophie," - , "Juristerei und Medizin," - , "Und leider auch Theologie!" - , "Durchaus studiert, mit heißem Bemühn." - , "#+end_verse" - ] =?> - mconcat - [ para $ spcSep [ "The", "first", "lines", "of" - , "Goethe's", emph "Faust" <> ":"] - , lineBlock - [ "Habe nun, ach! Philosophie," - , "Juristerei und Medizin," - , "Und leider auch Theologie!" - , "Durchaus studiert, mit heißem Bemühn." - ] - ] - - , "Verse block with blank lines" =: - T.unlines [ "#+BEGIN_VERSE" - , "foo" - , "" - , "bar" - , "#+END_VERSE" - ] =?> - lineBlock [ "foo", mempty, "bar" ] - - , "Verse block with varying indentation" =: - T.unlines [ "#+BEGIN_VERSE" - , " hello darkness" - , "my old friend" - , "#+END_VERSE" - ] =?> - lineBlock [ "\160\160hello darkness", "my old friend" ] - - , "Raw block LaTeX" =: - T.unlines [ "#+BEGIN_LaTeX" - , "The category $\\cat{Set}$ is adhesive." - , "#+END_LaTeX" - ] =?> - rawBlock "latex" "The category $\\cat{Set}$ is adhesive.\n" - - , "Raw LaTeX line" =: - "#+LATEX: \\let\\foo\\bar" =?> - rawBlock "latex" "\\let\\foo\\bar" - - , "Raw Beamer line" =: - "#+beamer: \\pause" =?> - rawBlock "beamer" "\\pause" - - , "Raw HTML line" =: - "#+HTML: " =?> - rawBlock "html" "" - - , "Export block HTML" =: - T.unlines [ "#+BEGIN_export html" - , "Hello, World!" - , "#+END_export" - ] =?> - rawBlock "html" "Hello, World!\n" - - , "LaTeX fragment" =: - T.unlines [ "\\begin{equation}" - , "X_i = \\begin{cases}" - , " G_{\\alpha(i)} & \\text{if }\\alpha(i-1) = \\alpha(i)\\\\" - , " C_{\\alpha(i)} & \\text{otherwise}" - , " \\end{cases}" - , "\\end{equation}" - ] =?> - rawBlock "latex" - (unlines [ "\\begin{equation}" - , "X_i = \\begin{cases}" - , " G_{\\alpha(i)} & \\text{if }\\alpha(i-1) =" <> - " \\alpha(i)\\\\" - , " C_{\\alpha(i)} & \\text{otherwise}" - , " \\end{cases}" - , "\\end{equation}" - ]) - - , "Convert blank lines in blocks to single newlines" =: - T.unlines [ "#+begin_html" - , "" - , "boring" - , "" - , "#+end_html" - ] =?> - rawBlock "html" "\nboring\n\n" - - , "Accept `ATTR_HTML` attributes for generic block" =: - T.unlines [ "#+ATTR_HTML: :title hello, world :id test :class fun code" - , "#+BEGIN_TEST" - , "nonsense" - , "#+END_TEST" - ] =?> - let attr = ("test", ["fun", "code", "TEST"], [("title", "hello, world")]) - in divWith attr (para "nonsense") - ] - - , testGroup "Headers" Header.tests - , testGroup "Figures" Figure.tests - , testGroup "Lists" List.tests - , testGroup "CodeBlocks" CodeBlock.tests - , testGroup "Tables" Table.tests - ] diff --git a/test/Tests/Readers/Org/Block/CodeBlock.hs.orig b/test/Tests/Readers/Org/Block/CodeBlock.hs.orig deleted file mode 100644 index 8fa822089..000000000 --- a/test/Tests/Readers/Org/Block/CodeBlock.hs.orig +++ /dev/null @@ -1,194 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block.CodeBlock (tests) where - -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc.Builder -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "Source block" =: - T.unlines [ " #+BEGIN_SRC haskell" - , " main = putStrLn greeting" - , " where greeting = \"moin\"" - , " #+END_SRC" ] =?> - let attr' = ("", ["haskell"], []) - code' = "main = putStrLn greeting\n" <> - " where greeting = \"moin\"\n" - in codeBlockWith attr' code' - - , "Source block with indented code" =: - T.unlines [ " #+BEGIN_SRC haskell" - , " main = putStrLn greeting" - , " where greeting = \"moin\"" - , " #+END_SRC" ] =?> - let attr' = ("", ["haskell"], []) - code' = "main = putStrLn greeting\n" <> - " where greeting = \"moin\"\n" - in codeBlockWith attr' code' - - , "Source block with tab-indented code" =: - T.unlines [ "\t#+BEGIN_SRC haskell" - , "\tmain = putStrLn greeting" - , "\t where greeting = \"moin\"" - , "\t#+END_SRC" ] =?> - let attr' = ("", ["haskell"], []) - code' = "main = putStrLn greeting\n" <> - " where greeting = \"moin\"\n" - in codeBlockWith attr' code' - - , "Empty source block" =: - T.unlines [ " #+BEGIN_SRC haskell" - , " #+END_SRC" ] =?> - let attr' = ("", ["haskell"], []) - code' = "" - in codeBlockWith attr' code' - - , "Source block between paragraphs" =: - T.unlines [ "Low German greeting" - , " #+BEGIN_SRC haskell" - , " main = putStrLn greeting" - , " where greeting = \"Moin!\"" - , " #+END_SRC" ] =?> - let attr' = ("", ["haskell"], []) - code' = "main = putStrLn greeting\n" <> - " where greeting = \"Moin!\"\n" - in mconcat [ para $ spcSep [ "Low", "German", "greeting" ] - , codeBlockWith attr' code' - ] - , "Source block with babel arguments" =: - T.unlines [ "#+BEGIN_SRC emacs-lisp :exports both" - , "(progn (message \"Hello, World!\")" - , " (+ 23 42))" - , "#+END_SRC" ] =?> - let classes = [ "commonlisp" ] -- as kate doesn't know emacs-lisp syntax - params = [ ("org-language", "emacs-lisp") - , ("exports", "both") - ] - code' = unlines [ "(progn (message \"Hello, World!\")" - , " (+ 23 42))" ] - in codeBlockWith ("", classes, params) code' - - , "Source block with results and :exports both" =: - T.unlines [ "#+BEGIN_SRC emacs-lisp :exports both" - , "(progn (message \"Hello, World!\")" - , " (+ 23 42))" - , "#+END_SRC" - , "" - , "#+RESULTS:" - , ": 65"] =?> - let classes = [ "commonlisp" ] - params = [ ("org-language", "emacs-lisp") - , ("exports", "both") - ] - code' = unlines [ "(progn (message \"Hello, World!\")" - , " (+ 23 42))" ] - results' = "65\n" - in codeBlockWith ("", classes, params) code' - <> - codeBlockWith ("", ["example"], []) results' - - , "Source block with results and :exports code" =: - T.unlines [ "#+BEGIN_SRC emacs-lisp :exports code" - , "(progn (message \"Hello, World!\")" - , " (+ 23 42))" - , "#+END_SRC" - , "" - , "#+RESULTS:" - , ": 65" ] =?> - let classes = [ "commonlisp" ] - params = [ ("org-language", "emacs-lisp") - , ("exports", "code") - ] - code' = unlines [ "(progn (message \"Hello, World!\")" - , " (+ 23 42))" ] - in codeBlockWith ("", classes, params) code' - - , "Source block with results and :exports results" =: - T.unlines [ "#+BEGIN_SRC emacs-lisp :exports results" - , "(progn (message \"Hello, World!\")" - , " (+ 23 42))" - , "#+END_SRC" - , "" - , "#+RESULTS:" - , ": 65" ] =?> - let results' = "65\n" - in codeBlockWith ("", ["example"], []) results' - - , "Source block with results and :exports none" =: - T.unlines [ "#+BEGIN_SRC emacs-lisp :exports none" - , "(progn (message \"Hello, World!\")" - , " (+ 23 42))" - , "#+END_SRC" - , "" - , "#+RESULTS:" - , ": 65" ] =?> - (mempty :: Blocks) - - , "Source block with toggling header arguments" =: - T.unlines [ "#+BEGIN_SRC sh :noeval" - , "echo $HOME" - , "#+END_SRC" - ] =?> - let classes = [ "bash" ] - params = [ ("org-language", "sh"), ("noeval", "yes") ] - in codeBlockWith ("", classes, params) "echo $HOME\n" - - , "Source block with line number switch" =: - T.unlines [ "#+BEGIN_SRC sh -n 10" - , ":() { :|:& };:" - , "#+END_SRC" - ] =?> - let classes = [ "bash", "numberLines" ] - params = [ ("org-language", "sh"), ("startFrom", "10") ] - in codeBlockWith ("", classes, params) ":() { :|:& };:\n" - - , "Source block with multi-word parameter values" =: - T.unlines [ "#+BEGIN_SRC dot :cmdline -Kdot -Tpng " - , "digraph { id [label=\"ID\"] }" - , "#+END_SRC" - ] =?> - let classes = [ "dot" ] - params = [ ("cmdline", "-Kdot -Tpng") ] - in codeBlockWith ("", classes, params) "digraph { id [label=\"ID\"] }\n" - - , "Example block" =: - T.unlines [ "#+begin_example" - , "A chosen representation of" - , "a rule." - , "#+eND_exAMPle" - ] =?> - codeBlockWith ("", ["example"], []) - "A chosen representation of\na rule.\n" - - , "Code block with caption" =: - T.unlines [ "#+CAPTION: Functor laws in Haskell" - , "#+NAME: functor-laws" - , "#+BEGIN_SRC haskell" - , "fmap id = id" - , "fmap (p . q) = (fmap p) . (fmap q)" - , "#+END_SRC" - ] =?> - divWith - nullAttr - (mappend - (plain $ spanWith ("", ["label"], []) - (spcSep [ "Functor", "laws", "in", "Haskell" ])) - (codeBlockWith ("functor-laws", ["haskell"], []) - (unlines [ "fmap id = id" - , "fmap (p . q) = (fmap p) . (fmap q)" - ]))) - - , "Non-letter chars in source block parameters" =: - T.unlines [ "#+BEGIN_SRC C :tangle xxxx.c :city Zürich" - , "code body" - , "#+END_SRC" - ] =?> - let params = [ ("org-language", "C") - , ("tangle", "xxxx.c") - , ("city", "Zürich") - ] - in codeBlockWith ( "", ["c"], params) "code body\n" - ] diff --git a/test/Tests/Readers/Org/Block/Figure.hs.orig b/test/Tests/Readers/Org/Block/Figure.hs.orig deleted file mode 100644 index cae6ef179..000000000 --- a/test/Tests/Readers/Org/Block/Figure.hs.orig +++ /dev/null @@ -1,57 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block.Figure (tests) where - -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:)) -import Text.Pandoc.Builder (image, imageWith, para) -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "Figure" =: - T.unlines [ "#+caption: A very courageous man." - , "#+name: goodguy" - , "[[file:edward.jpg]]" - ] =?> - para (image "edward.jpg" "fig:goodguy" "A very courageous man.") - - , "Figure with no name" =: - T.unlines [ "#+caption: I've been through the desert on this" - , "[[file:horse.png]]" - ] =?> - para (image "horse.png" "fig:" "I've been through the desert on this") - - , "Figure with `fig:` prefix in name" =: - T.unlines [ "#+caption: Used as a metapher in evolutionary biology." - , "#+name: fig:redqueen" - , "[[./the-red-queen.jpg]]" - ] =?> - para (image "./the-red-queen.jpg" "fig:redqueen" - "Used as a metapher in evolutionary biology.") - - , "Figure with HTML attributes" =: - T.unlines [ "#+CAPTION: mah brain just explodid" - , "#+NAME: lambdacat" - , "#+ATTR_HTML: :style color: blue :role button" - , "[[file:lambdacat.jpg]]" - ] =?> - let kv = [("style", "color: blue"), ("role", "button")] - name = "fig:lambdacat" - caption = "mah brain just explodid" - in para (imageWith (mempty, mempty, kv) "lambdacat.jpg" name caption) - - , "Labelled figure" =: - T.unlines [ "#+CAPTION: My figure" - , "#+LABEL: fig:myfig" - , "[[file:blub.png]]" - ] =?> - let attr = ("fig:myfig", mempty, mempty) - in para (imageWith attr "blub.png" "fig:" "My figure") - - , "Figure with empty caption" =: - T.unlines [ "#+CAPTION:" - , "[[file:guess.jpg]]" - ] =?> - para (image "guess.jpg" "fig:" "") - ] diff --git a/test/Tests/Readers/Org/Block/Header.hs.orig b/test/Tests/Readers/Org/Block/Header.hs.orig deleted file mode 100644 index e8ad88558..000000000 --- a/test/Tests/Readers/Org/Block/Header.hs.orig +++ /dev/null @@ -1,182 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block.Header (tests) where - -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep, tagSpan) -import Text.Pandoc.Builder -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "First Level Header" =: - "* Headline\n" =?> - headerWith ("headline", [], []) 1 "Headline" - - , "Third Level Header" =: - "*** Third Level Headline\n" =?> - headerWith ("third-level-headline", [], []) - 3 - ("Third" <> space <> "Level" <> space <> "Headline") - - , "Compact Headers with Paragraph" =: - T.unlines [ "* First Level" - , "** Second Level" - , " Text" - ] =?> - mconcat [ headerWith ("first-level", [], []) - 1 - ("First" <> space <> "Level") - , headerWith ("second-level", [], []) - 2 - ("Second" <> space <> "Level") - , para "Text" - ] - - , "Separated Headers with Paragraph" =: - T.unlines [ "* First Level" - , "" - , "** Second Level" - , "" - , " Text" - ] =?> - mconcat [ headerWith ("first-level", [], []) - 1 - ("First" <> space <> "Level") - , headerWith ("second-level", [], []) - 2 - ("Second" <> space <> "Level") - , para "Text" - ] - - , "Headers not preceded by a blank line" =: - T.unlines [ "** eat dinner" - , "Spaghetti and meatballs tonight." - , "** walk dog" - ] =?> - mconcat [ headerWith ("eat-dinner", [], []) - 2 - ("eat" <> space <> "dinner") - , para $ spcSep [ "Spaghetti", "and", "meatballs", "tonight." ] - , headerWith ("walk-dog", [], []) - 2 - ("walk" <> space <> "dog") - ] - - , testGroup "Todo keywords" - [ "Header with known todo keyword" =: - "* TODO header" =?> - let todoSpan = spanWith ("", ["todo", "TODO"], []) "TODO" - in headerWith ("header", [], []) 1 (todoSpan <> space <> "header") - - , "Header marked as done" =: - "* DONE header" =?> - let todoSpan = spanWith ("", ["done", "DONE"], []) "DONE" - in headerWith ("header", [], []) 1 (todoSpan <> space <> "header") - - , "Header with unknown todo keyword" =: - "* WAITING header" =?> - headerWith ("waiting-header", [], []) 1 "WAITING header" - - , "Custom todo keywords" =: - T.unlines [ "#+TODO: WAITING CANCELLED" - , "* WAITING compile" - , "* CANCELLED lunch" - ] =?> - let todoSpan = spanWith ("", ["todo", "WAITING"], []) "WAITING" - doneSpan = spanWith ("", ["done", "CANCELLED"], []) "CANCELLED" - in headerWith ("compile", [], []) 1 (todoSpan <> space <> "compile") - <> headerWith ("lunch", [], []) 1 (doneSpan <> space <> "lunch") - - , "Custom todo keywords with multiple done-states" =: - T.unlines [ "#+TODO: WAITING | DONE CANCELLED " - , "* WAITING compile" - , "* CANCELLED lunch" - , "* DONE todo-feature" - ] =?> - let waiting = spanWith ("", ["todo", "WAITING"], []) "WAITING" - cancelled = spanWith ("", ["done", "CANCELLED"], []) "CANCELLED" - done = spanWith ("", ["done", "DONE"], []) "DONE" - in headerWith ("compile", [], []) 1 (waiting <> space <> "compile") - <> headerWith ("lunch", [], []) 1 (cancelled <> space <> "lunch") - <> headerWith ("todo-feature", [], []) 1 (done <> space <> "todo-feature") - ] - - , "Tagged headers" =: - T.unlines [ "* Personal :PERSONAL:" - , "** Call Mom :@PHONE:" - , "** Call John :@PHONE:JOHN: " - ] =?> - mconcat [ headerWith ("personal", [], []) - 1 - ("Personal " <> tagSpan "PERSONAL") - , headerWith ("call-mom", [], []) - 2 - ("Call Mom " <> tagSpan "@PHONE") - , headerWith ("call-john", [], []) - 2 - ("Call John " <> tagSpan "@PHONE" <> "\160" <> tagSpan "JOHN") - ] - - , "Untagged header containing colons" =: - "* This: is not: tagged" =?> - headerWith ("this-is-not-tagged", [], []) 1 "This: is not: tagged" - - , "Header starting with strokeout text" =: - T.unlines [ "foo" - , "" - , "* +thing+ other thing" - ] =?> - mconcat [ para "foo" - , headerWith ("thing-other-thing", [], []) - 1 - (strikeout "thing" <> " other thing") - ] - - , "Comment Trees" =: - T.unlines [ "* COMMENT A comment tree" - , " Not much going on here" - , "** This will be dropped" - , "* Comment tree above" - ] =?> - headerWith ("comment-tree-above", [], []) 1 "Comment tree above" - - , "Nothing but a COMMENT header" =: - "* COMMENT Test" =?> - (mempty::Blocks) - - , "Tree with :noexport:" =: - T.unlines [ "* Should be ignored :archive:noexport:old:" - , "** Old stuff" - , " This is not going to be exported" - ] =?> - (mempty::Blocks) - - , "Subtree with :noexport:" =: - T.unlines [ "* Exported" - , "** This isn't exported :noexport:" - , "*** This neither" - , "** But this is" - ] =?> - mconcat [ headerWith ("exported", [], []) 1 "Exported" - , headerWith ("but-this-is", [], []) 2 "But this is" - ] - - , "Preferences are treated as header attributes" =: - T.unlines [ "* foo" - , " :PROPERTIES:" - , " :custom_id: fubar" - , " :bar: baz" - , " :END:" - ] =?> - headerWith ("fubar", [], [("bar", "baz")]) 1 "foo" - - - , "Headers marked with a unnumbered property get a class of the same name" =: - T.unlines [ "* Not numbered" - , " :PROPERTIES:" - , " :UNNUMBERED: t" - , " :END:" - ] =?> - headerWith ("not-numbered", ["unnumbered"], []) 1 "Not numbered" - ] diff --git a/test/Tests/Readers/Org/Block/List.hs.orig b/test/Tests/Readers/Org/Block/List.hs.orig deleted file mode 100644 index 343682a80..000000000 --- a/test/Tests/Readers/Org/Block/List.hs.orig +++ /dev/null @@ -1,244 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block.List (tests) where - -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc.Builder -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "Simple Bullet Lists" =: - ("- Item1\n" <> - "- Item2\n") =?> - bulletList [ plain "Item1" - , plain "Item2" - ] - - , "Indented Bullet Lists" =: - (" - Item1\n" <> - " - Item2\n") =?> - bulletList [ plain "Item1" - , plain "Item2" - ] - - , "Unindented *" =: - ("- Item1\n" <> - "* Item2\n") =?> - bulletList [ plain "Item1" - ] <> - headerWith ("item2", [], []) 1 "Item2" - - , "Multi-line Bullet Lists" =: - ("- *Fat\n" <> - " Tony*\n" <> - "- /Sideshow\n" <> - " Bob/") =?> - bulletList [ plain $ strong ("Fat" <> softbreak <> "Tony") - , plain $ emph ("Sideshow" <> softbreak <> "Bob") - ] - - , "Nested Bullet Lists" =: - ("- Discovery\n" <> - " + One More Time\n" <> - " + Harder, Better, Faster, Stronger\n" <> - "- Homework\n" <> - " + Around the World\n"<> - "- Human After All\n" <> - " + Technologic\n" <> - " + Robot Rock\n") =?> - bulletList [ mconcat - [ plain "Discovery" - , bulletList [ plain ("One" <> space <> - "More" <> space <> - "Time") - , plain ("Harder," <> space <> - "Better," <> space <> - "Faster," <> space <> - "Stronger") - ] - ] - , mconcat - [ plain "Homework" - , bulletList [ plain ("Around" <> space <> - "the" <> space <> - "World") - ] - ] - , mconcat - [ plain ("Human" <> space <> "After" <> space <> "All") - , bulletList [ plain "Technologic" - , plain ("Robot" <> space <> "Rock") - ] - ] - ] - - , "Bullet List with Decreasing Indent" =: - " - Discovery\n\ - \ - Human After All\n" =?> - mconcat [ bulletList [ plain "Discovery" ] - , bulletList [ plain ("Human" <> space <> "After" <> space <> "All")] - ] - - , "Header follows Bullet List" =: - " - Discovery\n\ - \ - Human After All\n\ - \* Homework" =?> - mconcat [ bulletList [ plain "Discovery" - , plain ("Human" <> space <> "After" <> space <> "All") - ] - , headerWith ("homework", [], []) 1 "Homework" - ] - - , "Bullet List Unindented with trailing Header" =: - "- Discovery\n\ - \- Homework\n\ - \* NotValidListItem" =?> - mconcat [ bulletList [ plain "Discovery" - , plain "Homework" - ] - , headerWith ("notvalidlistitem", [], []) 1 "NotValidListItem" - ] - - , "Empty bullet points" =: - T.unlines [ "-" - , "- " - ] =?> - bulletList [ plain "", plain "" ] - - , "Simple Ordered List" =: - ("1. Item1\n" <> - "2. Item2\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ plain "Item1" - , plain "Item2" - ] - in orderedListWith listStyle listStructure - - , "Simple Ordered List with Parens" =: - ("1) Item1\n" <> - "2) Item2\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ plain "Item1" - , plain "Item2" - ] - in orderedListWith listStyle listStructure - - , "Indented Ordered List" =: - (" 1. Item1\n" <> - " 2. Item2\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ plain "Item1" - , plain "Item2" - ] - in orderedListWith listStyle listStructure - - , "Empty ordered list item" =: - T.unlines [ "1." - , "3. " - ] =?> - orderedList [ plain "", plain "" ] - - , "Nested Ordered Lists" =: - ("1. One\n" <> - " 1. One-One\n" <> - " 2. One-Two\n" <> - "2. Two\n" <> - " 1. Two-One\n"<> - " 2. Two-Two\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ mconcat - [ plain "One" - , orderedList [ plain "One-One" - , plain "One-Two" - ] - ] - , mconcat - [ plain "Two" - , orderedList [ plain "Two-One" - , plain "Two-Two" - ] - ] - ] - in orderedListWith listStyle listStructure - - , "Ordered List in Bullet List" =: - ("- Emacs\n" <> - " 1. Org\n") =?> - bulletList [ plain "Emacs" <> - orderedList [ plain "Org"] - ] - - , "Bullet List in Ordered List" =: - ("1. GNU\n" <> - " - Freedom\n") =?> - orderedList [ plain "GNU" <> bulletList [ plain "Freedom" ] ] - - , "Definition List" =: - T.unlines [ "- PLL :: phase-locked loop" - , "- TTL ::" - , " transistor-transistor logic" - , "- PSK :: phase-shift keying" - , "" - , " a digital modulation scheme" - ] =?> - definitionList [ ("PLL", [ plain $ "phase-locked" <> space <> "loop" ]) - , ("TTL", [ plain $ "transistor-transistor" <> space <> - "logic" ]) - , ("PSK", [ mconcat - [ para $ "phase-shift" <> space <> "keying" - , para $ spcSep [ "a", "digital" - , "modulation", "scheme" ] - ] - ]) - ] - , "Definition list with multi-word term" =: - " - Elijah Wood :: He plays Frodo" =?> - definitionList [ ("Elijah" <> space <> "Wood", [plain $ "He" <> space <> "plays" <> space <> "Frodo"])] - , "Compact definition list" =: - T.unlines [ "- ATP :: adenosine 5' triphosphate" - , "- DNA :: deoxyribonucleic acid" - , "- PCR :: polymerase chain reaction" - , "" - ] =?> - definitionList - [ ("ATP", [ plain $ spcSep [ "adenosine", "5'", "triphosphate" ] ]) - , ("DNA", [ plain $ spcSep [ "deoxyribonucleic", "acid" ] ]) - , ("PCR", [ plain $ spcSep [ "polymerase", "chain", "reaction" ] ]) - ] - - , "Definition List With Trailing Header" =: - "- definition :: list\n\ - \- cool :: defs\n\ - \* header" =?> - mconcat [ definitionList [ ("definition", [plain "list"]) - , ("cool", [plain "defs"]) - ] - , headerWith ("header", [], []) 1 "header" - ] - - , "Definition lists double-colon markers must be surrounded by whitespace" =: - "- std::cout" =?> - bulletList [ plain "std::cout" ] - - , "Loose bullet list" =: - T.unlines [ "- apple" - , "" - , "- orange" - , "" - , "- peach" - ] =?> - bulletList [ para "apple" - , para "orange" - , para "peach" - ] - - , "Recognize preceding paragraphs in non-list contexts" =: - T.unlines [ "CLOSED: [2015-10-19 Mon 15:03]" - , "- Note taken on [2015-10-19 Mon 13:24]" - ] =?> - mconcat [ para "CLOSED: [2015-10-19 Mon 15:03]" - , bulletList [ plain "Note taken on [2015-10-19 Mon 13:24]" ] - ] - ] diff --git a/test/Tests/Readers/Org/Block/Table.hs.orig b/test/Tests/Readers/Org/Block/Table.hs.orig deleted file mode 100644 index db6e756f8..000000000 --- a/test/Tests/Readers/Org/Block/Table.hs.orig +++ /dev/null @@ -1,150 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Block.Table (tests) where - -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc.Builder -import qualified Data.Text as T - -simpleTable' :: Int - -> [Blocks] - -> [[Blocks]] - -> Blocks -simpleTable' n = table "" (replicate n (AlignDefault, 0.0)) - -tests :: [TestTree] -tests = - [ "Single cell table" =: - "|Test|" =?> - simpleTable' 1 mempty [[plain "Test"]] - - , "Multi cell table" =: - "| One | Two |" =?> - simpleTable' 2 mempty [ [ plain "One", plain "Two" ] ] - - , "Multi line table" =: - T.unlines [ "| One |" - , "| Two |" - , "| Three |" - ] =?> - simpleTable' 1 mempty - [ [ plain "One" ] - , [ plain "Two" ] - , [ plain "Three" ] - ] - - , "Empty table" =: - "||" =?> - simpleTable' 1 mempty [[mempty]] - - , "Glider Table" =: - T.unlines [ "| 1 | 0 | 0 |" - , "| 0 | 1 | 1 |" - , "| 1 | 1 | 0 |" - ] =?> - simpleTable' 3 mempty - [ [ plain "1", plain "0", plain "0" ] - , [ plain "0", plain "1", plain "1" ] - , [ plain "1", plain "1", plain "0" ] - ] - - , "Table between Paragraphs" =: - T.unlines [ "Before" - , "| One | Two |" - , "After" - ] =?> - mconcat [ para "Before" - , simpleTable' 2 mempty [ [ plain "One", plain "Two" ] ] - , para "After" - ] - - , "Table with Header" =: - T.unlines [ "| Species | Status |" - , "|--------------+--------------|" - , "| cervisiae | domesticated |" - , "| paradoxus | wild |" - ] =?> - simpleTable [ plain "Species", plain "Status" ] - [ [ plain "cervisiae", plain "domesticated" ] - , [ plain "paradoxus", plain "wild" ] - ] - - , "Table with final hline" =: - T.unlines [ "| cervisiae | domesticated |" - , "| paradoxus | wild |" - , "|--------------+--------------|" - ] =?> - simpleTable' 2 mempty - [ [ plain "cervisiae", plain "domesticated" ] - , [ plain "paradoxus", plain "wild" ] - ] - - , "Table in a box" =: - T.unlines [ "|---------|---------|" - , "| static | Haskell |" - , "| dynamic | Lisp |" - , "|---------+---------|" - ] =?> - simpleTable' 2 mempty - [ [ plain "static", plain "Haskell" ] - , [ plain "dynamic", plain "Lisp" ] - ] - - , "Table with empty cells" =: - "|||c|" =?> - simpleTable' 3 mempty [[mempty, mempty, plain "c"]] - - , "Table with empty rows" =: - T.unlines [ "| first |" - , "| |" - , "| third |" - ] =?> - simpleTable' 1 mempty [[plain "first"], [mempty], [plain "third"]] - - , "Table with alignment row" =: - T.unlines [ "| Numbers | Text | More |" - , "| | | |" - , "| 1 | One | foo |" - , "| 2 | Two | bar |" - ] =?> - table "" (zip [AlignCenter, AlignRight, AlignDefault] [0, 0, 0]) - [] - [ [ plain "Numbers", plain "Text", plain "More" ] - , [ plain "1" , plain "One" , plain "foo" ] - , [ plain "2" , plain "Two" , plain "bar" ] - ] - - , "Pipe within text doesn't start a table" =: - "Ceci n'est pas une | pipe " =?> - para (spcSep [ "Ceci", "n'est", "pas", "une", "|", "pipe" ]) - - , "Missing pipe at end of row" =: - "|incomplete-but-valid" =?> - simpleTable' 1 mempty [ [ plain "incomplete-but-valid" ] ] - - , "Table with differing row lengths" =: - T.unlines [ "| Numbers | Text " - , "|-" - , "| | |" - , "| 1 | One | foo |" - , "| 2" - ] =?> - table "" (zip [AlignCenter, AlignRight] [0, 0]) - [ plain "Numbers", plain "Text" ] - [ [ plain "1" , plain "One" , plain "foo" ] - , [ plain "2" ] - ] - - , "Table with caption" =: - T.unlines [ "#+CAPTION: Hitchhiker's Multiplication Table" - , "| x | 6 |" - , "| 9 | 42 |" - ] =?> - table "Hitchhiker's Multiplication Table" - [(AlignDefault, 0), (AlignDefault, 0)] - [] - [ [ plain "x", plain "6" ] - , [ plain "9", plain "42" ] - ] - ] diff --git a/test/Tests/Readers/Org/Directive.hs.orig b/test/Tests/Readers/Org/Directive.hs.orig deleted file mode 100644 index 7e2c0fb8d..000000000 --- a/test/Tests/Readers/Org/Directive.hs.orig +++ /dev/null @@ -1,199 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Directive (tests) where - -import Data.Time (UTCTime (UTCTime), secondsToDiffTime) -import Data.Time.Calendar (Day (ModifiedJulianDay)) -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>), ToString, purely, test) -import Tests.Readers.Org.Shared ((=:), tagSpan) -import Text.Pandoc -import Text.Pandoc.Builder -import qualified Data.ByteString as BS -import qualified Data.Text as T - -testWithFiles :: (ToString c) - => [(FilePath, BS.ByteString)] - -> String -- ^ name of test case - -> (T.Text, c) -- ^ (input, expected value) - -> TestTree -testWithFiles fileDefs = test (orgWithFiles fileDefs) - where -orgWithFiles :: [(FilePath, BS.ByteString)] -> T.Text -> Pandoc -orgWithFiles fileDefs input = - let readOrg' = readOrg def{ readerExtensions = getDefaultExtensions "org" } - in flip purely input $ \inp -> do - modifyPureState (\st -> st { stFiles = files fileDefs }) - readOrg' inp - - -files :: [(FilePath, BS.ByteString)] -> FileTree -files fileDefs = - let dummyTime = UTCTime (ModifiedJulianDay 125) (secondsToDiffTime 0) - in foldr (\(fp, bs) -> insertInFileTree fp (FileInfo dummyTime bs)) - mempty fileDefs - -tests :: [TestTree] -tests = - [ testGroup "export options" - [ "disable simple sub/superscript syntax" =: - T.unlines [ "#+OPTIONS: ^:nil" - , "a^b" - ] =?> - para "a^b" - - , "directly select drawers to be exported" =: - T.unlines [ "#+OPTIONS: d:(\"IMPORTANT\")" - , ":IMPORTANT:" - , "23" - , ":END:" - , ":BORING:" - , "very boring" - , ":END:" - ] =?> - divWith (mempty, ["IMPORTANT", "drawer"], mempty) (para "23") - - , "exclude drawers from being exported" =: - T.unlines [ "#+OPTIONS: d:(not \"BORING\")" - , ":IMPORTANT:" - , "5" - , ":END:" - , ":BORING:" - , "very boring" - , ":END:" - ] =?> - divWith (mempty, ["IMPORTANT", "drawer"], mempty) (para "5") - - , "don't include archive trees" =: - T.unlines [ "#+OPTIONS: arch:nil" - , "* old :ARCHIVE:" - ] =?> - (mempty ::Blocks) - - , "include complete archive trees" =: - T.unlines [ "#+OPTIONS: arch:t" - , "* old :ARCHIVE:" - , " boring" - ] =?> - mconcat [ headerWith ("old", [], mempty) 1 - ("old" <> space <> tagSpan "ARCHIVE") - , para "boring" - ] - - , "include archive tree header only" =: - T.unlines [ "#+OPTIONS: arch:headline" - , "* old :ARCHIVE:" - , " boring" - ] =?> - headerWith ("old", [], mempty) 1 ("old" <> space <> tagSpan "ARCHIVE") - - , "limit headline depth" =: - T.unlines [ "#+OPTIONS: H:2" - , "* top-level section" - , "** subsection" - , "*** list item 1" - , "*** list item 2" - ] =?> - mconcat [ headerWith ("top-level-section", [], []) 1 "top-level section" - , headerWith ("subsection", [], []) 2 "subsection" - , orderedList [ para "list item 1", para "list item 2" ] - ] - - , "turn all headlines into lists" =: - T.unlines [ "#+OPTIONS: H:0" - , "first block" - , "* top-level section 1" - , "** subsection" - , "* top-level section 2" - ] =?> - mconcat [ para "first block" - , orderedList - [ para "top-level section 1" <> - orderedList [ para "subsection" ] - , para "top-level section 2" ] - ] - - , "preserve linebreaks as hard breaks" =: - T.unlines [ "#+OPTIONS: \\n:t" - , "first" - , "second" - ] =?> - para ("first" <> linebreak <> "second") - - , "disable author export" =: - T.unlines [ "#+OPTIONS: author:nil" - , "#+AUTHOR: ShyGuy" - ] =?> - Pandoc nullMeta mempty - - , "disable creator export" =: - T.unlines [ "#+OPTIONS: creator:nil" - , "#+creator: The Architect" - ] =?> - Pandoc nullMeta mempty - - , "disable email export" =: - T.unlines [ "#+OPTIONS: email:nil" - , "#+email: no-mail-please@example.com" - ] =?> - Pandoc nullMeta mempty - - , "disable inclusion of todo keywords" =: - T.unlines [ "#+OPTIONS: todo:nil" - , "** DONE todo export" - ] =?> - headerWith ("todo-export", [], []) 2 "todo export" - - , "remove tags from headlines" =: - T.unlines [ "#+OPTIONS: tags:nil" - , "* Headline :hello:world:" - ] =?> - headerWith ("headline", [], mempty) 1 "Headline" - ] - - , testGroup "Include" - [ testWithFiles [("./other.org", "content of other file\n")] - "file inclusion" - (T.unlines [ "#+include: \"other.org\"" ] =?> - plain "content of other file") - - , testWithFiles [("./world.org", "World\n\n")] - "Included file belongs to item" - (T.unlines [ "- Hello,\n #+include: \"world.org\"" ] =?> - bulletList [para "Hello," <> para "World"]) - - , testWithFiles [("./level3.org", "*** Level3\n\n")] - "Default include preserves level" - (T.unlines [ "#+include: \"level3.org\"" ] =?> - headerWith ("level3", [], []) 3 "Level3") - - , testWithFiles [("./level3.org", "*** Level3\n\n")] - "Minlevel shifts level" - (T.unlines [ "#+include: \"level3.org\" :minlevel 1" ] =?> - headerWith ("level3", [], []) 1 "Level3") - - , testWithFiles [("./src.hs", "putStrLn outString\n")] - "Include file as source code snippet" - (T.unlines [ "#+include: \"src.hs\" src haskell" ] =?> - codeBlockWith ("", ["haskell"], []) "putStrLn outString\n") - - , testWithFiles [("./export-latex.org", "\\emph{Hello}\n")] - "Include file as export snippet" - (T.unlines [ "#+include: \"export-latex.org\" export latex" ] =?> - rawBlock "latex" "\\emph{Hello}\n") - - , testWithFiles [("./subdir/foo-bar.latex", "foo\n"), - ("./hello.lisp", "(print \"Hello!\")\n") - ] - "include directive is limited to one line" - (T.unlines [ "#+INCLUDE: \"hello.lisp\" src lisp" - , "#+include: \"subdir/foo-bar.latex\" export latex" - , "bar" - ] =?> - mconcat - [ codeBlockWith ("", ["lisp"], []) "(print \"Hello!\")\n" - , rawBlock "latex" "foo\n" - , para "bar" - ] - ) - ] - ] diff --git a/test/Tests/Readers/Org/Inline.hs.orig b/test/Tests/Readers/Org/Inline.hs.orig deleted file mode 100644 index 9bf5556d2..000000000 --- a/test/Tests/Readers/Org/Inline.hs.orig +++ /dev/null @@ -1,352 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Inline (tests) where - -import Data.List (intersperse) -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc.Builder -import Text.Pandoc.Shared (underlineSpan) -import qualified Data.Text as T -import qualified Tests.Readers.Org.Inline.Citation as Citation -import qualified Tests.Readers.Org.Inline.Note as Note -import qualified Tests.Readers.Org.Inline.Smart as Smart - -tests :: [TestTree] -tests = - [ "Plain String" =: - "Hello, World" =?> - para (spcSep [ "Hello,", "World" ]) - - , "Emphasis" =: - "/Planet Punk/" =?> - para (emph . spcSep $ ["Planet", "Punk"]) - - , "Strong" =: - "*Cider*" =?> - para (strong "Cider") - - , "Strong Emphasis" =: - "/*strength*/" =?> - para (emph . strong $ "strength") - - , "Emphasized Strong preceded by space" =: - " */super/*" =?> - para (strong . emph $ "super") - - , "Underline" =: - "_underline_" =?> - para (underlineSpan "underline") - - , "Strikeout" =: - "+Kill Bill+" =?> - para (strikeout . spcSep $ [ "Kill", "Bill" ]) - - , "Verbatim" =: - "=Robot.rock()=" =?> - para (code "Robot.rock()") - - , "Code" =: - "~word for word~" =?> - para (code "word for word") - - , "Math $..$" =: - "$E=mc^2$" =?> - para (math "E=mc^2") - - , "Math $$..$$" =: - "$$E=mc^2$$" =?> - para (displayMath "E=mc^2") - - , "Math \\[..\\]" =: - "\\[E=ℎν\\]" =?> - para (displayMath "E=ℎν") - - , "Math \\(..\\)" =: - "\\(σ_x σ_p ≥ \\frac{ℏ}{2}\\)" =?> - para (math "σ_x σ_p ≥ \\frac{ℏ}{2}") - - , "Symbol" =: - "A * symbol" =?> - para (str "A" <> space <> str "*" <> space <> "symbol") - - , "Superscript simple expression" =: - "2^-λ" =?> - para (str "2" <> superscript "-λ") - - , "Superscript multi char" =: - "2^{n-1}" =?> - para (str "2" <> superscript "n-1") - - , "Subscript simple expression" =: - "a_n" =?> - para (str "a" <> subscript "n") - - , "Subscript multi char" =: - "a_{n+1}" =?> - para (str "a" <> subscript "n+1") - - , "Linebreak" =: - "line \\\\ \nbreak" =?> - para ("line" <> linebreak <> "break") - - , "Inline note" =: - "[fn::Schreib mir eine E-Mail]" =?> - para (note $ para "Schreib mir eine E-Mail") - - , "Markup-chars not occuring on word break are symbols" =: - T.unlines [ "this+that+ +so+on" - , "seven*eight* nine*" - , "+not+funny+" - ] =?> - para ("this+that+ +so+on" <> softbreak <> - "seven*eight* nine*" <> softbreak <> - strikeout "not+funny") - - , "No empty markup" =: - "// ** __ <> == ~~ $$" =?> - para (spcSep [ "//", "**", "__", "<>", "==", "~~", "$$" ]) - - , "Adherence to Org's rules for markup borders" =: - "/t/& a/ / ./r/ (*l*) /e/! /b/." =?> - para (spcSep [ emph $ "t/&" <> space <> "a" - , "/" - , "./r/" - , "(" <> strong "l" <> ")" - , emph "e" <> "!" - , emph "b" <> "." - ]) - - , "Quotes are allowed border chars" =: - "/'yep/ *sure\"*" =?> - para (emph "'yep" <> space <> strong "sure\"") - - , "Spaces are forbidden border chars" =: - "/nada /" =?> - para "/nada /" - - , "Markup should work properly after a blank line" =: - T.unlines ["foo", "", "/bar/"] =?> - para (text "foo") <> - para (emph $ text "bar") - - , "Inline math must stay within three lines" =: - T.unlines [ "$a", "b", "c$", "$d", "e", "f", "g$" ] =?> - para (math "a\nb\nc" <> softbreak <> - "$d" <> softbreak <> "e" <> softbreak <> - "f" <> softbreak <> "g$") - - , "Single-character math" =: - "$a$ $b$! $c$?" =?> - para (spcSep [ math "a" - , "$b$!" - , math "c" <> "?" - ]) - - , "Markup may not span more than two lines" =: - "/this *is +totally\nnice+ not*\nemph/" =?> - para ("/this" <> space <> - strong ("is" <> space <> - strikeout ("totally" <> - softbreak <> "nice") <> - space <> "not") <> - softbreak <> "emph/") - - , "Sub- and superscript expressions" =: - T.unlines [ "a_(a(b)(c)d)" - , "e^(f(g)h)" - , "i_(jk)l)" - , "m^()n" - , "o_{p{q{}r}}" - , "s^{t{u}v}" - , "w_{xy}z}" - , "1^{}2" - , "3_{{}}" - , "4^(a(*b(c*)d))" - ] =?> - para (mconcat $ intersperse softbreak - [ "a" <> subscript "(a(b)(c)d)" - , "e" <> superscript "(f(g)h)" - , "i" <> subscript "(jk)" <> "l)" - , "m" <> superscript "()" <> "n" - , "o" <> subscript "p{q{}r}" - , "s" <> superscript "t{u}v" - , "w" <> subscript "xy" <> "z}" - , "1" <> superscript "" <> "2" - , "3" <> subscript "{}" - , "4" <> superscript ("(a(" <> strong "b(c" <> ")d))") - ]) - , "Verbatim text can contain equal signes (=)" =: - "=is_subst = True=" =?> - para (code "is_subst = True") - - , testGroup "Images" - [ "Image" =: - "[[./sunset.jpg]]" =?> - para (image "./sunset.jpg" "" "") - - , "Image with explicit file: prefix" =: - "[[file:sunrise.jpg]]" =?> - para (image "sunrise.jpg" "" "") - - , "Multiple images within a paragraph" =: - T.unlines [ "[[file:sunrise.jpg]]" - , "[[file:sunset.jpg]]" - ] =?> - para ((image "sunrise.jpg" "" "") - <> softbreak - <> (image "sunset.jpg" "" "")) - - , "Image with html attributes" =: - T.unlines [ "#+ATTR_HTML: :width 50%" - , "[[file:guinea-pig.gif]]" - ] =?> - para (imageWith ("", [], [("width", "50%")]) "guinea-pig.gif" "" "") - ] - - , "Explicit link" =: - "[[http://zeitlens.com/][pseudo-random /nonsense/]]" =?> - para (link "http://zeitlens.com/" "" - ("pseudo-random" <> space <> emph "nonsense")) - - , "Self-link" =: - "[[http://zeitlens.com/]]" =?> - para (link "http://zeitlens.com/" "" "http://zeitlens.com/") - - , "Absolute file link" =: - "[[/url][hi]]" =?> - para (link "file:///url" "" "hi") - - , "Link to file in parent directory" =: - "[[../file.txt][moin]]" =?> - para (link "../file.txt" "" "moin") - - , "Empty link (for gitit interop)" =: - "[[][New Link]]" =?> - para (link "" "" "New Link") - - , "Image link" =: - "[[sunset.png][file:dusk.svg]]" =?> - para (link "sunset.png" "" (image "dusk.svg" "" "")) - - , "Image link with non-image target" =: - "[[http://example.com][./logo.png]]" =?> - para (link "http://example.com" "" (image "./logo.png" "" "")) - - , "Plain link" =: - "Posts on http://zeitlens.com/ can be funny at times." =?> - para (spcSep [ "Posts", "on" - , link "http://zeitlens.com/" "" "http://zeitlens.com/" - , "can", "be", "funny", "at", "times." - ]) - - , "Angle link" =: - "Look at for fnords." =?> - para (spcSep [ "Look", "at" - , link "http://moltkeplatz.de" "" "http://moltkeplatz.de" - , "for", "fnords." - ]) - - , "Absolute file link" =: - "[[file:///etc/passwd][passwd]]" =?> - para (link "file:///etc/passwd" "" "passwd") - - , "File link" =: - "[[file:target][title]]" =?> - para (link "target" "" "title") - - , "Anchor" =: - "<> Link here later." =?> - para (spanWith ("anchor", [], []) mempty <> - "Link" <> space <> "here" <> space <> "later.") - - , "Inline code block" =: - "src_emacs-lisp{(message \"Hello\")}" =?> - para (codeWith ( "" - , [ "commonlisp" ] - , [ ("org-language", "emacs-lisp") ]) - "(message \"Hello\")") - - , "Inline code block with arguments" =: - "src_sh[:export both :results output]{echo 'Hello, World'}" =?> - para (codeWith ( "" - , [ "bash" ] - , [ ("org-language", "sh") - , ("export", "both") - , ("results", "output") - ] - ) - "echo 'Hello, World'") - - , "Inline code block with toggle" =: - "src_sh[:toggle]{echo $HOME}" =?> - para (codeWith ( "" - , [ "bash" ] - , [ ("org-language", "sh") - , ("toggle", "yes") - ] - ) - "echo $HOME") - - , "Inline LaTeX symbol" =: - "\\dots" =?> - para "…" - - , "Inline LaTeX command" =: - "\\textit{Emphasised}" =?> - para (emph "Emphasised") - - , "Inline LaTeX command with spaces" =: - "\\emph{Emphasis mine}" =?> - para (emph "Emphasis mine") - - , "Inline LaTeX math symbol" =: - "\\tau" =?> - para (emph "τ") - - , "Unknown inline LaTeX command" =: - "\\notacommand{foo}" =?> - para (rawInline "latex" "\\notacommand{foo}") - - , "Export snippet" =: - "@@html:M-x org-agenda@@" =?> - para (rawInline "html" "M-x org-agenda") - - , "MathML symbol in LaTeX-style" =: - "There is a hackerspace in Lübeck, Germany, called nbsp (unicode symbol: '\\nbsp')." =?> - para "There is a hackerspace in Lübeck, Germany, called nbsp (unicode symbol: ' ')." - - , "MathML symbol in LaTeX-style, including braces" =: - "\\Aacute{}stor" =?> - para "Ástor" - - , "MathML copy sign" =: - "\\copy" =?> - para "©" - - , "MathML symbols, space separated" =: - "\\ForAll \\Auml" =?> - para "∀ Ä" - - , "Macro" =: - T.unlines [ "#+MACRO: HELLO /Hello, $1/" - , "{{{HELLO(World)}}}" - ] =?> - para (emph "Hello, World") - - , "Macro repeting its argument" =: - T.unlines [ "#+MACRO: HELLO $1$1" - , "{{{HELLO(moin)}}}" - ] =?> - para "moinmoin" - - , "Macro called with too few arguments" =: - T.unlines [ "#+MACRO: HELLO Foo $1 $2 Bar" - , "{{{HELLO()}}}" - ] =?> - para "Foo Bar" - - , testGroup "Citations" Citation.tests - , testGroup "Footnotes" Note.tests - , testGroup "Smart punctuation" Smart.tests - ] diff --git a/test/Tests/Readers/Org/Inline/Citation.hs.orig b/test/Tests/Readers/Org/Inline/Citation.hs.orig deleted file mode 100644 index d7e38a6b0..000000000 --- a/test/Tests/Readers/Org/Inline/Citation.hs.orig +++ /dev/null @@ -1,179 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Inline.Citation (tests) where - -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:)) -import Text.Pandoc.Builder - -tests :: [TestTree] -tests = - [ testGroup "Markdown-style citations" - [ "Citation" =: - "[@nonexistent]" =?> - let citation = Citation - { citationId = "nonexistent" - , citationPrefix = [] - , citationSuffix = [] - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0} - in (para $ cite [citation] "[@nonexistent]") - - , "Citation containing text" =: - "[see @item1 p. 34-35]" =?> - let citation = Citation - { citationId = "item1" - , citationPrefix = [Str "see"] - , citationSuffix = [Space ,Str "p.",Space,Str "34-35"] - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0} - in (para $ cite [citation] "[see @item1 p. 34-35]") - ] - - , testGroup "org-ref citations" - [ "simple citation" =: - "cite:pandoc" =?> - let citation = Citation - { citationId = "pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "cite:pandoc") - - , "simple citation with underscores" =: - "cite:pandoc_org_ref" =?> - let citation = Citation - { citationId = "pandoc_org_ref" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "cite:pandoc_org_ref") - - , "simple citation succeeded by comma" =: - "cite:pandoc," =?> - let citation = Citation - { citationId = "pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "cite:pandoc" <> str ",") - - , "simple citation succeeded by dot" =: - "cite:pandoc." =?> - let citation = Citation - { citationId = "pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "cite:pandoc" <> str ".") - - , "simple citation succeeded by colon" =: - "cite:pandoc:" =?> - let citation = Citation - { citationId = "pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = AuthorInText - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "cite:pandoc" <> str ":") - - , "simple citep citation" =: - "citep:pandoc" =?> - let citation = Citation - { citationId = "pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "citep:pandoc") - - , "extended citation" =: - "[[citep:Dominik201408][See page 20::, for example]]" =?> - let citation = Citation - { citationId = "Dominik201408" - , citationPrefix = toList "See page 20" - , citationSuffix = toList ", for example" - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0 - } - in (para $ cite [citation] "[[citep:Dominik201408][See page 20::, for example]]") - ] - - , testGroup "Berkeley-style citations" $ - let pandocCite = Citation - { citationId = "Pandoc" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0 - } - pandocInText = pandocCite { citationMode = AuthorInText } - dominikCite = Citation - { citationId = "Dominik201408" - , citationPrefix = mempty - , citationSuffix = mempty - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0 - } - dominikInText = dominikCite { citationMode = AuthorInText } - in - [ "Berkeley-style in-text citation" =: - "See @Dominik201408." =?> - para ("See " - <> cite [dominikInText] "@Dominik201408" - <> ".") - - , "Berkeley-style parenthetical citation list" =: - "[(cite): see; @Dominik201408;also @Pandoc; and others]" =?> - let pandocCite' = pandocCite { - citationPrefix = toList "also" - , citationSuffix = toList "and others" - } - dominikCite' = dominikCite { - citationPrefix = toList "see" - } - in (para $ cite [dominikCite', pandocCite'] "") - - , "Berkeley-style plain citation list" =: - "[cite: See; @Dominik201408; and @Pandoc; and others]" =?> - let pandocCite' = pandocInText { citationPrefix = toList "and" } - in (para $ "See " - <> cite [dominikInText] "" - <> "," <> space - <> cite [pandocCite'] "" - <> "," <> space <> "and others") - ] - - , "LaTeX citation" =: - "\\cite{Coffee}" =?> - let citation = Citation - { citationId = "Coffee" - , citationPrefix = [] - , citationSuffix = [] - , citationMode = NormalCitation - , citationNoteNum = 0 - , citationHash = 0} - in (para . cite [citation] $ rawInline "latex" "\\cite{Coffee}") - - ] diff --git a/test/Tests/Readers/Org/Inline/Note.hs.orig b/test/Tests/Readers/Org/Inline/Note.hs.orig deleted file mode 100644 index 9eb1d02d6..000000000 --- a/test/Tests/Readers/Org/Inline/Note.hs.orig +++ /dev/null @@ -1,86 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Inline.Note (tests) where - -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:)) -import Text.Pandoc.Builder -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "Footnote" =: - T.unlines [ "A footnote[1]" - , "" - , "[1] First paragraph" - , "" - , "second paragraph" - ] =?> - para (mconcat - [ "A", space, "footnote" - , note $ mconcat [ para ("First" <> space <> "paragraph") - , para ("second" <> space <> "paragraph") - ] - ]) - - , "Two footnotes" =: - T.unlines [ "Footnotes[fn:1][fn:2]" - , "" - , "[fn:1] First note." - , "" - , "[fn:2] Second note." - ] =?> - para (mconcat - [ "Footnotes" - , note $ para ("First" <> space <> "note.") - , note $ para ("Second" <> space <> "note.") - ]) - - , "Emphasized text before footnote" =: - T.unlines [ "/text/[fn:1]" - , "" - , "[fn:1] unicorn" - ] =?> - para (mconcat - [ emph "text" - , note . para $ "unicorn" - ]) - - , "Footnote that starts with emphasized text" =: - T.unlines [ "text[fn:1]" - , "" - , "[fn:1] /emphasized/" - ] =?> - para (mconcat - [ "text" - , note . para $ emph "emphasized" - ]) - - , "Footnote followed by header" =: - T.unlines [ "Another note[fn:yay]" - , "" - , "[fn:yay] This is great!" - , "" - , "** Headline" - ] =?> - mconcat - [ para (mconcat - [ "Another", space, "note" - , note $ para ("This" <> space <> "is" <> space <> "great!") - ]) - , headerWith ("headline", [], []) 2 "Headline" - ] - - , "Footnote followed by two blank lines" =: - T.unlines [ "footnote[fn:blanklines]" - , "" - , "[fn:blanklines] followed by blank lines" - , "" - , "" - , "next" - ] =?> - mconcat - [ para ("footnote" <> note (para "followed by blank lines")) - , para "next" - ] - ] diff --git a/test/Tests/Readers/Org/Inline/Smart.hs.orig b/test/Tests/Readers/Org/Inline/Smart.hs.orig deleted file mode 100644 index 77f10699d..000000000 --- a/test/Tests/Readers/Org/Inline/Smart.hs.orig +++ /dev/null @@ -1,46 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Inline.Smart (tests) where - -import Data.Text (Text) -import Test.Tasty (TestTree) -import Tests.Helpers ((=?>), purely, test) -import Text.Pandoc (ReaderOptions (readerExtensions), - Extension (Ext_smart), def, enableExtension, - getDefaultExtensions, readOrg) -import Text.Pandoc.Builder - -orgSmart :: Text -> Pandoc -orgSmart = purely $ - let extensionsSmart = enableExtension Ext_smart (getDefaultExtensions "org") - in readOrg def{ readerExtensions = extensionsSmart } - -tests :: [TestTree] -tests = - [ test orgSmart "quote before ellipses" - ("'...hi'" - =?> para (singleQuoted "…hi")) - - , test orgSmart "apostrophe before emph" - ("D'oh! A l'/aide/!" - =?> para ("D’oh! A l’" <> emph "aide" <> "!")) - - , test orgSmart "apostrophe in French" - ("À l'arrivée de la guerre, le thème de l'«impossibilité du socialisme»" - =?> para "À l’arrivée de la guerre, le thème de l’«impossibilité du socialisme»") - - , test orgSmart "Quotes cannot occur at the end of emphasized text" - ("/say \"yes\"/" =?> - para ("/say" <> space <> doubleQuoted "yes" <> "/")) - - , test orgSmart "Dashes are allowed at the borders of emphasis'" - ("/foo---/" =?> - para (emph "foo—")) - - , test orgSmart "Single quotes can be followed by emphasized text" - ("Singles on the '/meat market/'" =?> - para ("Singles on the " <> singleQuoted (emph "meat market"))) - - , test orgSmart "Double quotes can be followed by emphasized text" - ("Double income, no kids: \"/DINK/\"" =?> - para ("Double income, no kids: " <> doubleQuoted (emph "DINK"))) - ] diff --git a/test/Tests/Readers/Org/Meta.hs.orig b/test/Tests/Readers/Org/Meta.hs.orig deleted file mode 100644 index 6bd1b02e7..000000000 --- a/test/Tests/Readers/Org/Meta.hs.orig +++ /dev/null @@ -1,191 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Org.Meta (tests) where - -import Test.Tasty (TestTree, testGroup) -import Tests.Helpers ((=?>)) -import Tests.Readers.Org.Shared ((=:), spcSep) -import Text.Pandoc -import Text.Pandoc.Builder -import qualified Data.Text as T - -tests :: [TestTree] -tests = - [ "Comment" =: - "# Nothing to see here" =?> - (mempty::Blocks) - - , "Not a comment" =: - "#-tag" =?> - para "#-tag" - - , "Comment surrounded by Text" =: - T.unlines [ "Before" - , "# Comment" - , "After" - ] =?> - mconcat [ para "Before" - , para "After" - ] - - , "Title" =: - "#+TITLE: Hello, World" =?> - let titleInline = toList $ "Hello," <> space <> "World" - meta = setMeta "title" (MetaInlines titleInline) nullMeta - in Pandoc meta mempty - - , "Author" =: - "#+author: John /Emacs-Fanboy/ Doe" =?> - let author = toList . spcSep $ [ "John", emph "Emacs-Fanboy", "Doe" ] - meta = setMeta "author" (MetaList [MetaInlines author]) nullMeta - in Pandoc meta mempty - - , "Multiple authors" =: - "#+author: James Dewey Watson, Francis Harry Compton Crick " =?> - let watson = MetaInlines $ toList "James Dewey Watson" - crick = MetaInlines $ toList "Francis Harry Compton Crick" - meta = setMeta "author" (MetaList [watson, crick]) nullMeta - in Pandoc meta mempty - - , "Date" =: - "#+Date: Feb. *28*, 2014" =?> - let date = toList . spcSep $ [ "Feb.", strong "28" <> ",", "2014" ] - meta = setMeta "date" (MetaInlines date) nullMeta - in Pandoc meta mempty - - , "Description" =: - "#+DESCRIPTION: Explanatory text" =?> - let description = "Explanatory text" - meta = setMeta "description" (MetaString description) nullMeta - in Pandoc meta mempty - - , "Properties drawer" =: - T.unlines [ " :PROPERTIES:" - , " :setting: foo" - , " :END:" - ] =?> - (mempty::Blocks) - - , "LaTeX_headers options are translated to header-includes" =: - "#+LaTeX_header: \\usepackage{tikz}" =?> - let latexInlines = rawInline "latex" "\\usepackage{tikz}" - inclList = MetaList [MetaInlines (toList latexInlines)] - meta = setMeta "header-includes" inclList nullMeta - in Pandoc meta mempty - - , "LaTeX_class option is translated to documentclass" =: - "#+LATEX_CLASS: article" =?> - let meta = setMeta "documentclass" (MetaString "article") nullMeta - in Pandoc meta mempty - - , "LaTeX_class_options is translated to classoption" =: - "#+LATEX_CLASS_OPTIONS: [a4paper]" =?> - let meta = setMeta "classoption" (MetaString "a4paper") nullMeta - in Pandoc meta mempty - - , "LaTeX_class_options is translated to classoption" =: - "#+html_head: " =?> - let html = rawInline "html" "" - inclList = MetaList [MetaInlines (toList html)] - meta = setMeta "header-includes" inclList nullMeta - in Pandoc meta mempty - - , "later meta definitions take precedence" =: - T.unlines [ "#+AUTHOR: this will not be used" - , "#+author: Max" - ] =?> - let author = MetaInlines [Str "Max"] - meta = setMeta "author" (MetaList [author]) nullMeta - in Pandoc meta mempty - - , "Logbook drawer" =: - T.unlines [ " :LogBook:" - , " - State \"DONE\" from \"TODO\" [2014-03-03 Mon 11:00]" - , " :END:" - ] =?> - (mempty::Blocks) - - , "Drawer surrounded by text" =: - T.unlines [ "Before" - , ":PROPERTIES:" - , ":END:" - , "After" - ] =?> - para "Before" <> para "After" - - , "Drawer markers must be the only text in the line" =: - T.unlines [ " :LOGBOOK: foo" - , " :END: bar" - ] =?> - para (":LOGBOOK: foo" <> softbreak <> ":END: bar") - - , "Drawers can be arbitrary" =: - T.unlines [ ":FOO:" - , "/bar/" - , ":END:" - ] =?> - divWith (mempty, ["FOO", "drawer"], mempty) (para $ emph "bar") - - , "Anchor reference" =: - T.unlines [ "<> Target." - , "" - , "[[link-here][See here!]]" - ] =?> - (para (spanWith ("link-here", [], []) mempty <> "Target.") <> - para (link "#link-here" "" ("See" <> space <> "here!"))) - - , "Search links are read as emph" =: - "[[Wally][Where's Wally?]]" =?> - para (emph $ "Where's" <> space <> "Wally?") - - , "Link to nonexistent anchor" =: - T.unlines [ "<> Target." - , "" - , "[[link$here][See here!]]" - ] =?> - (para (spanWith ("link-here", [], []) mempty <> "Target.") <> - para (emph ("See" <> space <> "here!"))) - - , "Link abbreviation" =: - T.unlines [ "#+LINK: wp https://en.wikipedia.org/wiki/%s" - , "[[wp:Org_mode][Wikipedia on Org-mode]]" - ] =?> - para (link "https://en.wikipedia.org/wiki/Org_mode" "" - ("Wikipedia" <> space <> "on" <> space <> "Org-mode")) - - , "Link abbreviation, defined after first use" =: - T.unlines [ "[[zl:non-sense][Non-sense articles]]" - , "#+LINK: zl http://zeitlens.com/tags/%s.html" - ] =?> - para (link "http://zeitlens.com/tags/non-sense.html" "" - ("Non-sense" <> space <> "articles")) - - , "Link abbreviation, URL encoded arguments" =: - T.unlines [ "#+link: expl http://example.com/%h/foo" - , "[[expl:Hello, World!][Moin!]]" - ] =?> - para (link "http://example.com/Hello%2C%20World%21/foo" "" "Moin!") - - , "Link abbreviation, append arguments" =: - T.unlines [ "#+link: expl http://example.com/" - , "[[expl:foo][bar]]" - ] =?> - para (link "http://example.com/foo" "" "bar") - - , testGroup "emphasis config" - [ "Changing pre and post chars for emphasis" =: - T.unlines [ "#+pandoc-emphasis-pre: \"[)\"" - , "#+pandoc-emphasis-post: \"]\\n\"" - , "([/emph/])*foo*" - ] =?> - para ("([" <> emph "emph" <> "])" <> strong "foo") - - , "setting an invalid value restores the default" =: - T.unlines [ "#+pandoc-emphasis-pre: \"[\"" - , "#+pandoc-emphasis-post: \"]\"" - , "#+pandoc-emphasis-pre:" - , "#+pandoc-emphasis-post:" - , "[/noemph/]" - ] =?> - para ("[/noemph/]") - ] - ] diff --git a/test/Tests/Readers/Org/Shared.hs.orig b/test/Tests/Readers/Org/Shared.hs.orig deleted file mode 100644 index 5e8f6dd54..000000000 --- a/test/Tests/Readers/Org/Shared.hs.orig +++ /dev/null @@ -1,29 +0,0 @@ -module Tests.Readers.Org.Shared - ( (=:) - , org - , spcSep - , tagSpan - ) where - -import Data.List (intersperse) -import Data.Text (Text) -import Tests.Helpers (ToString, purely, test) -import Test.Tasty (TestTree) -import Text.Pandoc (Pandoc, ReaderOptions (readerExtensions), - def, getDefaultExtensions, readOrg) -import Text.Pandoc.Builder (Inlines, smallcaps, space, spanWith, str) - -org :: Text -> Pandoc -org = purely $ readOrg def{ readerExtensions = getDefaultExtensions "org" } - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test org - -spcSep :: [Inlines] -> Inlines -spcSep = mconcat . intersperse space - --- | Create a span for the given tag. -tagSpan :: String -> Inlines -tagSpan t = spanWith ("", ["tag"], [("tag-name", t)]) . smallcaps $ str t diff --git a/test/Tests/Readers/RST.hs.orig b/test/Tests/Readers/RST.hs.orig deleted file mode 100644 index 305c7060b..000000000 --- a/test/Tests/Readers/RST.hs.orig +++ /dev/null @@ -1,189 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -{-# LANGUAGE ScopedTypeVariables #-} -module Tests.Readers.RST (tests) where - -import Data.Text (Text) -import qualified Data.Text as T -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -rst :: Text -> Pandoc -rst = purely $ readRST def{ readerStandalone = True } - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test rst - -tests :: [TestTree] -tests = [ "line block with blank line" =: - "| a\n|\n| b" =?> lineBlock [ "a", mempty, "\160b" ] - , testGroup "field list" - [ "general" =: T.unlines - [ "para" - , "" - , ":Hostname: media08" - , ":IP address: 10.0.0.19" - , ":Size: 3ru" - , ":Version: 1" - , ":Indentation: Since the field marker may be quite long, the second" - , " and subsequent lines of the field body do not have to line up" - , " with the first line, but they must be indented relative to the" - , " field name marker, and they must line up with each other." - , ":Parameter i: integer" - , ":Final: item" - , " on two lines" ] - =?> - doc (para "para" <> - definitionList [ (str "Hostname", [para "media08"]) - , (text "IP address", [para "10.0.0.19"]) - , (str "Size", [para "3ru"]) - , (str "Version", [para "1"]) - , (str "Indentation", [para "Since the field marker may be quite long, the second\nand subsequent lines of the field body do not have to line up\nwith the first line, but they must be indented relative to the\nfield name marker, and they must line up with each other."]) - , (text "Parameter i", [para "integer"]) - , (str "Final", [para "item\non two lines"]) - ]) - , "metadata" =: T.unlines - [ "=====" - , "Title" - , "=====" - , "--------" - , "Subtitle" - , "--------" - , "" - , ":Version: 1" - ] - =?> - setMeta "version" (para "1") (setMeta "title" ("Title" :: Inlines) - $ setMeta "subtitle" ("Subtitle" :: Inlines) - $ doc mempty) - , "with inline markup" =: T.unlines - [ ":*Date*: today" - , "" - , ".." - , "" - , ":*one*: emphasis" - , ":two_: reference" - , ":`three`_: another one" - , ":``four``: literal" - , "" - , ".. _two: http://example.com" - , ".. _three: http://example.org" - ] - =?> - setMeta "date" (str "today") (doc - $ definitionList [ (emph "one", [para "emphasis"]) - , (link "http://example.com" "" "two", [para "reference"]) - , (link "http://example.org" "" "three", [para "another one"]) - , (code "four", [para "literal"]) - ]) - ] - , "URLs with following punctuation" =: - ("http://google.com, http://yahoo.com; http://foo.bar.baz.\n" <> - "http://foo.bar/baz_(bam) (http://foo.bar)") =?> - para (link "http://google.com" "" "http://google.com" <> ", " <> - link "http://yahoo.com" "" "http://yahoo.com" <> "; " <> - link "http://foo.bar.baz" "" "http://foo.bar.baz" <> ". " <> - softbreak <> - link "http://foo.bar/baz_(bam)" "" "http://foo.bar/baz_(bam)" - <> " (" <> link "http://foo.bar" "" "http://foo.bar" <> ")") - , "Reference names with special characters" =: - ("A-1-B_2_C:3:D+4+E.5.F_\n\n" <> - ".. _A-1-B_2_C:3:D+4+E.5.F: https://example.com\n") =?> - para (link "https://example.com" "" "A-1-B_2_C:3:D+4+E.5.F") - , "Code directive with class and number-lines" =: T.unlines - [ ".. code::python" - , " :number-lines: 34" - , " :class: class1 class2 class3" - , "" - , " def func(x):" - , " return y" - ] =?> - doc (codeBlockWith - ( "" - , ["sourceCode", "python", "numberLines", "class1", "class2", "class3"] - , [ ("startFrom", "34") ] - ) - "def func(x):\n return y") - , "Code directive with number-lines, no line specified" =: T.unlines - [ ".. code::python" - , " :number-lines: " - , "" - , " def func(x):" - , " return y" - ] =?> - doc (codeBlockWith - ( "" - , ["sourceCode", "python", "numberLines"] - , [ ("startFrom", "") ] - ) - "def func(x):\n return y") - , testGroup "literal / line / code blocks" - [ "indented literal block" =: T.unlines - [ "::" - , "" - , " block quotes" - , "" - , " can go on for many lines" - , "but must stop here"] - =?> - doc ( - codeBlock "block quotes\n\ncan go on for many lines" <> - para "but must stop here") - , "line block with 3 lines" =: "| a\n| b\n| c" - =?> lineBlock ["a", "b", "c"] - , "line blocks with blank lines" =: T.unlines - [ "|" - , "" - , "|" - , "| a" - , "| b" - , "|" - , "" - , "|" - ] =?> - lineBlock [""] <> - lineBlock ["", "a", "b", ""] <> - lineBlock [""] - , "quoted literal block using >" =: "::\n\n> quoted\n> block\n\nOrdinary paragraph" - =?> codeBlock "> quoted\n> block" <> para "Ordinary paragraph" - , "quoted literal block using | (not a line block)" =: "::\n\n| quoted\n| block\n\nOrdinary paragraph" - =?> codeBlock "| quoted\n| block" <> para "Ordinary paragraph" - , "class directive with single paragraph" =: ".. class:: special\n\nThis is a \"special\" paragraph." - =?> divWith ("", ["special"], []) (para "This is a \"special\" paragraph.") - , "class directive with two paragraphs" =: ".. class:: exceptional remarkable\n\n First paragraph.\n\n Second paragraph." - =?> divWith ("", ["exceptional", "remarkable"], []) (para "First paragraph." <> para "Second paragraph.") - , "class directive around literal block" =: ".. class:: classy\n\n::\n\n a\n b" - =?> divWith ("", ["classy"], []) (codeBlock "a\nb")] - , testGroup "interpreted text roles" - [ "literal role prefix" =: ":literal:`a`" =?> para (code "a") - , "literal role postfix" =: "`a`:literal:" =?> para (code "a") - , "literal text" =: "``text``" =?> para (code "text") - , "code role" =: ":code:`a`" =?> para (codeWith ("", ["sourceCode"], []) "a") - , "inherited code role" =: ".. role:: codeLike(code)\n\n:codeLike:`a`" - =?> para (codeWith ("", ["codeLike", "sourceCode"], []) "a") - , "custom code role with language field" - =: ".. role:: lhs(code)\n :language: haskell\n\n:lhs:`a`" - =?> para (codeWith ("", ["lhs", "haskell","sourceCode"], []) "a") - , "custom role with unspecified parent role" - =: ".. role:: classy\n\n:classy:`text`" - =?> para (spanWith ("", ["classy"], []) "text") - , "role with recursive inheritance" - =: ".. role:: haskell(code)\n.. role:: lhs(haskell)\n\n:lhs:`text`" - =?> para (codeWith ("", ["lhs", "haskell", "sourceCode"], []) "text") - , "unknown role" =: ":unknown:`text`" =?> - para (spanWith ("",[],[("role","unknown")]) (str "text")) - ] - , testGroup "footnotes" - [ "remove space before note" =: T.unlines - [ "foo [1]_" - , "" - , ".. [1]" - , " bar" - ] =?> - para ("foo" <> note (para "bar")) - ] - ] diff --git a/test/Tests/Readers/Txt2Tags.hs.orig b/test/Tests/Readers/Txt2Tags.hs.orig deleted file mode 100644 index e3646e95e..000000000 --- a/test/Tests/Readers/Txt2Tags.hs.orig +++ /dev/null @@ -1,437 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Readers.Txt2Tags (tests) where - -import Data.List (intersperse) -import Data.Text (Text) -import qualified Data.Text as T -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder -import Text.Pandoc.Shared (underlineSpan) - -t2t :: Text -> Pandoc --- t2t = handleError . readTxt2Tags (T2TMeta "date" "mtime" "in" "out") def -t2t = purely $ \s -> do - setInputFiles ["in"] - setOutputFile (Just "out") - readTxt2Tags def s - -infix 4 =: -(=:) :: ToString c - => String -> (Text, c) -> TestTree -(=:) = test t2t - -spcSep :: [Inlines] -> Inlines -spcSep = mconcat . intersperse space - -simpleTable' :: Int - -> [Blocks] - -> [[Blocks]] - -> Blocks -simpleTable' n = table "" (replicate n (AlignCenter, 0.0)) - -tests :: [TestTree] -tests = - [ testGroup "Inlines" - [ "Plain String" =: - "Hello, World" =?> - para (spcSep [ "Hello,", "World" ]) - - , "Emphasis" =: - "//Planet Punk//" =?> - para (emph . spcSep $ ["Planet", "Punk"]) - - , "Strong" =: - "**Cider**" =?> - para (strong "Cider") - - , "Strong Emphasis" =: - "//**strength**//" =?> - para (emph . strong $ "strength") - - , "Strikeout" =: - "--Kill Bill--" =?> - para (strikeout . spcSep $ [ "Kill", "Bill" ]) - - , "Verbatim" =: - "``Robot.rock()``" =?> - para (code "Robot.rock()") - - , "Symbol" =: - "A * symbol" =?> - para (str "A" <> space <> str "*" <> space <> "symbol") - - , "No empty markup" =: - "//// **** ____ ---- ```` \"\"\"\" ''''" =?> - para (spcSep [ "////", "****", "____", "----", "````", "\"\"\"\"", "''''" ]) - - , "Inline markup is greedy" =: - "***** ///// _____ ----- ````` \"\"\"\"\" '''''" =?> - para (spcSep [strong "*", emph "/", underlineSpan "_" - , strikeout "-", code "`", text "\"" - , rawInline "html" "'"]) - , "Markup must be greedy" =: - "********** ////////// __________ ---------- `````````` \"\"\"\"\"\"\"\"\"\" ''''''''''" =?> - para (spcSep [strong "******", emph "//////", underlineSpan "______" - , strikeout "------", code "``````", text "\"\"\"\"\"\"" - , rawInline "html" "''''''"]) - , "Inlines must be glued" =: - "** a** **a ** ** a **" =?> - para (text "** a** **a ** ** a **") - - , "Macros: Date" =: - "%%date" =?> - para "1970-01-01" - , "Macros: Mod Time" =: - "%%mtime" =?> - para (str "") - , "Macros: Infile" =: - "%%infile" =?> - para "in" - , "Macros: Outfile" =: - "%%outfile" =?> - para "out" - , "Autolink" =: - "http://www.google.com" =?> - para (link "http://www.google.com" "" (str "http://www.google.com")) - , "JPEG Image" =: - "[image.jpg]" =?> - para (image "image.jpg" "" mempty) - , "PNG Image" =: - "[image.png]" =?> - para (image "image.png" "" mempty) - - , "Link" =: - "[title http://google.com]" =?> - para (link "http://google.com" "" (str "title")) - - , "Image link" =: - "[[image.jpg] abc]" =?> - para (link "abc" "" (image "image.jpg" "" mempty)) - , "Invalid link: No trailing space" =: - "[title invalid ]" =?> - para (text "[title invalid ]") - - - ] - - , testGroup "Basic Blocks" - ["Paragraph, lines grouped together" =: - "A paragraph\n A blank line ends the \n current paragraph\n" - =?> para "A paragraph\n A blank line ends the\n current paragraph" - , "Paragraph, ignore leading and trailing spaces" =: - " Leading and trailing spaces are ignored. \n" =?> - para "Leading and trailing spaces are ignored." - , "Comment line in paragraph" =: - "A comment line can be placed inside a paragraph.\n% this comment will be ignored \nIt will not affect it.\n" - =?> para "A comment line can be placed inside a paragraph.\nIt will not affect it." - , "Paragraph" =: - "Paragraph\n" =?> - para "Paragraph" - - , "First Level Header" =: - "+ Headline +\n" =?> - header 1 "Headline" - - , "Third Level Header" =: - "=== Third Level Headline ===\n" =?> - header 3 ("Third" <> space <> - "Level" <> space <> - "Headline") - - , "Header with label" =: - "= header =[label]" =?> - headerWith ("label", [], []) 1 "header" - - , "Invalid header, mismatched delimiters" =: - "== header =" =?> - para (text "== header =") - - , "Invalid header, spaces in label" =: - "== header ==[ haha ]" =?> - para (text "== header ==[ haha ]") - - , "Invalid header, invalid label character" =: - "== header ==[lab/el]" =?> - para (text "== header ==[lab/el]") - , "Headers not preceded by a blank line" =: - T.unlines [ "++ eat dinner ++" - , "Spaghetti and meatballs tonight." - , "== walk dog ==" - ] =?> - mconcat [ header 2 ("eat" <> space <> "dinner") - , para $ spcSep [ "Spaghetti", "and", "meatballs", "tonight." ] - , header 2 ("walk" <> space <> "dog") - ] - - , "Paragraph starting with an equals" =: - "=five" =?> - para "=five" - - , "Paragraph containing asterisk at beginning of line" =: - T.unlines [ "lucky" - , "*star" - ] =?> - para ("lucky" <> softbreak <> "*star") - - , "Horizontal Rule" =: - T.unlines [ "before" - , T.replicate 20 "-" - , T.replicate 20 "=" - , T.replicate 20 "_" - , "after" - ] =?> - mconcat [ para "before" - , horizontalRule - , horizontalRule - , horizontalRule - , para "after" - ] - - , "Comment Block" =: - T.unlines [ "%%%" - , "stuff" - , "bla" - , "%%%"] =?> - (mempty::Blocks) - - - ] - - , testGroup "Lists" - [ "Simple Bullet Lists" =: - ("- Item1\n" <> - "- Item2\n") =?> - bulletList [ plain "Item1" - , plain "Item2" - ] - - , "Indented Bullet Lists" =: - (" - Item1\n" <> - " - Item2\n") =?> - bulletList [ plain "Item1" - , plain "Item2" - ] - - - - , "Nested Bullet Lists" =: - ("- Discovery\n" <> - " + One More Time\n" <> - " + Harder, Better, Faster, Stronger\n" <> - "- Homework\n" <> - " + Around the World\n"<> - "- Human After All\n" <> - " + Technologic\n" <> - " + Robot Rock\n") =?> - bulletList [ mconcat - [ plain "Discovery" - , orderedList [ plain ("One" <> space <> - "More" <> space <> - "Time") - , plain ("Harder," <> space <> - "Better," <> space <> - "Faster," <> space <> - "Stronger") - ] - ] - , mconcat - [ plain "Homework" - , orderedList [ plain ("Around" <> space <> - "the" <> space <> - "World") - ] - ] - , mconcat - [ plain ("Human" <> space <> "After" <> space <> "All") - , orderedList [ plain "Technologic" - , plain ("Robot" <> space <> "Rock") - ] - ] - ] - - , "Simple Ordered List" =: - ("+ Item1\n" <> - "+ Item2\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ plain "Item1" - , plain "Item2" - ] - in orderedListWith listStyle listStructure - - - , "Indented Ordered List" =: - (" + Item1\n" <> - " + Item2\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ plain "Item1" - , plain "Item2" - ] - in orderedListWith listStyle listStructure - - , "Nested Ordered Lists" =: - ("+ One\n" <> - " + One-One\n" <> - " + One-Two\n" <> - "+ Two\n" <> - " + Two-One\n"<> - " + Two-Two\n") =?> - let listStyle = (1, DefaultStyle, DefaultDelim) - listStructure = [ mconcat - [ plain "One" - , orderedList [ plain "One-One" - , plain "One-Two" - ] - ] - , mconcat - [ plain "Two" - , orderedList [ plain "Two-One" - , plain "Two-Two" - ] - ] - ] - in orderedListWith listStyle listStructure - - , "Ordered List in Bullet List" =: - ("- Emacs\n" <> - " + Org\n") =?> - bulletList [ (plain "Emacs") <> - (orderedList [ plain "Org"]) - ] - - , "Bullet List in Ordered List" =: - ("+ GNU\n" <> - " - Freedom\n") =?> - orderedList [ (plain "GNU") <> bulletList [ (plain "Freedom") ] ] - - , "Definition List" =: - T.unlines [ ": PLL" - , " phase-locked loop" - , ": TTL" - , " transistor-transistor logic" - , ": PSK" - , " a digital" - ] =?> - definitionList [ ("PLL", [ plain $ "phase-locked" <> space <> "loop" ]) - , ("TTL", [ plain $ "transistor-transistor" <> space <> "logic" ]) - , ("PSK", [ plain $ "a" <> space <> "digital" ]) - ] - - - , "Loose bullet list" =: - T.unlines [ "- apple" - , "" - , "- orange" - , "" - , "- peach" - ] =?> - bulletList [ para "apple" - , para "orange" - , para "peach" - ] - ] - - , testGroup "Tables" - [ "Single cell table" =: - "| Test " =?> - simpleTable' 1 mempty [[plain "Test"]] - - , "Multi cell table" =: - "| One | Two |" =?> - simpleTable' 2 mempty [ [ plain "One", plain "Two" ] ] - - , "Multi line table" =: - T.unlines [ "| One |" - , "| Two |" - , "| Three |" - ] =?> - simpleTable' 1 mempty - [ [ plain "One" ] - , [ plain "Two" ] - , [ plain "Three" ] - ] - - , "Empty table" =: - "| |" =?> - simpleTable' 1 mempty [[mempty]] - - , "Glider Table" =: - T.unlines [ "| 1 | 0 | 0 |" - , "| 0 | 1 | 1 |" - , "| 1 | 1 | 0 |" - ] =?> - simpleTable' 3 mempty - [ [ plain "1", plain "0", plain "0" ] - , [ plain "0", plain "1", plain "1" ] - , [ plain "1", plain "1", plain "0" ] - ] - - - , "Table with Header" =: - T.unlines [ "|| Species | Status |" - , "| cervisiae | domesticated |" - , "| paradoxus | wild |" - ] =?> - simpleTable [ plain "Species", plain "Status" ] - [ [ plain "cervisiae", plain "domesticated" ] - , [ plain "paradoxus", plain "wild" ] - ] - - , "Table alignment determined by spacing" =: - T.unlines [ "| Numbers | Text | More |" - , "| 1 | One | foo |" - , "| 2 | Two | bar |" - ] =?> - table "" (zip [AlignCenter, AlignRight, AlignDefault] [0, 0, 0]) - [] - [ [ plain "Numbers", plain "Text", plain "More" ] - , [ plain "1" , plain "One" , plain "foo" ] - , [ plain "2" , plain "Two" , plain "bar" ] - ] - - , "Pipe within text doesn't start a table" =: - "Ceci n'est pas une | pipe " =?> - para (spcSep [ "Ceci", "n'est", "pas", "une", "|", "pipe" ]) - - - , "Table with differing row lengths" =: - T.unlines [ "|| Numbers | Text " - , "| 1 | One | foo |" - , "| 2 " - ] =?> - table "" (zip [AlignCenter, AlignLeft, AlignLeft] [0, 0, 0]) - [ plain "Numbers", plain "Text" , plain mempty ] - [ [ plain "1" , plain "One" , plain "foo" ] - , [ plain "2" , plain mempty , plain mempty ] - ] - - ] - - , testGroup "Blocks and fragments" - [ "Source block" =: - T.unlines [ "```" - , "main = putStrLn greeting" - , " where greeting = \"moin\"" - , "```" ] =?> - let code' = "main = putStrLn greeting\n" <> - " where greeting = \"moin\"\n" - in codeBlock code' - - , "tagged block" =: - T.unlines [ "'''" - , "" - , "'''" - ] =?> - rawBlock "html" "\n" - - , "Quote block" =: - T.unlines ["\t//Niemand// hat die Absicht, eine Mauer zu errichten!" - ] =?> - blockQuote (para (spcSep [ emph "Niemand", "hat", "die", "Absicht," - , "eine", "Mauer", "zu", "errichten!" - ])) - - ] - ] diff --git a/test/Tests/Shared.hs.orig b/test/Tests/Shared.hs.orig deleted file mode 100644 index cc448419c..000000000 --- a/test/Tests/Shared.hs.orig +++ /dev/null @@ -1,39 +0,0 @@ -module Tests.Shared (tests) where - -import System.FilePath.Posix (joinPath) -import Test.Tasty -import Test.Tasty.HUnit (assertBool, testCase, (@?=)) -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder -import Text.Pandoc.Shared - -tests :: [TestTree] -tests = [ testGroup "compactifyDL" - [ testCase "compactifyDL with empty def" $ - assertBool "compactifyDL" - (let x = [(str "word", [para (str "def"), mempty])] - in compactifyDL x == x) - ] - , testGroup "collapseFilePath" testCollapse - ] - -testCollapse :: [TestTree] -testCollapse = map (testCase "collapse") - [ collapseFilePath (joinPath [ ""]) @?= (joinPath [ ""]) - , collapseFilePath (joinPath [ ".","foo"]) @?= (joinPath [ "foo"]) - , collapseFilePath (joinPath [ ".",".","..","foo"]) @?= (joinPath [ joinPath ["..", "foo"]]) - , collapseFilePath (joinPath [ "..","foo"]) @?= (joinPath [ "..","foo"]) - , collapseFilePath (joinPath [ "","bar","..","baz"]) @?= (joinPath [ "","baz"]) - , collapseFilePath (joinPath [ "","..","baz"]) @?= (joinPath [ "","..","baz"]) - , collapseFilePath (joinPath [ ".","foo","..",".","bar","..",".",".","baz"]) @?= (joinPath [ "baz"]) - , collapseFilePath (joinPath [ ".",""]) @?= (joinPath [ ""]) - , collapseFilePath (joinPath [ ".",".",""]) @?= (joinPath [ ""]) - , collapseFilePath (joinPath [ "..",""]) @?= (joinPath [ ".."]) - , collapseFilePath (joinPath [ "..",".",""]) @?= (joinPath [ ".."]) - , collapseFilePath (joinPath [ ".","..",""]) @?= (joinPath [ ".."]) - , collapseFilePath (joinPath [ "..","..",""]) @?= (joinPath [ "..",".."]) - , collapseFilePath (joinPath [ "parent","foo","baz","..","bar"]) @?= (joinPath [ "parent","foo","bar"]) - , collapseFilePath (joinPath [ "parent","foo","baz","..","..","bar"]) @?= (joinPath [ "parent","bar"]) - , collapseFilePath (joinPath [ "parent","foo",".."]) @?= (joinPath [ "parent"]) - , collapseFilePath (joinPath [ "","parent","foo","..","..","bar"]) @?= (joinPath [ "","bar"]) - , collapseFilePath (joinPath [ "",".","parent","foo"]) @?= (joinPath [ "","parent","foo"])] diff --git a/test/Tests/Writers/AsciiDoc.hs.orig b/test/Tests/Writers/AsciiDoc.hs.orig deleted file mode 100644 index 6b97c0761..000000000 --- a/test/Tests/Writers/AsciiDoc.hs.orig +++ /dev/null @@ -1,56 +0,0 @@ -module Tests.Writers.AsciiDoc (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -asciidoc :: (ToPandoc a) => a -> String -asciidoc = unpack . purely (writeAsciiDoc def{ writerWrapText = WrapNone }) . toPandoc - -tests :: [TestTree] -tests = [ testGroup "emphasis" - [ test asciidoc "emph word before" $ - para (text "foo" <> emph (text "bar")) =?> - "foo__bar__" - , test asciidoc "emph word after" $ - para (emph (text "foo") <> text "bar") =?> - "__foo__bar" - , test asciidoc "emph quoted" $ - para (doubleQuoted (emph (text "foo"))) =?> - "``__foo__''" - , test asciidoc "strong word before" $ - para (text "foo" <> strong (text "bar")) =?> - "foo**bar**" - , test asciidoc "strong word after" $ - para (strong (text "foo") <> text "bar") =?> - "**foo**bar" - , test asciidoc "strong quoted" $ - para (singleQuoted (strong (text "foo"))) =?> - "`**foo**'" - ] - , testGroup "tables" - [ test asciidoc "empty cells" $ - simpleTable [] [[mempty],[mempty]] =?> unlines - [ "[cols=\"\",]" - , "|====" - , "|" - , "|" - , "|====" - ] - , test asciidoc "multiblock cells" $ - simpleTable [] [[para (text "Para 1") <> para (text "Para 2")]] - =?> unlines - [ "[cols=\"\",]" - , "|=====" - , "a|" - , "Para 1" - , "" - , "Para 2" - , "" - , "|=====" - ] - ] - ] diff --git a/test/Tests/Writers/ConTeXt.hs.orig b/test/Tests/Writers/ConTeXt.hs.orig deleted file mode 100644 index 812aab4a6..000000000 --- a/test/Tests/Writers/ConTeXt.hs.orig +++ /dev/null @@ -1,149 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.ConTeXt (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Test.Tasty.QuickCheck -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -context :: (ToPandoc a) => a -> String -context = unpack . purely (writeConTeXt def) . toPandoc - -context' :: (ToPandoc a) => a -> String -context' = unpack . purely (writeConTeXt def{ writerWrapText = WrapNone }) . toPandoc - -contextNtb :: (ToPandoc a) => a -> String -contextNtb = unpack . purely (writeConTeXt def{ writerExtensions = enableExtension Ext_ntb pandocExtensions }) . toPandoc - -contextDiv :: (ToPandoc a) => a -> String -contextDiv = unpack . purely (writeConTeXt def{ writerSectionDivs = True }) . toPandoc - -{- - "my test" =: X =?> Y - -is shorthand for - - test context "my test" $ X =?> Y - -which is in turn shorthand for - - test context "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test context - -tests :: [TestTree] -tests = [ testGroup "inline code" - [ "with '}'" =: code "}" =?> "\\mono{\\}}" - , "without '}'" =: code "]" =?> "\\type{]}" - , testProperty "code property" $ \s -> null s || - if '{' `elem` s || '}' `elem` s - then context' (code s) == "\\mono{" ++ - context' (str s) ++ "}" - else context' (code s) == "\\type{" ++ s ++ "}" - ] - , testGroup "headers" - [ "level 1" =: - headerWith ("my-header",[],[]) 1 "My header" =?> "\\section[title={My header},reference={my-header}]" - , test contextDiv "section-divs" $ - ( headerWith ("header1", [], []) 1 (text "Header1") - <> headerWith ("header2", [], []) 2 (text "Header2") - <> headerWith ("header3", [], []) 3 (text "Header3") - <> headerWith ("header4", [], []) 4 (text "Header4") - <> headerWith ("header5", [], []) 5 (text "Header5") - <> headerWith ("header6", [], []) 6 (text "Header6")) - =?> - unlines [ "\\startsection[title={Header1},reference={header1}]\n" - , "\\startsubsection[title={Header2},reference={header2}]\n" - , "\\startsubsubsection[title={Header3},reference={header3}]\n" - , "\\startsubsubsubsection[title={Header4},reference={header4}]\n" - , "\\startsubsubsubsubsection[title={Header5},reference={header5}]\n" - , "\\startsubsubsubsubsubsection[title={Header6},reference={header6}]\n" - , "\\stopsubsubsubsubsubsection\n" - , "\\stopsubsubsubsubsection\n" - , "\\stopsubsubsubsection\n" - , "\\stopsubsubsection\n" - , "\\stopsubsection\n" - , "\\stopsection" ] - ] - , testGroup "bullet lists" - [ "nested" =: - bulletList [ - plain (text "top") - <> bulletList [ - plain (text "next") - <> bulletList [plain (text "bot")] - ] - ] =?> unlines - [ "\\startitemize[packed]" - , "\\item" - , " top" - , " \\startitemize[packed]" - , " \\item" - , " next" - , " \\startitemize[packed]" - , " \\item" - , " bot" - , " \\stopitemize" - , " \\stopitemize" - , "\\stopitemize" ] - ] - , testGroup "natural tables" - [ test contextNtb "table with header and caption" $ - let caption = text "Table 1" - aligns = [(AlignRight, 0.0), (AlignLeft, 0.0), (AlignCenter, 0.0), (AlignDefault, 0.0)] - headers = [plain $ text "Right", - plain $ text "Left", - plain $ text "Center", - plain $ text "Default"] - rows = [[plain $ text "1.1", - plain $ text "1.2", - plain $ text "1.3", - plain $ text "1.4"] - ,[plain $ text "2.1", - plain $ text "2.2", - plain $ text "2.3", - plain $ text "2.4"] - ,[plain $ text "3.1", - plain $ text "3.2", - plain $ text "3.3", - plain $ text "3.4"]] - in table caption aligns headers rows - =?> unlines [ "\\startplacetable[title={Table 1}]" - , "\\startTABLE" - , "\\startTABLEhead" - , "\\NC[align=left] Right" - , "\\NC[align=right] Left" - , "\\NC[align=middle] Center" - , "\\NC Default" - , "\\NC\\NR" - , "\\stopTABLEhead" - , "\\startTABLEbody" - , "\\NC[align=left] 1.1" - , "\\NC[align=right] 1.2" - , "\\NC[align=middle] 1.3" - , "\\NC 1.4" - , "\\NC\\NR" - , "\\NC[align=left] 2.1" - , "\\NC[align=right] 2.2" - , "\\NC[align=middle] 2.3" - , "\\NC 2.4" - , "\\NC\\NR" - , "\\stopTABLEbody" - , "\\startTABLEfoot" - , "\\NC[align=left] 3.1" - , "\\NC[align=right] 3.2" - , "\\NC[align=middle] 3.3" - , "\\NC 3.4" - , "\\NC\\NR" - , "\\stopTABLEfoot" - , "\\stopTABLE" - , "\\stopplacetable" ] - ] - ] diff --git a/test/Tests/Writers/Docbook.hs.orig b/test/Tests/Writers/Docbook.hs.orig deleted file mode 100644 index 89ea76586..000000000 --- a/test/Tests/Writers/Docbook.hs.orig +++ /dev/null @@ -1,303 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.Docbook (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -docbook :: (ToPandoc a) => a -> String -docbook = docbookWithOpts def{ writerWrapText = WrapNone } - -docbookWithOpts :: ToPandoc a => WriterOptions -> a -> String -docbookWithOpts opts = unpack . purely (writeDocbook4 opts) . toPandoc - -{- - "my test" =: X =?> Y - -is shorthand for - - test docbook "my test" $ X =?> Y - -which is in turn shorthand for - - test docbook "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test docbook - -lineblock :: Blocks -lineblock = para ("some text" <> linebreak <> - "and more lines" <> linebreak <> - "and again") -lineblock_out :: [String] -lineblock_out = [ "some text" - , "and more lines" - , "and again" - ] - -tests :: [TestTree] -tests = [ testGroup "line blocks" - [ "none" =: para "This is a test" - =?> unlines - [ "" - , " This is a test" - , "" - ] - , "basic" =: lineblock - =?> unlines lineblock_out - , "blockquote" =: blockQuote lineblock - =?> unlines - ( [ "
" ] ++ - lineblock_out ++ - [ "
" ] - ) - , "footnote" =: para ("This is a test" <> - note lineblock <> - " of footnotes") - =?> unlines - ( [ "" - , " This is a test" ] ++ - lineblock_out ++ - [ " of footnotes" - , "" ] - ) - ] - , testGroup "compact lists" - [ testGroup "bullet" - [ "compact" =: bulletList [plain "a", plain "b", plain "c"] - =?> unlines - [ "" - , " " - , " " - , " a" - , " " - , " " - , " " - , " " - , " b" - , " " - , " " - , " " - , " " - , " c" - , " " - , " " - , "" - ] - , "loose" =: bulletList [para "a", para "b", para "c"] - =?> unlines - [ "" - , " " - , " " - , " a" - , " " - , " " - , " " - , " " - , " b" - , " " - , " " - , " " - , " " - , " c" - , " " - , " " - , "" - ] - ] - , testGroup "ordered" - [ "compact" =: orderedList [plain "a", plain "b", plain "c"] - =?> unlines - [ "" - , " " - , " " - , " a" - , " " - , " " - , " " - , " " - , " b" - , " " - , " " - , " " - , " " - , " c" - , " " - , " " - , "" - ] - , "loose" =: orderedList [para "a", para "b", para "c"] - =?> unlines - [ "" - , " " - , " " - , " a" - , " " - , " " - , " " - , " " - , " b" - , " " - , " " - , " " - , " " - , " c" - , " " - , " " - , "" - ] - ] - , testGroup "definition" - [ "compact" =: definitionList [ ("an", [plain "apple" ]) - , ("a", [plain "banana"]) - , ("an", [plain "orange"])] - =?> unlines - [ "" - , " " - , " " - , " an" - , " " - , " " - , " " - , " apple" - , " " - , " " - , " " - , " " - , " " - , " a" - , " " - , " " - , " " - , " banana" - , " " - , " " - , " " - , " " - , " " - , " an" - , " " - , " " - , " " - , " orange" - , " " - , " " - , " " - , "" - ] - , "loose" =: definitionList [ ("an", [para "apple" ]) - , ("a", [para "banana"]) - , ("an", [para "orange"])] - =?> unlines - [ "" - , " " - , " " - , " an" - , " " - , " " - , " " - , " apple" - , " " - , " " - , " " - , " " - , " " - , " a" - , " " - , " " - , " " - , " banana" - , " " - , " " - , " " - , " " - , " " - , " an" - , " " - , " " - , " " - , " orange" - , " " - , " " - , " " - , "" - ] - ] - ] - , testGroup "writer options" - [ testGroup "top-level division" $ - let - headers = header 1 (text "header1") - <> header 2 (text "header2") - <> header 3 (text "header3") - - docbookTopLevelDiv :: (ToPandoc a) - => TopLevelDivision -> a -> String - docbookTopLevelDiv division = - docbookWithOpts def{ writerTopLevelDivision = division } - in - [ test (docbookTopLevelDiv TopLevelSection) "sections as top-level" $ - headers =?> - unlines [ "" - , " header1" - , " " - , " header2" - , " " - , " header3" - , " " - , " " - , " " - , " " - , "" - ] - , test (docbookTopLevelDiv TopLevelChapter) "chapters as top-level" $ - headers =?> - unlines [ "" - , " header1" - , " " - , " header2" - , " " - , " header3" - , " " - , " " - , " " - , " " - , "" - ] - , test (docbookTopLevelDiv TopLevelPart) "parts as top-level" $ - headers =?> - unlines [ "" - , " header1" - , " " - , " header2" - , " " - , " header3" - , " " - , " " - , " " - , " " - , "" - ] - , test (docbookTopLevelDiv TopLevelDefault) "default top-level" $ - headers =?> - unlines [ "" - , " header1" - , " " - , " header2" - , " " - , " header3" - , " " - , " " - , " " - , " " - , "" - ] - ] - ] - ] diff --git a/test/Tests/Writers/Docx.hs.orig b/test/Tests/Writers/Docx.hs.orig deleted file mode 100644 index 3ded0aa38..000000000 --- a/test/Tests/Writers/Docx.hs.orig +++ /dev/null @@ -1,157 +0,0 @@ -module Tests.Writers.Docx (tests) where - -import Text.Pandoc -import Test.Tasty -import Tests.Writers.OOXML -import Test.Tasty.HUnit -import Data.List (isPrefixOf) - --- we add an extra check to make sure that we're not writing in the --- toplevel docx directory. We don't want to accidentally overwrite an --- Word-generated docx file used to test the reader. -docxTest :: String -> WriterOptions -> FilePath -> FilePath -> TestTree -docxTest testName opts nativeFP goldenFP = - if "docx/golden/" `isPrefixOf` goldenFP - then ooxmlTest writeDocx testName opts nativeFP goldenFP - else testCase testName $ - assertFailure $ - goldenFP ++ " is not in `test/docx/golden`" - -tests :: [TestTree] -tests = [ testGroup "inlines" - [ docxTest - "font formatting" - def - "docx/inline_formatting.native" - "docx/golden/inline_formatting.docx" - , docxTest - "hyperlinks" - def - "docx/links.native" - "docx/golden/links.docx" - , docxTest - "inline image" - def - "docx/image_writer_test.native" - "docx/golden/image.docx" - , docxTest - "inline images" - def - "docx/inline_images_writer_test.native" - "docx/golden/inline_images.docx" - , docxTest - "handling unicode input" - def - "docx/unicode.native" - "docx/golden/unicode.docx" - , docxTest - "inline code" - def - "docx/inline_code.native" - "docx/golden/inline_code.docx" - , docxTest - "inline code in subscript and superscript" - def - "docx/verbatim_subsuper.native" - "docx/golden/verbatim_subsuper.docx" - ] - , testGroup "blocks" - [ docxTest - "headers" - def - "docx/headers.native" - "docx/golden/headers.docx" - , docxTest - "nested anchor spans in header" - def - "docx/nested_anchors_in_header.native" - "docx/golden/nested_anchors_in_header.docx" - , docxTest - "lists" - def - "docx/lists.native" - "docx/golden/lists.docx" - , docxTest - "lists continuing after interruption" - def - "docx/lists_continuing.native" - "docx/golden/lists_continuing.docx" - , docxTest - "lists restarting after interruption" - def - "docx/lists_restarting.native" - "docx/golden/lists_restarting.docx" - , docxTest - "definition lists" - def - "docx/definition_list.native" - "docx/golden/definition_list.docx" - , docxTest - "footnotes and endnotes" - def - "docx/notes.native" - "docx/golden/notes.docx" - , docxTest - "links in footnotes and endnotes" - def - "docx/link_in_notes.native" - "docx/golden/link_in_notes.docx" - , docxTest - "blockquotes" - def - "docx/block_quotes_parse_indent.native" - "docx/golden/block_quotes.docx" - , docxTest - "tables" - def - "docx/tables.native" - "docx/golden/tables.docx" - , docxTest - "tables with lists in cells" - def - "docx/table_with_list_cell.native" - "docx/golden/table_with_list_cell.docx" - , docxTest - "tables with one row" - def - "docx/table_one_row.native" - "docx/golden/table_one_row.docx" - , docxTest - "code block" - def - "docx/codeblock.native" - "docx/golden/codeblock.docx" - ] - , testGroup "track changes" - [ docxTest - "insertion" - def - "docx/track_changes_insertion_all.native" - "docx/golden/track_changes_insertion.docx" - , docxTest - "deletion" - def - "docx/track_changes_deletion_all.native" - "docx/golden/track_changes_deletion.docx" - , docxTest - "move text" - def - "docx/track_changes_move_all.native" - "docx/golden/track_changes_move.docx" - , docxTest - "comments" - def - "docx/comments.native" - "docx/golden/comments.docx" - ] - , testGroup "custom styles" - [ docxTest "custom styles without reference.docx" - def - "docx/custom_style.native" - "docx/golden/custom_style_no_reference.docx" - , docxTest "custom styles with reference.docx" - def{writerReferenceDoc = Just "docx/custom-style-reference.docx"} - "docx/custom_style.native" - "docx/golden/custom_style_reference.docx" - ] - ] diff --git a/test/Tests/Writers/FB2.hs.orig b/test/Tests/Writers/FB2.hs.orig deleted file mode 100644 index 6663c42f8..000000000 --- a/test/Tests/Writers/FB2.hs.orig +++ /dev/null @@ -1,34 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.FB2 (tests) where - -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -fb2 :: String -> String -fb2 x = "\n" ++ - "unrecognisedpandoc<p />
" ++ x ++ "
" - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test (purely (writeFB2 def) . toPandoc) - -tests :: [TestTree] -tests = [ testGroup "block elements" - ["para" =: para "Lorem ipsum cetera." - =?> fb2 "

Lorem ipsum cetera.

" - ] - , testGroup "inlines" - [ - "Emphasis" =: emph "emphasized" - =?> fb2 "emphasized" - ] - , "bullet list" =: bulletList [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ] - =?> fb2 "

\x2022 first

\x2022 second

\x2022 third

" - ] diff --git a/test/Tests/Writers/HTML.hs.orig b/test/Tests/Writers/HTML.hs.orig deleted file mode 100644 index 23ff718d3..000000000 --- a/test/Tests/Writers/HTML.hs.orig +++ /dev/null @@ -1,44 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.HTML (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -html :: (ToPandoc a) => a -> String -html = unpack . purely (writeHtml4String def{ writerWrapText = WrapNone }) . toPandoc - -{- - "my test" =: X =?> Y - -is shorthand for - - test html "my test" $ X =?> Y - -which is in turn shorthand for - - test html "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test html - -tests :: [TestTree] -tests = [ testGroup "inline code" - [ "basic" =: code "@&" =?> "@&" - , "haskell" =: codeWith ("",["haskell"],[]) ">>=" - =?> ">>=" - , "nolanguage" =: codeWith ("",["nolanguage"],[]) ">>=" - =?> ">>=" - ] - , testGroup "images" - [ "alt with formatting" =: - image "/url" "title" ("my " <> emph "image") - =?> "\"my" - ] - ] diff --git a/test/Tests/Writers/JATS.hs.orig b/test/Tests/Writers/JATS.hs.orig deleted file mode 100644 index 723c0e8a8..000000000 --- a/test/Tests/Writers/JATS.hs.orig +++ /dev/null @@ -1,108 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.JATS (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -jats :: (ToPandoc a) => a -> String -jats = unpack . purely (writeJATS def{ writerWrapText = WrapNone }) . toPandoc - -{- - "my test" =: X =?> Y - -is shorthand for - - test jats "my test" $ X =?> Y - -which is in turn shorthand for - - test jats "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test jats - -tests :: [TestTree] -tests = [ testGroup "inline code" - [ "basic" =: code "@&" =?> "

@&

" - , "lang" =: codeWith ("", ["c"], []) "@&" =?> "

@&

" - ] - , testGroup "block code" - [ "basic" =: codeBlock "@&" =?> "@&" - , "lang" =: codeBlockWith ("", ["c"], []) "@&" =?> "@&" - ] - , testGroup "images" - [ "basic" =: - image "/url" "title" mempty - =?> "" - ] - , testGroup "inlines" - [ "Emphasis" =: emph "emphasized" - =?> "

emphasized

" - ] - , "bullet list" =: bulletList [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ] - =?> "\n\ - \ \n\ - \

first

\n\ - \
\n\ - \ \n\ - \

second

\n\ - \
\n\ - \ \n\ - \

third

\n\ - \
\n\ - \
" - , testGroup "definition lists" - [ "with internal link" =: definitionList [(link "#go" "" (str "testing"), - [plain (text "hi there")])] =?> - "\n\ - \ \n\ - \ testing\n\ - \ \n\ - \

hi there

\n\ - \
\n\ - \
\n\ - \
" - ] - , testGroup "math" - [ "escape |" =: para (math "\\sigma|_{\\{x\\}}") =?> - "

\n\ - \\n\ - \σ|{x}

" - ] - , testGroup "headers" - [ "unnumbered header" =: - headerWith ("foo",["unnumbered"],[]) 1 - (text "Header 1" <> note (plain $ text "note")) =?> - "\n\ - \ Header 1<fn>\n\ - \ <p>note</p>\n\ - \ </fn>\n\ - \" - , "unnumbered sub header" =: - headerWith ("foo",["unnumbered"],[]) 1 - (text "Header") - <> headerWith ("foo",["unnumbered"],[]) 2 - (text "Sub-Header") =?> - "\n\ - \ Header\n\ - \ \n\ - \ Sub-Header\n\ - \ \n\ - \" - , "containing image" =: - header 1 (image "imgs/foo.jpg" "" (text "Alt text")) =?> - "\n\ - \ <inline-graphic mimetype=\"image\" mime-subtype=\"jpeg\" xlink:href=\"imgs/foo.jpg\" />\n\ - \" - ] - ] diff --git a/test/Tests/Writers/LaTeX.hs.orig b/test/Tests/Writers/LaTeX.hs.orig deleted file mode 100644 index 471d9d9e7..000000000 --- a/test/Tests/Writers/LaTeX.hs.orig +++ /dev/null @@ -1,176 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.LaTeX (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -latex :: (ToPandoc a) => a -> String -latex = latexWithOpts def - -latexListing :: (ToPandoc a) => a -> String -latexListing = latexWithOpts def{ writerListings = True } - -latexWithOpts :: (ToPandoc a) => WriterOptions -> a -> String -latexWithOpts opts = unpack . purely (writeLaTeX opts) . toPandoc - -beamerWithOpts :: (ToPandoc a) => WriterOptions -> a -> String -beamerWithOpts opts = unpack . purely (writeBeamer opts) . toPandoc - -{- - "my test" =: X =?> Y - -is shorthand for - - test latex "my test" $ X =?> Y - -which is in turn shorthand for - - test latex "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test latex - -tests :: [TestTree] -tests = [ testGroup "code blocks" - [ "in footnotes" =: note (para "hi" <> codeBlock "hi") =?> - "\\footnote{hi\n\n\\begin{Verbatim}\nhi\n\\end{Verbatim}\n}" - , test latexListing "identifier" $ codeBlockWith ("id",[],[]) "hi" =?> - ("\\begin{lstlisting}[label=id]\nhi\n\\end{lstlisting}" :: String) - , test latexListing "no identifier" $ codeBlock "hi" =?> - ("\\begin{lstlisting}\nhi\n\\end{lstlisting}" :: String) - ] - , testGroup "definition lists" - [ "with internal link" =: definitionList [(link "#go" "" (str "testing"), - [plain (text "hi there")])] =?> - "\\begin{description}\n\\tightlist\n\\item[{\\protect\\hyperlink{go}{testing}}]\nhi there\n\\end{description}" - ] - , testGroup "math" - [ "escape |" =: para (math "\\sigma|_{\\{x\\}}") =?> - "\\(\\sigma|_{\\{x\\}}\\)" - ] - , testGroup "headers" - [ "unnumbered header" =: - headerWith ("foo",["unnumbered"],[]) 1 - (text "Header 1" <> note (plain $ text "note")) =?> - "\\hypertarget{foo}{%\n\\section*{\\texorpdfstring{Header 1\\footnote{note}}{Header 1}}\\label{foo}}\n\\addcontentsline{toc}{section}{Header 1}\n" - , "in list item" =: - bulletList [header 2 (text "foo")] =?> - "\\begin{itemize}\n\\item ~\n \\subsection{foo}\n\\end{itemize}" - , "in definition list item" =: - definitionList [(text "foo", [header 2 (text "bar"), - para $ text "baz"])] =?> - "\\begin{description}\n\\item[foo] ~ \n\\subsection{bar}\n\nbaz\n\\end{description}" - , "containing image" =: - header 1 (image "imgs/foo.jpg" "" (text "Alt text")) =?> - "\\section{\\texorpdfstring{\\protect\\includegraphics{imgs/foo.jpg}}{Alt text}}" - ] - , testGroup "inline code" - [ "struck out and highlighted" =: - strikeout (codeWith ("",["haskell"],[]) "foo" <> space - <> str "bar") =?> - "\\sout{\\mbox{\\VERB|\\NormalTok{foo}|} bar}" - , "struck out and not highlighted" =: - strikeout (code "foo" <> space - <> str "bar") =?> - "\\sout{\\texttt{foo} bar}" - , "single quotes" =: - code "dog's" =?> "\\texttt{dog\\textquotesingle{}s}" - , "backtick" =: - code "`nu?`" =?> "\\texttt{\\textasciigrave{}nu?\\textasciigrave{}}" - ] - , testGroup "writer options" - [ testGroup "top-level division" $ - let - headers = header 1 (text "header1") - <> header 2 (text "header2") - <> header 3 (text "header3") - - latexTopLevelDiv :: (ToPandoc a) => TopLevelDivision -> a -> String - latexTopLevelDiv division = - latexWithOpts def{ writerTopLevelDivision = division } - - beamerTopLevelDiv :: (ToPandoc a) - => TopLevelDivision -> a -> String - beamerTopLevelDiv division = - beamerWithOpts def { writerTopLevelDivision = division } - in - [ test (latexTopLevelDiv TopLevelSection) - "sections as top-level" $ headers =?> - unlines [ "\\section{header1}\n" - , "\\subsection{header2}\n" - , "\\subsubsection{header3}" - ] - , test (latexTopLevelDiv TopLevelChapter) - "chapters as top-level" $ headers =?> - unlines [ "\\chapter{header1}\n" - , "\\section{header2}\n" - , "\\subsection{header3}" - ] - , test (latexTopLevelDiv TopLevelPart) - "parts as top-level" $ headers =?> - unlines [ "\\part{header1}\n" - , "\\chapter{header2}\n" - , "\\section{header3}" - ] - , test (latexTopLevelDiv TopLevelDefault) - "default top-level" $ headers =?> - unlines [ "\\section{header1}\n" - , "\\subsection{header2}\n" - , "\\subsubsection{header3}" - ] - , test (beamerTopLevelDiv TopLevelSection) - "sections as top-level in beamer" $ headers =?> - unlines [ "\\section{header1}\n" - , "\\subsection{header2}\n" - , "\\subsubsection{header3}" - ] - , test (beamerTopLevelDiv TopLevelChapter) - "chapters are as part in beamer" $ headers =?> - unlines [ "\\part{header1}\n" - , "\\section{header2}\n" - , "\\subsection{header3}" - ] - , test (beamerTopLevelDiv TopLevelPart) - "parts as top-level in beamer" $ headers =?> - unlines [ "\\part{header1}\n" - , "\\section{header2}\n" - , "\\subsection{header3}" - ] - , test (beamerTopLevelDiv TopLevelDefault) - "default top-level in beamer" $ headers =?> - unlines [ "\\section{header1}\n" - , "\\subsection{header2}\n" - , "\\subsubsection{header3}" - ] - , test (latexTopLevelDiv TopLevelPart) - "part top-level, section not in toc" $ - ( headerWith ("", ["unnumbered"], []) 1 (text "header1") - <> headerWith ("", ["unnumbered"], []) 2 (text "header2") - <> headerWith ("", ["unnumbered"], []) 3 (text "header3") - <> headerWith ("", ["unnumbered"], []) 4 (text "header4") - <> headerWith ("", ["unnumbered"], []) 5 (text "header5") - <> headerWith ("", ["unnumbered"], []) 6 (text "header6")) - =?> - unlines [ "\\part*{header1}" - , "\\addcontentsline{toc}{part}{header1}\n" - , "\\chapter*{header2}" - , "\\addcontentsline{toc}{chapter}{header2}\n" - , "\\section*{header3}" - , "\\addcontentsline{toc}{section}{header3}\n" - , "\\subsection*{header4}" - , "\\addcontentsline{toc}{subsection}{header4}\n" - , "\\subsubsection*{header5}" - , "\\addcontentsline{toc}{subsubsection}{header5}\n" - , "\\paragraph{header6}" - , "\\addcontentsline{toc}{paragraph}{header6}" - ] - ] - ] - ] diff --git a/test/Tests/Writers/Markdown.hs.orig b/test/Tests/Writers/Markdown.hs.orig deleted file mode 100644 index 7f9ac3627..000000000 --- a/test/Tests/Writers/Markdown.hs.orig +++ /dev/null @@ -1,267 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -{-# OPTIONS_GHC -fno-warn-name-shadowing #-} -module Tests.Writers.Markdown (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -defopts :: WriterOptions -defopts = def{ writerExtensions = pandocExtensions } - -markdown :: (ToPandoc a) => a -> String -markdown = unpack . purely (writeMarkdown defopts) . toPandoc - -markdownWithOpts :: (ToPandoc a) => WriterOptions -> a -> String -markdownWithOpts opts x = unpack . purely (writeMarkdown opts) $ toPandoc x - -{- - "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) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test markdown - -tests :: [TestTree] -tests = [ "indented code after list" - =: (orderedList [ para "one" <> para "two" ] <> codeBlock "test") - =?> "1. one\n\n two\n\n\n\n test" - , "list with tight sublist" - =: bulletList [ plain "foo" <> bulletList [ plain "bar" ], - plain "baz" ] - =?> "- foo\n - bar\n- baz\n" - ] ++ [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 :: TestTree -noteTests = testGroup "note and reference location" - [ test (markdownWithOpts defopts) - "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." - ]) - , test (markdownWithOpts defopts{writerReferenceLocation=EndOfBlock}) - "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." - ]) - , test (markdownWithOpts defopts{writerReferenceLocation=EndOfBlock, writerReferenceLinks=True}) - "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." - ]) - , test (markdownWithOpts defopts{writerReferenceLocation=EndOfSection}) - "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." - ]) - - ] - -shortcutLinkRefsTests :: TestTree -shortcutLinkRefsTests = - let infix 4 =: - (=:) :: (ToString a, ToPandoc a) - - => String -> (a, String) -> TestTree - (=:) = test (purely (writeMarkdown defopts{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]") - =?> unlines [ "[link][]\\[text in brackets\\]" - , "" - , " [link]: /url" - ] - , "Reference link is followed by space and text in brackets" - =: para ((link "/url" "" "link") <> " [text in brackets]") - =?> unlines [ "[link][] \\[text in brackets\\]" - , "" - , " [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" - ] - ] diff --git a/test/Tests/Writers/Muse.hs.orig b/test/Tests/Writers/Muse.hs.orig deleted file mode 100644 index b86dee5e1..000000000 --- a/test/Tests/Writers/Muse.hs.orig +++ /dev/null @@ -1,410 +0,0 @@ -module Tests.Writers.Muse (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -muse :: (ToPandoc a) => a -> String -muse = museWithOpts def{ writerWrapText = WrapNone, - writerExtensions = extensionsFromList [Ext_amuse, - Ext_auto_identifiers] } - -museWithOpts :: (ToPandoc a) => WriterOptions -> a -> String -museWithOpts opts = unpack . purely (writeMuse opts) . toPandoc - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test muse - -tests :: [TestTree] -tests = [ testGroup "block elements" - [ "plain" =: plain (text "Foo bar.") =?> "Foo bar." - , testGroup "paragraphs" - [ "single paragraph" =: para (text "Sample paragraph.") - =?> "Sample paragraph." - , "two paragraphs" =: para (text "First paragraph.") <> - para (text "Second paragraph.") - =?> unlines [ "First paragraph." - , "" - , "Second paragraph." - ] - ] - , "line block" =: lineBlock [text "Foo", text "bar", text "baz"] - =?> unlines [ "> Foo" - , "> bar" - , "> baz" - ] - , "code block" =: codeBlock "int main(void) {\n\treturn 0;\n}" - =?> unlines [ "" - , "int main(void) {" - , "\treturn 0;" - , "}" - , "" - ] - , "html raw block" =: rawBlock "html" "
" - =?> unlines [ "" - , "
" - , "
" - ] - , "block quote" =: blockQuote (para (text "Foo")) - =?> unlines [ "" - , "Foo" - , "" - ] - , testGroup "lists" - [ testGroup "simple lists" - [ - "ordered list" =: orderedList [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ] - =?> unlines [ " 1. first" - , " 2. second" - , " 3. third" - ] - , "ordered list with Roman numerals" - =: orderedListWith (1, UpperRoman, DefaultDelim) - [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ] - =?> unlines [ " I. first" - , " II. second" - , " III. third" - ] - , "bullet list" =: bulletList [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ] - =?> unlines [ " - first" - , " - second" - , " - third" - ] - , "definition list" =: definitionList [ (text "first definition", [plain $ text "first description"]) - , (text "second definition", [plain $ text "second description"]) - , (text "third definition", [plain $ text "third description"]) - ] - =?> unlines [ " first definition :: first description" - , " second definition :: second description" - , " third definition :: third description" - ] - , "definition list with multiple descriptions" =: - definitionList [ (text "first definition", [plain $ text "first description" - ,plain $ text "second description"]) - , (text "second definition", [plain $ text "third description"]) - ] - =?> unlines [ " first definition :: first description" - , " :: second description" - , " second definition :: third description" - ] - , "definition list with empty term" =: - definitionList [ (text "first definition", [plain $ text "first description"]) - , (mempty, [plain $ text "second description"]) - , (str "", [plain $ text "third description"]) - ] - =?> unlines [ " first definition :: first description" - , " :: second description" - , " :: third description" - ] - ] - -- Test that lists of the same type and style are separated with two blanklines - , testGroup "sequential lists" - [ "bullet lists" =: - bulletList [ para $ text "First" - , para $ text "Second" - , para $ text "Third" - ] <> - bulletList [ para $ text "Fourth" - , para $ text "Fifth" - ] =?> - unlines [ " - First" - , " - Second" - , " - Third" - , "" - , "" - , " - Fourth" - , " - Fifth" - ] - , "ordered lists of the same style" =: - orderedListWith (1, UpperRoman, DefaultDelim) [ para $ text "First" - , para $ text "Second" - ] <> - orderedListWith (1, UpperRoman, DefaultDelim) [ para $ text "Third" - , para $ text "Fourth" - ] =?> - unlines [ " I. First" - , " II. Second" - , "" - , "" - , " I. Third" - , " II. Fourth" - ] - , "ordered lists with equal styles" =: - orderedList [ para $ text "First" - , para $ text "Second" - ] <> - orderedListWith (1, Decimal, DefaultDelim) [ para $ text "Third" - , para $ text "Fourth" - ] =?> - unlines [ " 1. First" - , " 2. Second" - , "" - , "" - , " 1. Third" - , " 2. Fourth" - ] - , "bullet and ordered lists" =: - bulletList [ para $ text "First" - , para $ text "Second" - ] <> - orderedListWith (1, UpperRoman, DefaultDelim) [ para $ text "Third" - , para $ text "Fourth" - ] =?> - unlines [ " - First" - , " - Second" - , "" - , " I. Third" - , " II. Fourth" - ] - , "different style ordered lists" =: - orderedListWith (1, UpperRoman, DefaultDelim) [ para $ text "First" - , para $ text "Second" - ] <> - orderedListWith (1, Decimal, DefaultDelim) [ para $ text "Third" - , para $ text "Fourth" - ] =?> - unlines [ " I. First" - , " II. Second" - , "" - , " 1. Third" - , " 2. Fourth" - ] - ] - , testGroup "nested lists" - [ "nested ordered list" =: orderedList [ plain $ text "First outer" - , plain (text "Second outer:") <> - orderedList [ plain $ text "first" - , plain $ text "second" - ] - , plain $ text "Third outer" - ] - =?> unlines [ " 1. First outer" - , " 2. Second outer:" - , " 1. first" - , " 2. second" - , " 3. Third outer" - ] - , "nested bullet lists" =: bulletList [ plain $ text "First outer" - , plain (text "Second outer:") <> - bulletList [ plain $ text "first" - , plain $ text "second" - ] - , plain $ text "Third outer" - ] - =?> unlines [ " - First outer" - , " - Second outer:" - , " - first" - , " - second" - , " - Third outer" - ] - , "nested definition lists" =: definitionList [ (text "first definition", [plain $ text "first description"]) - , (text "second definition", - [ plain (text "second description") <> - definitionList [ ( text "first inner definition" - , [plain $ text "first inner description"]) - , ( text "second inner definition" - , [plain $ text "second inner description"]) - ] - ] - ) - ] - =?> unlines [ " first definition :: first description" - , " second definition :: second description" - , " first inner definition :: first inner description" - , " second inner definition :: second inner description" - ] - ] - -- Check that list is intended with one space even inside a quote - , "List inside block quote" =: blockQuote (orderedList [ plain $ text "first" - , plain $ text "second" - , plain $ text "third" - ]) - =?> unlines [ "" - , " 1. first" - , " 2. second" - , " 3. third" - , "" - ] - ] - , testGroup "headings" - [ "normal heading" =: - header 1 (text "foo") =?> "* foo" - , "heading levels" =: - header 1 (text "First level") <> - header 3 (text "Third level") =?> - unlines [ "* First level" - , "" - , "*** Third level" - ] - , "heading with ID" =: - headerWith ("bar", [], []) 2 (text "Foo") =?> - unlines [ "** Foo" - , "#bar" - ] - ] - , "horizontal rule" =: horizontalRule =?> "----" - , "escape horizontal rule" =: para (text "----") =?> "----" - , "escape nonbreaking space" =: para (text "~~") =?> "~~" - , testGroup "tables" - [ "table without header" =: - let rows = [[para $ text "Para 1.1", para $ text "Para 1.2"] - ,[para $ text "Para 2.1", para $ text "Para 2.2"]] - in simpleTable [] rows - =?> - unlines [ " Para 1.1 | Para 1.2" - , " Para 2.1 | Para 2.2" - ] - , "table with header" =: - let headers = [plain $ text "header 1", plain $ text "header 2"] - rows = [[para $ text "Para 1.1", para $ text "Para 1.2"] - ,[para $ text "Para 2.1", para $ text "Para 2.2"]] - in simpleTable headers rows - =?> - unlines [ " header 1 || header 2" - , " Para 1.1 | Para 1.2" - , " Para 2.1 | Para 2.2" - ] - , "table with header and caption" =: - let caption = text "Table 1" - headers = [plain $ text "header 1", plain $ text "header 2"] - rows = [[para $ text "Para 1.1", para $ text "Para 1.2"] - ,[para $ text "Para 2.1", para $ text "Para 2.2"]] - in table caption mempty headers rows - =?> unlines [ " header 1 || header 2" - , " Para 1.1 | Para 1.2" - , " Para 2.1 | Para 2.2" - , " |+ Table 1 +|" - ] - ] - , "div with bullet list" =: - divWith nullAttr (bulletList [para $ text "foo"]) =?> - unlines [ " - foo" ] -- Making sure bullets are indented - -- Null is trivial - ] - , testGroup "inline elements" - [ testGroup "string" - [ "string" =: str "foo" =?> "foo" - , "escape footnote" =: str "[1]" =?> "[1]" - , "escape verbatim close tag" =: str "foobar" - =?> "foo</verbatim>bar" - , "escape pipe to avoid accidental tables" =: str "foo | bar" - =?> "foo | bar" - , "escape hash to avoid accidental anchors" =: text "#foo bar" - =?> "#foo bar" - , "escape definition list markers" =: str "::" =?> "::" - , "normalize strings before escaping" =: fromList [Str ":", Str ":"] =?> "::" - -- We don't want colons to be escaped if they can't be confused - -- with definition list item markers. - , "do not escape colon" =: str ":" =?> ":" - , "escape - to avoid accidental unordered lists" =: text " - foo" =?> " - foo" - , "escape - inside a list to avoid accidental nested unordered lists" =: - bulletList [ (para $ text "foo") <> - (para $ text "- bar") - ] =?> - unlines [ " - foo" - , "" - , " - bar" - ] - ] - , testGroup "emphasis" - [ "emph" =: emph (text "foo") =?> "foo" - , "strong" =: strong (text "foo") =?> "foo" - , "strikeout" =: strikeout (text "foo") =?> "foo" - ] - , "superscript" =: superscript (text "foo") =?> "foo" - , "subscript" =: subscript (text "foo") =?> "foo" - , "smallcaps" =: smallcaps (text "foo") =?> "foo" - , "smallcaps near emphasis" =: emph (str "foo") <> smallcaps (str "bar") =?> "foobar" - , "single quoted" =: singleQuoted (text "foo") =?> "‘foo’" - , "double quoted" =: doubleQuoted (text "foo") =?> "“foo”" - -- Cite is trivial - , testGroup "code" - [ "simple" =: code "foo" =?> "foo" - , "escape tag" =: code "foo = bar baz" =?> "foo = bar</code> baz" - , "normalization with attributes" =: codeWith ("",["haskell"],[]) "foo" <> code "bar" =?> "foobar" - , "normalization" =: code " code "de>" =?> "</code>" - , "normalization with empty string" =: code " str "" <> code "de>" =?> "</code>" - ] - , testGroup "spaces" - [ "space" =: text "a" <> space <> text "b" =?> "a b" - , "soft break" =: text "a" <> softbreak <> text "b" =?> "a b" - , test (museWithOpts def{ writerWrapText = WrapPreserve }) - "preserve soft break" $ text "a" <> softbreak <> text "b" - =?> "a\nb" - , "line break" =: text "a" <> linebreak <> text "b" =?> "a
\nb" - ] - , testGroup "math" - [ "inline math" =: math "2^3" =?> "23" - , "display math" =: displayMath "2^3" =?> "23" - , "multiple letters in inline math" =: math "abc" =?> "abc" - , "expand math before normalization" =: math "[" <> str "2]" =?> "[2]" - , "multiple math expressions inside one inline list" =: math "5_4" <> text ", " <> displayMath "3^2" =?> "54, 32" - ] - , "raw inline" - =: rawInline "html" "marked text" - =?> "marked text" - , testGroup "links" - [ "link with description" =: link "https://example.com" "" (str "Link 1") - =?> "[[https://example.com][Link 1]]" - , "link without description" =: link "https://example.com" "" (str "https://example.com") - =?> "[[https://example.com]]" - -- Internal links in Muse include '#' - , "link to anchor" =: link "#intro" "" (str "Introduction") - =?> "[[#intro][Introduction]]" - -- According to Emacs Muse manual, links to images should be prefixed with "URL:" - , "link to image with description" =: link "1.png" "" (str "Link to image") - =?> "[[URL:1.png][Link to image]]" - , "link to image without description" =: link "1.png" "" (str "1.png") - =?> "[[URL:1.png]]" - ] - , "image" =: image "image.png" "Image 1" (str "") =?> "[[image.png][Image 1]]" - , "image with width" =: - imageWith ("", [], [("width", "60%")]) "image.png" "Image" (str "") =?> - "[[image.png 60][Image]]" - , "note" =: note (plain (text "Foo")) - =?> unlines [ "[1]" - , "" - , "[1] Foo" - ] - , "span with class" =: spanWith ("",["foobar"],[]) (text "Some text") - =?> "Some text" - , "span with anchor" =: spanWith ("anchor", [], []) (text "Foo bar") - =?> "#anchor Foo bar" - , "span with class and anchor" =: spanWith ("anchor", ["foo"], []) (text "bar") - =?> "#anchor bar" - , testGroup "combined" - [ "emph word before" =: - para (text "foo" <> emph (text "bar")) =?> - "foobar" - , "emph word after" =: - para (emph (text "foo") <> text "bar") =?> - "foobar" - , "emph quoted" =: - para (doubleQuoted (emph (text "foo"))) =?> - "“foo”" - , "strong word before" =: - para (text "foo" <> strong (text "bar")) =?> - "foobar" - , "strong word after" =: - para (strong (text "foo") <> text "bar") =?> - "foobar" - , "strong quoted" =: - para (singleQuoted (strong (text "foo"))) =?> - "‘foo’" - ] - ] - ] diff --git a/test/Tests/Writers/Native.hs.orig b/test/Tests/Writers/Native.hs.orig deleted file mode 100644 index 0c4bf7623..000000000 --- a/test/Tests/Writers/Native.hs.orig +++ /dev/null @@ -1,22 +0,0 @@ -module Tests.Writers.Native (tests) where - -import Data.Text (unpack) -import Test.Tasty -import Test.Tasty.QuickCheck -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () - -p_write_rt :: Pandoc -> Bool -p_write_rt d = - read (unpack $ purely (writeNative def{ writerTemplate = Just "" }) d) == d - -p_write_blocks_rt :: [Block] -> Bool -p_write_blocks_rt bs = - read (unpack $ purely (writeNative def) (Pandoc nullMeta bs)) == bs - -tests :: [TestTree] -tests = [ testProperty "p_write_rt" p_write_rt - , testProperty "p_write_blocks_rt" $ mapSize - (\x -> if x > 3 then 3 else x) p_write_blocks_rt - ] diff --git a/test/Tests/Writers/OOXML.hs.orig b/test/Tests/Writers/OOXML.hs.orig deleted file mode 100644 index bdfdea145..000000000 --- a/test/Tests/Writers/OOXML.hs.orig +++ /dev/null @@ -1,184 +0,0 @@ -{-# LANGUAGE PatternGuards #-} -{-# LANGUAGE OverloadedStrings #-} - -module Tests.Writers.OOXML (ooxmlTest) where - -import Text.Pandoc -import Test.Tasty -import Test.Tasty.Golden.Advanced -import Codec.Archive.Zip -import Text.XML.Light -import qualified Data.ByteString as BS -import qualified Data.ByteString.Lazy as BL -import qualified Data.Text.IO as T -import Data.List (isSuffixOf, sort, (\\), intercalate, union) -import Data.Maybe (catMaybes, mapMaybe) -import Tests.Helpers -import Data.Algorithm.Diff -import System.FilePath.Glob (compile, match) - -compareXMLBool :: Content -> Content -> Bool --- We make a special exception for times at the moment, and just pass --- them because we can't control the utctime when running IO. Besides, --- so long as we have two times, we're okay. -compareXMLBool (Elem myElem) (Elem goodElem) - | (QName "created" _ (Just "dcterms")) <- elName myElem - , (QName "created" _ (Just "dcterms")) <- elName goodElem = - True -compareXMLBool (Elem myElem) (Elem goodElem) - | (QName "modified" _ (Just "dcterms")) <- elName myElem - , (QName "modified" _ (Just "dcterms")) <- elName goodElem = - True -compareXMLBool (Elem myElem) (Elem goodElem) = - elName myElem == elName goodElem && - elAttribs myElem == elAttribs goodElem && - and (zipWith compareXMLBool (elContent myElem) (elContent goodElem)) -compareXMLBool (Text myCData) (Text goodCData) = - cdVerbatim myCData == cdVerbatim goodCData && - cdData myCData == cdData goodCData && - cdLine myCData == cdLine goodCData -compareXMLBool (CRef myStr) (CRef goodStr) = - myStr == goodStr -compareXMLBool _ _ = False - -displayDiff :: Content -> Content -> String -displayDiff elemA elemB = - showDiff (1,1) $ getDiff (lines $ ppContent elemA) (lines $ ppContent elemB) - -goldenArchive :: FilePath -> IO Archive -goldenArchive fp = (toArchive . BL.fromStrict) <$> BS.readFile fp - -testArchive :: (WriterOptions -> Pandoc -> PandocIO BL.ByteString) - -> WriterOptions - -> FilePath - -> IO Archive -testArchive writerFn opts fp = do - txt <- T.readFile fp - bs <- runIOorExplode $ readNative def txt >>= writerFn opts - return $ toArchive bs - -compareFileList :: FilePath -> Archive -> Archive -> Maybe String -compareFileList goldenFP goldenArch testArch = - let testFiles = filesInArchive testArch - goldenFiles = filesInArchive goldenArch - diffTestGolden = testFiles \\ goldenFiles - diffGoldenTest = goldenFiles \\ testFiles - - results = - [ if null diffGoldenTest - then Nothing - else Just $ - "Files in " ++ goldenFP ++ " but not in generated archive:\n" ++ - intercalate ", " diffGoldenTest - , if null diffTestGolden - then Nothing - else Just $ - "Files in generated archive but not in " ++ goldenFP ++ ":\n" ++ - intercalate ", " diffTestGolden - ] - in - if null $ catMaybes results - then Nothing - else Just $ intercalate "\n" $ catMaybes results - -compareXMLFile' :: FilePath -> Archive -> Archive -> Either String () -compareXMLFile' fp goldenArch testArch = do - testEntry <- case findEntryByPath fp testArch of - Just entry -> Right entry - Nothing -> Left $ - "Can't extract " ++ fp ++ " from generated archive" - testXMLDoc <- case parseXMLDoc $ fromEntry testEntry of - Just doc -> Right doc - Nothing -> Left $ - "Can't parse xml in " ++ fp ++ " from generated archive" - - goldenEntry <- case findEntryByPath fp goldenArch of - Just entry -> Right entry - Nothing -> Left $ - "Can't extract " ++ fp ++ " from archive in stored file" - goldenXMLDoc <- case parseXMLDoc $ fromEntry goldenEntry of - Just doc -> Right doc - Nothing -> Left $ - "Can't parse xml in " ++ fp ++ " from archive in stored file" - - let testContent = Elem testXMLDoc - goldenContent = Elem goldenXMLDoc - - if compareXMLBool goldenContent testContent - then Right () - else Left $ - "Non-matching xml in " ++ fp ++ ":\n" ++ displayDiff testContent goldenContent - -compareXMLFile :: FilePath -> Archive -> Archive -> Maybe String -compareXMLFile fp goldenArch testArch = - case compareXMLFile' fp goldenArch testArch of - Right _ -> Nothing - Left s -> Just s - -compareAllXMLFiles :: Archive -> Archive -> Maybe String -compareAllXMLFiles goldenArch testArch = - let allFiles = filesInArchive goldenArch `union` filesInArchive testArch - allXMLFiles = sort $ - filter - (\fp -> ".xml" `isSuffixOf` fp || ".rels" `isSuffixOf` fp) - allFiles - results = - mapMaybe (\fp -> compareXMLFile fp goldenArch testArch) allXMLFiles - in - if null results - then Nothing - else Just $ unlines results - -compareMediaFile' :: FilePath -> Archive -> Archive -> Either String () -compareMediaFile' fp goldenArch testArch = do - testEntry <- case findEntryByPath fp testArch of - Just entry -> Right entry - Nothing -> Left $ - "Can't extract " ++ fp ++ " from generated archive" - goldenEntry <- case findEntryByPath fp goldenArch of - Just entry -> Right entry - Nothing -> Left $ - "Can't extract " ++ fp ++ " from archive in stored file" - - if fromEntry testEntry == fromEntry goldenEntry - then Right () - else Left $ - "Non-matching binary file: " ++ fp - -compareMediaFile :: FilePath -> Archive -> Archive -> Maybe String -compareMediaFile fp goldenArch testArch = - case compareMediaFile' fp goldenArch testArch of - Right _ -> Nothing - Left s -> Just s - -compareAllMediaFiles :: Archive -> Archive -> Maybe String -compareAllMediaFiles goldenArch testArch = - let allFiles = filesInArchive goldenArch `union` filesInArchive testArch - mediaPattern = compile "*/media/*" - allMediaFiles = sort $ - filter (match mediaPattern) allFiles - results = - mapMaybe (\fp -> compareMediaFile fp goldenArch testArch) allMediaFiles - in - if null results - then Nothing - else Just $ unlines results - -ooxmlTest :: (WriterOptions -> Pandoc -> PandocIO BL.ByteString) - -> String - -> WriterOptions - -> FilePath - -> FilePath - -> TestTree -ooxmlTest writerFn testName opts nativeFP goldenFP = - goldenTest - testName - (goldenArchive goldenFP) - (testArchive writerFn opts nativeFP) - (\goldenArch testArch -> - let res = catMaybes [ compareFileList goldenFP goldenArch testArch - , compareAllXMLFiles goldenArch testArch - , compareAllMediaFiles goldenArch testArch - ] - in return $ if null res then Nothing else Just $ unlines res) - (\a -> BL.writeFile goldenFP $ fromArchive a) diff --git a/test/Tests/Writers/Org.hs.orig b/test/Tests/Writers/Org.hs.orig deleted file mode 100644 index 9cbe360da..000000000 --- a/test/Tests/Writers/Org.hs.orig +++ /dev/null @@ -1,25 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.Org (tests) where - -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test (purely (writeOrg def . toPandoc)) - -tests :: [TestTree] -tests = [ testGroup "links" - -- See http://orgmode.org/manual/Internal-links.html#Internal-links - [ "simple link" - =: link "/url" "" "foo" - =?> "[[/url][foo]]" - , "internal link to anchor" - =: link "#my-custom-id" "" "#my-custom-id" - =?> "[[#my-custom-id]]" - ] - ] diff --git a/test/Tests/Writers/Plain.hs.orig b/test/Tests/Writers/Plain.hs.orig deleted file mode 100644 index ab09bca26..000000000 --- a/test/Tests/Writers/Plain.hs.orig +++ /dev/null @@ -1,21 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.Plain (tests) where - -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test (purely (writePlain def) . toPandoc) - - -tests :: [TestTree] -tests = [ "strongly emphasized text to uppercase" - =: strong "Straße" - =?> "STRASSE" - ] diff --git a/test/Tests/Writers/Powerpoint.hs.orig b/test/Tests/Writers/Powerpoint.hs.orig deleted file mode 100644 index 9af8fc471..000000000 --- a/test/Tests/Writers/Powerpoint.hs.orig +++ /dev/null @@ -1,93 +0,0 @@ -module Tests.Writers.Powerpoint (tests) where - -import Tests.Writers.OOXML (ooxmlTest) -import Text.Pandoc -import Test.Tasty -import System.FilePath - --- templating is important enough, and can break enough things, that --- we want to run all our tests with both default formatting and a --- template. - -modifyPptxName :: FilePath -> FilePath -modifyPptxName fp = - addExtension (dropExtension fp ++ "_templated") "pptx" - -pptxTests :: String -> WriterOptions -> FilePath -> FilePath -> (TestTree, TestTree) -pptxTests name opts native pptx = - let referenceDoc = "pptx/reference_depth.pptx" - in - ( ooxmlTest - writePowerpoint - name - opts{writerReferenceDoc=Nothing} - native - pptx - , ooxmlTest - writePowerpoint - name - opts{writerReferenceDoc=Just referenceDoc} - native - (modifyPptxName pptx) - ) - -groupPptxTests :: [(TestTree, TestTree)] -> [TestTree] -groupPptxTests pairs = - let (noRefs, refs) = unzip pairs - in - [ testGroup "Default slide formatting" noRefs - , testGroup "With `--reference-doc` pptx file" refs - ] - - -tests :: [TestTree] -tests = groupPptxTests [ pptxTests "Inline formatting" - def - "pptx/inline_formatting.native" - "pptx/inline_formatting.pptx" - , pptxTests "Slide breaks (default slide-level)" - def - "pptx/slide_breaks.native" - "pptx/slide_breaks.pptx" - , pptxTests "slide breaks (slide-level set to 1)" - def{ writerSlideLevel = Just 1 } - "pptx/slide_breaks.native" - "pptx/slide_breaks_slide_level_1.pptx" - , pptxTests "lists" - def - "pptx/lists.native" - "pptx/lists.pptx" - , pptxTests "tables" - def - "pptx/tables.native" - "pptx/tables.pptx" - , pptxTests "table of contents" - def{ writerTableOfContents = True } - "pptx/slide_breaks.native" - "pptx/slide_breaks_toc.pptx" - , pptxTests "end notes" - def - "pptx/endnotes.native" - "pptx/endnotes.pptx" - , pptxTests "end notes, with table of contents" - def { writerTableOfContents = True } - "pptx/endnotes.native" - "pptx/endnotes_toc.pptx" - , pptxTests "images" - def - "pptx/images.native" - "pptx/images.pptx" - , pptxTests "two-column layout" - def - "pptx/two_column.native" - "pptx/two_column.pptx" - , pptxTests "speaker notes" - def - "pptx/speaker_notes.native" - "pptx/speaker_notes.pptx" - , pptxTests "remove empty slides" - def - "pptx/remove_empty_slides.native" - "pptx/remove_empty_slides.pptx" - - ] diff --git a/test/Tests/Writers/RST.hs.orig b/test/Tests/Writers/RST.hs.orig deleted file mode 100644 index e54ce4737..000000000 --- a/test/Tests/Writers/RST.hs.orig +++ /dev/null @@ -1,130 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.RST (tests) where - -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test (purely (writeRST def . toPandoc)) - -tests :: [TestTree] -tests = [ testGroup "rubrics" - [ "in list item" =: - bulletList [header 2 (text "foo")] =?> - "- .. rubric:: foo" - , "in definition list item" =: - definitionList [(text "foo", [header 2 (text "bar"), - para $ text "baz"])] =?> - unlines - [ "foo" - , " .. rubric:: bar" - , "" - , " baz"] - , "in block quote" =: - blockQuote (header 1 (text "bar")) =?> - " .. rubric:: bar" - , "with id" =: - blockQuote (headerWith ("foo",[],[]) 1 (text "bar")) =?> - unlines - [ " .. rubric:: bar" - , " :name: foo"] - , "with id class" =: - blockQuote (headerWith ("foo",["baz"],[]) 1 (text "bar")) =?> - unlines - [ " .. rubric:: bar" - , " :name: foo" - , " :class: baz"] - ] - , testGroup "ligatures" -- handling specific sequences of blocks - [ "a list is closed by a comment before a quote" =: -- issue 4248 - bulletList [plain "bulleted"] <> blockQuote (plain "quoted") =?> - unlines - [ "- bulleted" - , "" - , ".." - , "" - , " quoted"] - ] - , testGroup "inlines" - [ "are removed when empty" =: -- #4434 - plain (strong (str "")) =?> "" - , "do not cause the introduction of extra spaces when removed" =: - plain (strong (str "") <> emph (str "text")) =?> "*text*" - , "spaces are stripped at beginning and end" =: - -- pandoc issue 4327 "The text within inline markup may not - -- begin or end with whitespace" - -- http://docutils.sourceforge.net/docs/ref/rst/restructuredtext.html#inline-markup - strong (space <> str "text" <> space <> space) =?> "**text**" - , "single space stripped" =: - strong space =?> "" - ] - , testGroup "headings" - [ "normal heading" =: - header 1 (text "foo") =?> - unlines - [ "foo" - , "==="] - -- note: heading normalization is only done in standalone mode - , test (purely (writeRST def{ writerTemplate = Just "$body$\n" }) . toPandoc) - "heading levels" $ - header 1 (text "Header 1") <> - header 3 (text "Header 2") <> - header 2 (text "Header 2") <> - header 1 (text "Header 1") <> - header 4 (text "Header 2") <> - header 5 (text "Header 3") <> - header 3 (text "Header 2") =?> - unlines - [ "Header 1" - , "========" - , "" - , "Header 2" - , "--------" - , "" - , "Header 2" - , "--------" - , "" - , "Header 1" - , "========" - , "" - , "Header 2" - , "--------" - , "" - , "Header 3" - , "~~~~~~~~" - , "" - , "Header 2" - , "--------"] - , test (purely (writeRST def{ writerTemplate = Just "$body$\n" }) . toPandoc) - "minimal heading levels" $ - header 2 (text "Header 1") <> - header 3 (text "Header 2") <> - header 2 (text "Header 1") <> - header 4 (text "Header 2") <> - header 5 (text "Header 3") <> - header 3 (text "Header 2") =?> - unlines - [ "Header 1" - , "========" - , "" - , "Header 2" - , "--------" - , "" - , "Header 1" - , "========" - , "" - , "Header 2" - , "--------" - , "" - , "Header 3" - , "~~~~~~~~" - , "" - , "Header 2" - , "--------"] - ] - ] diff --git a/test/Tests/Writers/TEI.hs.orig b/test/Tests/Writers/TEI.hs.orig deleted file mode 100644 index fa372909f..000000000 --- a/test/Tests/Writers/TEI.hs.orig +++ /dev/null @@ -1,43 +0,0 @@ -{-# LANGUAGE OverloadedStrings #-} -module Tests.Writers.TEI (tests) where - -import Test.Tasty -import Tests.Helpers -import Text.Pandoc -import Text.Pandoc.Arbitrary () -import Text.Pandoc.Builder - -{- - "my test" =: X =?> Y - -is shorthand for - - test html "my test" $ X =?> Y - -which is in turn shorthand for - - test html "my test" (X,Y) --} - -infix 4 =: -(=:) :: (ToString a, ToPandoc a) - => String -> (a, String) -> TestTree -(=:) = test (purely (writeTEI def) . toPandoc) - -tests :: [TestTree] -tests = [ testGroup "block elements" - ["para" =: para "Lorem ipsum cetera." - =?> "

Lorem ipsum cetera.

" - ] - , testGroup "inlines" - [ - "Emphasis" =: emph "emphasized" - =?> "

emphasized

" - ,"SingleQuoted" =: singleQuoted (text "quoted material") - =?> "

quoted material

" - ,"DoubleQuoted" =: doubleQuoted (text "quoted material") - =?> "

quoted material

" - ,"NestedQuoted" =: doubleQuoted (singleQuoted (text "quoted material")) - =?> "

quoted material

" - ] - ] diff --git a/test/command/3510-src.hs.orig b/test/command/3510-src.hs.orig deleted file mode 100644 index ad5744b80..000000000 --- a/test/command/3510-src.hs.orig +++ /dev/null @@ -1 +0,0 @@ -putStrLn outString diff --git a/test/pandoc-test14632-86 b/test/pandoc-test14632-86 deleted file mode 100644 index 507e9f672..000000000 --- a/test/pandoc-test14632-86 +++ /dev/null @@ -1,1448 +0,0 @@ - - -
- - - - - - - - - - -Pandoc Test Suite - - - - -John MacFarlane - - - - -Anonymous - - - - -July 17, 2006 - - - - -

- This is a set of tests for pandoc. Most of them are adapted from John - Gruber’s markdown test suite. -

- - Headers - - Level 2 with an - <ext-link ext-link-type="uri" xlink:href="/url">embedded - link</ext-link> - - Level 3 with <italic>emphasis</italic> - - Level 4 - - Level 5 - - - - - - - Level 1 - - Level 2 with <italic>emphasis</italic> - - Level 3 -

- with no blank line -

-
-
- - Level 2 -

- with no blank line -

-
-
- - Paragraphs -

- Here’s a regular paragraph. -

-

- In Markdown 1.0.0 and earlier. Version 8. This line turns into a list - item. Because a hard-wrapped line in the middle of a paragraph looked like - a list item. -

-

- Here’s one with a bullet. * criminey. -

-

- There should be a hard line breakhere. -

-
- - Block Quotes -

- E-mail style: -

- -

- This is a block quote. It is pretty short. -

-
- -

- Code in a block quote: -

- sub status { - print "working"; -} -

- A list: -

- - -

- item one -

-
- -

- item two -

-
-
-

- Nested block quotes: -

- -

- nested -

-
- -

- nested -

-
-
-

- This should not be a block quote: 2 > 1. -

-

- And a following paragraph. -

-
- - Code Blocks -

- Code: -

- ---- (should be four hyphens) - -sub status { - print "working"; -} - -this code block is indented by one tab -

- And: -

- this code block is indented by two tabs - -These should not be escaped: \$ \\ \> \[ \{ -
- - Lists - - Unordered -

- Asterisks tight: -

- - -

- asterisk 1 -

-
- -

- asterisk 2 -

-
- -

- asterisk 3 -

-
-
-

- Asterisks loose: -

- - -

- asterisk 1 -

-
- -

- asterisk 2 -

-
- -

- asterisk 3 -

-
-
-

- Pluses tight: -

- - -

- Plus 1 -

-
- -

- Plus 2 -

-
- -

- Plus 3 -

-
-
-

- Pluses loose: -

- - -

- Plus 1 -

-
- -

- Plus 2 -

-
- -

- Plus 3 -

-
-
-

- Minuses tight: -

- - -

- Minus 1 -

-
- -

- Minus 2 -

-
- -

- Minus 3 -

-
-
-

- Minuses loose: -

- - -

- Minus 1 -

-
- -

- Minus 2 -

-
- -

- Minus 3 -

-
-
-
- - Ordered -

- Tight: -

- - -

- First -

-
- -

- Second -

-
- -

- Third -

-
-
-

- and: -

- - -

- One -

-
- -

- Two -

-
- -

- Three -

-
-
-

- Loose using tabs: -

- - -

- First -

-
- -

- Second -

-
- -

- Third -

-
-
-

- and using spaces: -

- - -

- One -

-
- -

- Two -

-
- -

- Three -

-
-
-

- Multiple paragraphs: -

- - -

- Item 1, graf one. -

-

- Item 1. graf two. The quick brown fox jumped over the lazy dog’s - back. -

-
- -

- Item 2. -

-
- -

- Item 3. -

-
-
-
- - Nested - - -

- Tab -

- - -

- Tab -

- - -

- Tab -

-
-
-
-
-
-
-

- Here’s another: -

- - -

- First -

-
- -

- Second: -

- - -

- Fee -

-
- -

- Fie -

-
- -

- Foe -

-
-
-
- -

- Third -

-
-
-

- Same thing but with paragraphs: -

- - -

- First -

-
- -

- Second: -

- - -

- Fee -

-
- -

- Fie -

-
- -

- Foe -

-
-
-
- -

- Third -

-
-
-
- - Tabs and spaces - - -

- this is a list item indented with tabs -

-
- -

- this is a list item indented with spaces -

- - -

- this is an example list item indented with tabs -

-
- -

- this is an example list item indented with spaces -

-
-
-
-
-
- - Fancy list markers - - - -

- begins with 2 -

-
- - -

- and now 3 -

-

- with a continuation -

- - - -

- sublist with roman numerals, starting with 4 -

-
- - -

- more items -

- - - -

- a subsublist -

-
- - -

- a subsublist -

-
-
-
-
-
-
-

- Nesting: -

- - -

- Upper Alpha -

- - -

- Upper Roman. -

- - - -

- Decimal start with 6 -

- - - -

- Lower alpha with paren -

-
-
-
-
-
-
-
-
-

- Autonumbering: -

- - -

- Autonumber. -

-
- -

- More. -

- - -

- Nested. -

-
-
-
-
-

- Should not be a list item: -

-

- M.A. 2007 -

-

- B. Williams -

-
-
- - Definition Lists -

- Tight using spaces: -

- - - - apple - - -

- red fruit -

-
-
- - - orange - - -

- orange fruit -

-
-
- - - banana - - -

- yellow fruit -

-
-
-
-

- Tight using tabs: -

- - - - apple - - -

- red fruit -

-
-
- - - orange - - -

- orange fruit -

-
-
- - - banana - - -

- yellow fruit -

-
-
-
-

- Loose: -

- - - - apple - - -

- red fruit -

-
-
- - - orange - - -

- orange fruit -

-
-
- - - banana - - -

- yellow fruit -

-
-
-
-

- Multiple blocks with italics: -

- - - - apple - - -

- red fruit -

-

- contains seeds, crisp, pleasant to taste -

-
-
- - - orange - - -

- orange fruit -

- { orange code block } - -

- orange block quote -

-
-
-
-
-

- Multiple definitions, tight: -

- - - - apple - - -

- red fruit -

-

- computer -

-
-
- - - orange - - -

- orange fruit -

-

- bank -

-
-
-
-

- Multiple definitions, loose: -

- - - - apple - - -

- red fruit -

-

- computer -

-
-
- - - orange - - -

- orange fruit -

-

- bank -

-
-
-
-

- Blank line after term, indented marker, alternate markers: -

- - - - apple - - -

- red fruit -

-

- computer -

-
-
- - - orange - - -

- orange fruit -

- - -

- sublist -

-
- -

- sublist -

-
-
-
-
-
-
- - HTML Blocks -

- Simple block on one line: -

- -

- foo -

-
-

- And nested without indentation: -

- - - -

- foo -

-
-
- -

- bar -

-
-
-

- Interpreted markdown in a table: -

-

- This is emphasized -

-

- And this is strong -

-

- Here’s a simple block: -

- -

- foo -

-
-

- This should be a code block, though: -

- <div> - foo -</div> -

- As should this: -

- <div>foo</div> -

- Now, nested: -

- - - -

- foo -

-
-
-
-

- This should just be an HTML comment: -

-

- Multiline: -

-

- Code block: -

- <!-- Comment --> -

- Just plain comment, with trailing spaces on the line: -

-

- Code: -

- <hr /> -

- Hr’s: -

-
- - Inline Markup -

- This is emphasized, and so is this. -

-

- This is strong, and so is - this. -

-

- An emphasized - link. -

-

- This is strong and em. -

-

- So is this word. -

-

- This is strong and em. -

-

- So is this word. -

-

- This is code: >, $, - \, \$, - <html>. -

-

- This is strikeout. -

-

- Superscripts: abcd ahello - ahello there. -

-

- Subscripts: H2O, H23O, Hmany of themO. -

-

- These should not be superscripts or subscripts, because of the unescaped - spaces: a^b c^d, a~b c~d. -

-
- - Smart quotes, ellipses, dashes -

- “Hello,” said the spider. “‘Shelob’ is my name.” -

-

- ‘A’, ‘B’, and ‘C’ are letters. -

-

- ‘Oak,’ ‘elm,’ and ‘beech’ are names of trees. So is ‘pine.’ -

-

- ‘He said, “I want to go.”’ Were you alive in the 70’s? -

-

- Here is some quoted ‘code’ and a - “quoted - link”. -

-

- Some dashes: one—two — three—four — five. -

-

- Dashes between numbers: 5–7, 255–66, 1987–1999. -

-

- Ellipses…and…and…. -

-
- - LaTeX - - -

-

-
- -

- - - 2+2=4 -

-
- -

- - - xy -

-
- -

- - - αω -

-
- -

- - - 223 -

-
- -

- - - p-Tree -

-
- -

- Here’s some display math: - - ddxf(x)=limh0f(x+h)f(x)h -

-
- -

- Here’s one that has a line break in it: - - α+ω×x2. -

-
-
-

- These shouldn’t be math: -

- - -

- To get the famous equation, write $e = mc^2$. -

-
- -

- $22,000 is a lot of money. So is $34,000. (It worked - if “lot” is emphasized.) -

-
- -

- Shoes ($20) and socks ($5). -

-
- -

- Escaped $: $73 this should be - emphasized 23$. -

-
-
-

- Here’s a LaTeX table: -

-
- - Special Characters -

- Here is some unicode: -

- - -

- I hat: Î -

-
- -

- o umlaut: ö -

-
- -

- section: § -

-
- -

- set membership: ∈ -

-
- -

- copyright: © -

-
-
-

- AT&T has an ampersand in their name. -

-

- AT&T is another way to write it. -

-

- This & that. -

-

- 4 < 5. -

-

- 6 > 5. -

-

- Backslash: \ -

-

- Backtick: ` -

-

- Asterisk: * -

-

- Underscore: _ -

-

- Left brace: { -

-

- Right brace: } -

-

- Left bracket: [ -

-

- Right bracket: ] -

-

- Left paren: ( -

-

- Right paren: ) -

-

- Greater-than: > -

-

- Hash: # -

-

- Period: . -

-

- Bang: ! -

-

- Plus: + -

-

- Minus: - -

-
- - Links - - Explicit -

- Just a URL. -

-

- URL - and title. -

-

- URL - and title. -

-

- URL - and title. -

-

- URL - and title -

-

- URL - and title -

-

- with_underscore -

-

- Email - link -

-

- Empty. -

-
- - Reference -

- Foo bar. -

-

- With embedded - [brackets]. -

-

- b by itself - should be a link. -

-

- Indented - once. -

-

- Indented - twice. -

-

- Indented - thrice. -

-

- This should [not][] be a link. -

- [not]: /url -

- Foo - bar. -

-

- Foo - biz. -

-
- - With ampersands -

- Here’s a - link - with an ampersand in the URL. -

-

- Here’s a link with an amersand in the link text: - AT&T. -

-

- Here’s an - inline - link. -

-

- Here’s an - inline - link in pointy braces. -

-
- - Autolinks -

- With an ampersand: - http://example.com/?foo=1&bar=2 -

- - -

- In a list? -

-
- -

- http://example.com/ -

-
- -

- It should. -

-
-
-

- An e-mail address: nobody@nowhere.net -

- -

- Blockquoted: - http://example.com/ -

-
-

- Auto-links should not occur here: - <http://example.com/> -

- or here: <http://example.com/> -
-
- - Images -

- From “Voyage dans la Lune” by Georges Melies (1902): -

- - lalune - - -

- Here is a movie - - icon. -

-
- - Footnotes -

- Here is a footnote reference, -

- Here is the footnote. It can go anywhere after the footnote reference. - It need not be placed at the end of the document. -

- and another. -

- Here’s the long note. This one contains multiple blocks. -

-

- Subsequent blocks are indented to show that they belong to the - footnote (as with list items). -

- { <code> } -

- If you want, you can indent every line, but you can also be lazy and - just indent the first line of each block. -

-
This should not be a footnote reference, because it - contains a space.[^my note] Here is an inline note. -

- This is easier to type. Inline notes may contain - links - and ] verbatim characters, as well as - [bracketed text]. -

-
-

- -

- Notes can go in quotes. -

- In quote. -

- -

-
- - -

- And in list items. -

- In list. -

- -

-
-
-

- This paragraph should not be part of the note, as it is not indented. -

-
- - - -
diff --git a/test/pandoc-test14632-89 b/test/pandoc-test14632-89 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-90 b/test/pandoc-test14632-90 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-91 b/test/pandoc-test14632-91 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-94 b/test/pandoc-test14632-94 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-95 b/test/pandoc-test14632-95 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-96 b/test/pandoc-test14632-96 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test14632-97 b/test/pandoc-test14632-97 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-78 b/test/pandoc-test77993-78 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-79 b/test/pandoc-test77993-79 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-82 b/test/pandoc-test77993-82 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-83 b/test/pandoc-test77993-83 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-86 b/test/pandoc-test77993-86 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-87 b/test/pandoc-test77993-87 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-90 b/test/pandoc-test77993-90 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test77993-91 b/test/pandoc-test77993-91 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-110 b/test/pandoc-test88473-110 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-111 b/test/pandoc-test88473-111 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-112 b/test/pandoc-test88473-112 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-113 b/test/pandoc-test88473-113 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-116 b/test/pandoc-test88473-116 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-117 b/test/pandoc-test88473-117 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-118 b/test/pandoc-test88473-118 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test88473-119 b/test/pandoc-test88473-119 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-86 b/test/pandoc-test94017-86 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-87 b/test/pandoc-test94017-87 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-90 b/test/pandoc-test94017-90 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-91 b/test/pandoc-test94017-91 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-92 b/test/pandoc-test94017-92 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/pandoc-test94017-93 b/test/pandoc-test94017-93 deleted file mode 100644 index e69de29bb..000000000 diff --git a/test/test-pandoc.hs.orig b/test/test-pandoc.hs.orig deleted file mode 100644 index 4cf1a952d..000000000 --- a/test/test-pandoc.hs.orig +++ /dev/null @@ -1,83 +0,0 @@ -{-# OPTIONS_GHC -Wall #-} - -module Main where - -import GHC.IO.Encoding -import Test.Tasty -import qualified Tests.Command -import qualified Tests.Lua -import qualified Tests.Old -import qualified Tests.Readers.Creole -import qualified Tests.Readers.Docx -import qualified Tests.Readers.EPUB -import qualified Tests.Readers.HTML -import qualified Tests.Readers.JATS -import qualified Tests.Readers.LaTeX -import qualified Tests.Readers.Markdown -import qualified Tests.Readers.Muse -import qualified Tests.Readers.Odt -import qualified Tests.Readers.Org -import qualified Tests.Readers.RST -import qualified Tests.Readers.Txt2Tags -import qualified Tests.Shared -import qualified Tests.Writers.AsciiDoc -import qualified Tests.Writers.ConTeXt -import qualified Tests.Writers.Docbook -import qualified Tests.Writers.Docx -import qualified Tests.Writers.FB2 -import qualified Tests.Writers.HTML -import qualified Tests.Writers.JATS -import qualified Tests.Writers.LaTeX -import qualified Tests.Writers.Markdown -import qualified Tests.Writers.Muse -import qualified Tests.Writers.Native -import qualified Tests.Writers.Org -import qualified Tests.Writers.Plain -import qualified Tests.Writers.Powerpoint -import qualified Tests.Writers.RST -import qualified Tests.Writers.TEI -import Text.Pandoc.Shared (inDirectory) - -tests :: TestTree -tests = testGroup "pandoc tests" [ Tests.Command.tests - , testGroup "Old" Tests.Old.tests - , testGroup "Shared" Tests.Shared.tests - , testGroup "Writers" - [ testGroup "Native" Tests.Writers.Native.tests - , testGroup "ConTeXt" Tests.Writers.ConTeXt.tests - , testGroup "LaTeX" Tests.Writers.LaTeX.tests - , testGroup "HTML" Tests.Writers.HTML.tests - , testGroup "JATS" Tests.Writers.JATS.tests - , testGroup "Docbook" Tests.Writers.Docbook.tests - , testGroup "Markdown" Tests.Writers.Markdown.tests - , testGroup "Org" Tests.Writers.Org.tests - , testGroup "Plain" Tests.Writers.Plain.tests - , testGroup "AsciiDoc" Tests.Writers.AsciiDoc.tests - , testGroup "Docx" Tests.Writers.Docx.tests - , testGroup "RST" Tests.Writers.RST.tests - , testGroup "TEI" Tests.Writers.TEI.tests - , testGroup "Muse" Tests.Writers.Muse.tests - , testGroup "FB2" Tests.Writers.FB2.tests - , testGroup "PowerPoint" Tests.Writers.Powerpoint.tests - ] - , testGroup "Readers" - [ testGroup "LaTeX" Tests.Readers.LaTeX.tests - , testGroup "Markdown" Tests.Readers.Markdown.tests - , testGroup "HTML" Tests.Readers.HTML.tests - , testGroup "JATS" Tests.Readers.JATS.tests - , testGroup "Org" Tests.Readers.Org.tests - , testGroup "RST" Tests.Readers.RST.tests - , testGroup "Docx" Tests.Readers.Docx.tests - , testGroup "Odt" Tests.Readers.Odt.tests - , testGroup "Txt2Tags" Tests.Readers.Txt2Tags.tests - , testGroup "EPUB" Tests.Readers.EPUB.tests - , testGroup "Muse" Tests.Readers.Muse.tests - , testGroup "Creole" Tests.Readers.Creole.tests - ] - , testGroup "Lua filters" Tests.Lua.tests - ] - -main :: IO () -main = do - setLocaleEncoding utf8 - inDirectory "test" $ defaultMain tests -- cgit v1.2.3