2013-05-10 22:53:35 -07:00
{- # LANGUAGE OverloadedStrings, ScopedTypeVariables # -}
2011-01-26 09:10:39 -08:00
module Tests.Readers.RST ( tests ) where
import Text.Pandoc.Definition
import Test.Framework
import Tests.Helpers
import Tests.Arbitrary ()
import Text.Pandoc.Builder
import Text.Pandoc
2015-02-18 19:57:48 +00:00
import Text.Pandoc.Error
2011-01-26 09:10:39 -08:00
rst :: String -> Pandoc
2015-02-18 19:57:48 +00:00
rst = handleError . readRST def { readerStandalone = True }
2011-01-26 09:10:39 -08:00
2012-02-05 13:23:06 -08:00
infix 4 =:
2011-01-26 09:10:39 -08:00
( =: ) :: ToString c
=> String -> ( String , c ) -> Test
( =: ) = test rst
tests :: [ Test ]
2011-04-11 14:45:42 -07:00
tests = [ " line block with blank line " =:
2016-10-13 08:46:44 +02:00
" | a \ n | \ n | b " =?> lineBlock [ " a " , mempty , " \ 160 b " ]
2015-07-03 16:40:59 +02:00
, testGroup " field list "
[ " general " =: unlines
2013-05-10 22:53:35 -07:00
[ " para "
, " "
, " :Hostname: media08 "
2013-01-23 08:47:43 -08:00
, " :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 " ]
2015-07-03 16:40:59 +02:00
=?> ( doc
$ para " para " <>
definitionList [ ( str " Hostname " , [ para " media08 " ] )
, ( text " IP address " , [ para " 10.0.0.19 " ] )
, ( str " Size " , [ para " 3ru " ] )
, ( str " Version " , [ para " 1 " ] )
2015-12-12 12:21:36 -08:00
, ( str " Indentation " , [ para " Since the field marker may be quite long, the second \ n and subsequent lines of the field body do not have to line up \ n with the first line, but they must be indented relative to the \ n field name marker, and they must line up with each other. " ] )
2015-07-03 16:40:59 +02:00
, ( text " Parameter i " , [ para " integer " ] )
2015-12-12 12:21:36 -08:00
, ( str " Final " , [ para " item \ n on two lines " ] )
2015-07-03 16:40:59 +02:00
] )
, " metadata " =: unlines
2013-05-10 22:53:35 -07:00
[ " ===== "
, " Title "
, " ===== "
, " -------- "
, " Subtitle "
, " -------- "
, " "
, " :Version: 1 "
]
2015-07-03 16:40:59 +02:00
=?> ( setMeta " version " ( para " 1 " )
$ setMeta " title " ( " Title " :: Inlines )
$ setMeta " subtitle " ( " Subtitle " :: Inlines )
$ doc mempty )
, " with inline markup " =: unlines
2015-07-03 16:56:25 +02:00
[ " :*Date*: today "
, " "
, " .. "
2015-07-02 19:16:30 +02:00
, " "
, " :*one*: emphasis "
, " :two_: reference "
, " :`three`_: another one "
, " :``four``: literal "
, " "
, " .. _two: http://example.com "
, " .. _three: http://example.org "
]
2015-07-03 16:56:25 +02:00
=?> ( setMeta " date " ( str " today " )
$ doc
$ definitionList [ ( emph " one " , [ para " emphasis " ] )
2015-07-03 16:40:59 +02:00
, ( link " http://example.com " " " " two " , [ para " reference " ] )
, ( link " http://example.org " " " " three " , [ para " another one " ] )
, ( code " four " , [ para " literal " ] )
] )
]
2011-03-18 11:27:42 -07:00
, " URLs with following punctuation " =:
( " http://google.com, http://yahoo.com; http://foo.bar.baz. \ n " ++
" http://foo.bar/baz_(bam) (http://foo.bar) " ) =?>
2011-12-13 14:29:07 -08:00
para ( link " http://google.com " " " " http://google.com " <> " , " <>
link " http://yahoo.com " " " " http://yahoo.com " <> " ; " <>
link " http://foo.bar.baz " " " " http://foo.bar.baz " <> " . " <>
2015-12-12 12:21:36 -08:00
softbreak <>
2011-03-18 11:27:42 -07:00
link " http://foo.bar/baz_(bam) " " " " http://foo.bar/baz_(bam) "
2011-12-13 14:29:07 -08:00
<> " ( " <> link " http://foo.bar " " " " http://foo.bar " <> " ) " )
2015-06-29 18:32:46 +02:00
, " Reference names with special characters " =:
2015-07-10 10:35:58 -07:00
( " 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 " )
2016-05-01 22:23:33 -05:00
, " Code directive with class and number-lines " =: unlines
[ " .. code::python "
, " :number-lines: 34 "
, " :class: class1 class2 class3 "
, " "
, " def func(x): "
, " return y "
] =?>
2016-05-01 22:32:26 -05:00
( doc $ codeBlockWith
( " "
, [ " sourceCode " , " python " , " numberLines " , " class1 " , " class2 " , " class3 " ]
, [ ( " startFrom " , " 34 " ) ]
)
" def func(x): \ n return y "
2016-05-01 22:23:33 -05:00
)
2016-05-01 22:36:19 -05:00
, " Code directive with number-lines, no line specified " =: unlines
[ " .. code::python "
, " :number-lines: "
, " "
, " def func(x): "
, " return y "
] =?>
( doc $ codeBlockWith
( " "
, [ " sourceCode " , " python " , " numberLines " ]
, [ ( " startFrom " , " " ) ]
)
" def func(x): \ n return y "
)
2014-12-11 17:14:03 +00:00
, testGroup " literal / line / code blocks "
[ " indented literal block " =: unlines
[ " :: "
, " "
, " block quotes "
, " "
, " can go on for many lines "
, " but must stop here " ]
=?> ( doc $
codeBlock " block quotes \ n \ n can go on for many lines " <>
para " but must stop here " )
, " line block with 3 lines " =: " | a \ n | b \ n | c "
2016-10-13 08:46:44 +02:00
=?> lineBlock [ " a " , " b " , " c " ]
2014-12-01 16:27:51 +00:00
, " quoted literal block using > " =: " :: \ n \ n > quoted \ n > block \ n \ n Ordinary paragraph "
=?> codeBlock " > quoted \ n > block " <> para " Ordinary paragraph "
, " quoted literal block using | (not a line block) " =: " :: \ n \ n | quoted \ n | block \ n \ n Ordinary paragraph "
=?> codeBlock " | quoted \ n | block " <> para " Ordinary paragraph "
2014-12-11 17:14:03 +00:00
, " class directive with single paragraph " =: " .. class:: special \ n \ n This 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 \ n b " ) ]
, 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` "
2014-12-11 18:50:24 +00:00
=?> para ( codeWith ( " " , [ " lhs " , " haskell " , " sourceCode " ] , [] ) " a " )
2014-12-11 17:14:03 +00:00
, " 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 ( str " text " )
]
2011-01-26 09:10:39 -08:00
]