{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes        #-}

module Headline where

import           Data.OrgMode.Parse
import           Test.Tasty
import           Test.Tasty.HUnit

import           Util

parserHeadlineTests :: TestTree
parserHeadlineTests = testGroup "Attoparsec Headline"
    [ testCase "Parse Headline Bare"                $ testHeadline "* This is a title\n"
    , testCase "Parse Headline Bare with end colon" $ testHeadline "* This heading ends in a colon:"
    , testCase "Parse Headline Bare w/ Depths"      $ testHeadline "*** This is a title\n"
    , testCase "Parse Headline w/ Priority"         $ testHeadline "* [#A] An important heading\n"
    , testCase "Parse Headline w/ Priority & State" $ testHeadline "* TODO [#A] An important heading with a state indicator\n"
    , testCase "Parse Headline w/ State"            $ testHeadline "* CANCELED An important heading with just state\n"
    , testCase "Parse Headline w/ Keywords"         $ testHeadline "* An important heading :WITH:KEYWORDS:\n"
    , testCase "Parse Headline Full"                $ testHeadline "* DONE [#B] A heading : with [[http://somelink.com][a link]] :WITH:KEYWORDS:\n"
    , testCase "Parse Headline All But Title"       $ testHeadline "* DONE [#A] :WITH:KEYWORDS:\n"
    , testCase "Parse Headline w/ Timestamp"        $ testHeadline "* TODO [#A] <2017-08-24 22:00> Pickup groceris on\n"
    ]
  where
    testHeadline = testParser (headlineBelowDepth ["TODO","CANCELED","DONE"] 0)