2015-09-22 14:02:12 +02:00
|
|
|
{-# LANGUAGE CPP #-}
|
2015-09-22 13:53:37 +02:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
|
|
module Main where
|
|
|
|
|
2015-09-22 14:02:12 +02:00
|
|
|
#if !MIN_VERSION_base(4,8,0)
|
|
|
|
import Control.Applicative ((<$>), (<*>))
|
|
|
|
#endif
|
|
|
|
|
2015-09-22 13:53:37 +02:00
|
|
|
import Data.Attoparsec.Text (parseOnly)
|
|
|
|
import qualified Data.Text.IO as Text
|
|
|
|
import Test.Tasty (defaultMain)
|
|
|
|
import Test.Tasty.HUnit
|
|
|
|
|
|
|
|
import qualified Data.GraphQL.Parser as Parser
|
|
|
|
import qualified Data.GraphQL.Printer as Printer
|
|
|
|
|
|
|
|
import Paths_graphql (getDataFileName)
|
|
|
|
|
|
|
|
main :: IO ()
|
|
|
|
main = defaultMain =<< testCase "Kitchen Sink"
|
|
|
|
<$> (assertEqual "Encode" <$> expected <*> actual)
|
|
|
|
where
|
|
|
|
expected = Text.readFile
|
|
|
|
=<< getDataFileName "tests/data/kitchen-sink.min.graphql"
|
|
|
|
|
|
|
|
actual = either (error "Parsing error!") Printer.document
|
|
|
|
<$> parseOnly Parser.document
|
|
|
|
<$> expected
|