2017-12-13 12:06:22 +13:00
|
|
|
|
{-# 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 "@&" =?> "<p>\n <monospace>@&</monospace>\n</p>"
|
2017-12-20 23:55:48 +13:00
|
|
|
|
, "lang" =: codeWith ("", ["c"], []) "@&" =?> "<p>\n <code language=\"c\">@&</code>\n</p>"
|
|
|
|
|
]
|
|
|
|
|
, testGroup "block code"
|
|
|
|
|
[ "basic" =: codeBlock "@&" =?> "<preformat>@&</preformat>"
|
|
|
|
|
, "lang" =: codeBlockWith ("", ["c"], []) "@&" =?> "<code language=\"c\">@&</code>"
|
2017-12-13 12:06:22 +13:00
|
|
|
|
]
|
|
|
|
|
, testGroup "images"
|
|
|
|
|
[ "basic" =:
|
|
|
|
|
image "/url" "title" mempty
|
|
|
|
|
=?> "<graphic mimetype=\"image\" mime-subtype=\"\" xlink:href=\"/url\" xlink:title=\"title\" />"
|
|
|
|
|
]
|
|
|
|
|
, testGroup "inlines"
|
2017-12-20 23:55:48 +13:00
|
|
|
|
[ "Emphasis" =: emph "emphasized"
|
2017-12-13 12:06:22 +13:00
|
|
|
|
=?> "<p>\n <italic>emphasized</italic>\n</p>"
|
|
|
|
|
]
|
|
|
|
|
, "bullet list" =: bulletList [ plain $ text "first"
|
|
|
|
|
, plain $ text "second"
|
|
|
|
|
, plain $ text "third"
|
|
|
|
|
]
|
|
|
|
|
=?> "<list list-type=\"bullet\">\n\
|
|
|
|
|
\ <list-item>\n\
|
|
|
|
|
\ <p>\n\
|
|
|
|
|
\ first\n\
|
|
|
|
|
\ </p>\n\
|
|
|
|
|
\ </list-item>\n\
|
|
|
|
|
\ <list-item>\n\
|
|
|
|
|
\ <p>\n\
|
|
|
|
|
\ second\n\
|
|
|
|
|
\ </p>\n\
|
|
|
|
|
\ </list-item>\n\
|
|
|
|
|
\ <list-item>\n\
|
|
|
|
|
\ <p>\n\
|
|
|
|
|
\ third\n\
|
|
|
|
|
\ </p>\n\
|
|
|
|
|
\ </list-item>\n\
|
|
|
|
|
\</list>"
|
|
|
|
|
, testGroup "definition lists"
|
|
|
|
|
[ "with internal link" =: definitionList [(link "#go" "" (str "testing"),
|
|
|
|
|
[plain (text "hi there")])] =?>
|
|
|
|
|
"<def-list>\n\
|
|
|
|
|
\ <def-item>\n\
|
|
|
|
|
\ <term>\n\
|
|
|
|
|
\ <xref alt=\"testing\" rid=\"go\">testing</xref>\n\
|
|
|
|
|
\ </term>\n\
|
|
|
|
|
\ <def>\n\
|
|
|
|
|
\ <p>\n\
|
|
|
|
|
\ hi there\n\
|
|
|
|
|
\ </p>\n\
|
|
|
|
|
\ </def>\n\
|
|
|
|
|
\ </def-item>\n\
|
|
|
|
|
\</def-list>"
|
|
|
|
|
]
|
|
|
|
|
, testGroup "math"
|
|
|
|
|
[ "escape |" =: para (math "\\sigma|_{\\{x\\}}") =?>
|
|
|
|
|
"<p>\n\
|
|
|
|
|
\ <inline-formula><alternatives>\n\
|
|
|
|
|
\ <tex-math><![CDATA[\\sigma|_{\\{x\\}}]]></tex-math>\n\
|
|
|
|
|
\ <mml:math display=\"inline\" xmlns:mml=\"http://www.w3.org/1998/Math/MathML\"><mml:mrow><mml:mi>σ</mml:mi><mml:msub><mml:mo stretchy=\"false\" form=\"prefix\">|</mml:mo><mml:mrow><mml:mo stretchy=\"false\" form=\"prefix\">{</mml:mo><mml:mi>x</mml:mi><mml:mo stretchy=\"false\" form=\"postfix\">}</mml:mo></mml:mrow></mml:msub></mml:mrow></mml:math></alternatives></inline-formula>\n\
|
|
|
|
|
\</p>"
|
|
|
|
|
]
|
|
|
|
|
, testGroup "headers"
|
|
|
|
|
[ "unnumbered header" =:
|
|
|
|
|
headerWith ("foo",["unnumbered"],[]) 1
|
|
|
|
|
(text "Header 1" <> note (plain $ text "note")) =?>
|
|
|
|
|
"<sec id=\"foo\">\n\
|
|
|
|
|
\ <title>Header 1<fn>\n\
|
|
|
|
|
\ <p>\n\
|
|
|
|
|
\ note\n\
|
|
|
|
|
\ </p>\n\
|
|
|
|
|
\ </fn></title>\n\
|
|
|
|
|
\</sec>"
|
|
|
|
|
, "unnumbered sub header" =:
|
|
|
|
|
headerWith ("foo",["unnumbered"],[]) 1
|
|
|
|
|
(text "Header")
|
|
|
|
|
<> headerWith ("foo",["unnumbered"],[]) 2
|
|
|
|
|
(text "Sub-Header") =?>
|
|
|
|
|
"<sec id=\"foo\">\n\
|
|
|
|
|
\ <title>Header</title>\n\
|
|
|
|
|
\ <sec id=\"foo\">\n\
|
|
|
|
|
\ <title>Sub-Header</title>\n\
|
|
|
|
|
\ </sec>\n\
|
|
|
|
|
\</sec>"
|
|
|
|
|
, "containing image" =:
|
|
|
|
|
header 1 (image "imgs/foo.jpg" "" (text "Alt text")) =?>
|
|
|
|
|
"<sec>\n\
|
|
|
|
|
\ <title><inline-graphic mimetype=\"image\" mime-subtype=\"jpeg\" xlink:href=\"imgs/foo.jpg\" /></title>\n\
|
|
|
|
|
\</sec>"
|
|
|
|
|
]
|
|
|
|
|
]
|