gdritter repos telml / master telml-markup / test / Telml / MarkupSpec.hs
master

Tree @master (Download .tar.gz)

MarkupSpec.hs @masterraw · history · blame

{-# LANGUAGE OverloadedStrings #-}

module Telml.MarkupSpec (main, spec) where

import Control.Monad ((>=>))
import Data.TeLML
import Data.TeLML.Markup
import Test.Hspec
import Text.Blaze.Renderer.String (renderMarkup)

main :: IO ()
main = hspec spec

doRender :: String -> Either String String
doRender = parse >=> render >=> return . renderMarkup

spec :: Spec
spec = do
  describe "render" $ do
    it "should emphasize" $ do
      doRender "\\em{foo}" `shouldBe` Right "<p><em>foo</em></p>"
    it "should embolden" $ do
      doRender "\\strong{foo}" `shouldBe` Right "<p><strong>foo</strong></p>"
    it "should list" $ do
      doRender "\\ul{\\li{one}\\li{two}}"
        `shouldBe` Right "<p><ul><li>one</li><li>two</li></ul></p>"