pandoc/test/Tests/Writers/Org.hs
Albert Krewinkel a31cf9a005
Org writer: keep code block attributes as header args.
This allows to keep more information in the resulting `src` blocks,
making it easier to roundtrip from or through Org. Org babel ignores
unknown header arguments.
2022-08-22 12:53:57 +02:00

89 lines
2.2 KiB
Haskell

{-# LANGUAGE OverloadedStrings #-}
module Tests.Writers.Org (tests) where
import Data.Text as T
import Test.Tasty
import Test.Tasty.HUnit (HasCallStack)
import Tests.Helpers
import Text.Pandoc
import Text.Pandoc.Arbitrary ()
import Text.Pandoc.Builder
infix 4 =:
(=:) :: (ToString a, ToPandoc a, HasCallStack)
=> String -> (a, Text) -> TestTree
(=:) = test org
defopts :: WriterOptions
defopts = def
{ writerExtensions = getDefaultExtensions "org"
}
org :: (ToPandoc a) => a -> Text
org = orgWithOpts defopts
orgWithOpts :: (ToPandoc a) => WriterOptions -> a -> Text
orgWithOpts opts x = purely (writeOrg opts) $ toPandoc x
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]]"
]
, testGroup "lists"
[ "bullet task list"
=: bulletList [plain "☐ a", plain "☒ b"]
=?> T.unlines
[ "- [ ] a"
, "- [X] b"
]
, "ordered task list"
=: orderedList [plain ("" <> space <> "a"), plain "☒ b"]
=?> T.unlines
[ "1. [ ] a"
, "2. [X] b"
]
, "ordered task list with starting number"
=: orderedListWith
(9, DefaultStyle, DefaultDelim)
[plain ("" <> space <> "a"), plain "☒ b"]
=?> T.unlines
[ "9. [@9] [ ] a"
, "10. [X] b"
]
, test (orgWithOpts def) "bullet without task_lists" $
bulletList [plain "☐ a", plain "☒ b"]
=?> T.unlines
[ "- ☐ a"
, "- ☒ b"
]
]
, testGroup "code blocks"
[ "identifier"
=: codeBlockWith ("abc", ["python"], []) "return True"
=?> T.unlines
[ "#+name: abc"
, "#+begin_src python"
, "return True"
, "#+end_src"
]
, "attributes"
=: codeBlockWith ("", ["python"], [("cache", "yes"), ("noweb", "yes")])
"'Hello'"
=?> T.unlines
[ "#+begin_src python :cache yes :noweb yes"
, "'Hello'"
, "#+end_src"
]
]
]