2d443ecb07
The org reader test file had grown large, to the point that editor performance was negatively affected in some cases. The tests are spread over multiple submodules, and re-combined into a tasty TestTree in the main org reader test file.
182 lines
6.5 KiB
Haskell
182 lines
6.5 KiB
Haskell
{-# 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"
|
|
]
|