summaryrefslogtreecommitdiff
path: root/tests/Test/StarWars/Schema.hs
diff options
context:
space:
mode:
authorDanny Navarro <j@dannynavarro.net>2016-02-12 13:27:46 +0100
committerDanny Navarro <j@dannynavarro.net>2016-02-12 13:27:46 +0100
commit04d8d40b3ad2dac0040a3fae63f48d8269adf81e (patch)
treeef5eea61a141baaf94ec63eb37156776c80b542d /tests/Test/StarWars/Schema.hs
parenta088c819442800cf9cf4a2e95d5cb4bc16584029 (diff)
downloadgraphql-04d8d40b3ad2dac0040a3fae63f48d8269adf81e.tar.gz
Split StarWars tests in different modules
Diffstat (limited to 'tests/Test/StarWars/Schema.hs')
-rw-r--r--tests/Test/StarWars/Schema.hs69
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/Test/StarWars/Schema.hs b/tests/Test/StarWars/Schema.hs
new file mode 100644
index 0000000..57c1b24
--- /dev/null
+++ b/tests/Test/StarWars/Schema.hs
@@ -0,0 +1,69 @@
+{-# LANGUAGE CPP #-}
+{-# LANGUAGE OverloadedStrings #-}
+module Test.StarWars.Schema where
+
+#if !MIN_VERSION_base(4,8,0)
+import Control.Applicative (pure)
+import Data.Traversable (traverse)
+#endif
+import Control.Applicative (Alternative, empty)
+import Data.Foldable (fold)
+
+import Data.HashMap.Strict (HashMap)
+import qualified Data.HashMap.Strict as HashMap
+import Data.Text (Text)
+
+import Data.GraphQL.Schema
+
+import Test.StarWars.Data
+
+-- * Schema
+-- See https://github.com/graphql/graphql-js/blob/master/src/__tests__/starWarsSchema.js
+
+schema :: (Alternative m, Monad m) => Schema m
+schema = Schema query
+
+query :: (Alternative m, Monad m) => QueryRoot m
+query (InputField "hero" args ins) = hero args ins
+query (InputField "human" args ins) = human args ins
+query (InputField "droid" args ins) = droid args ins
+query _ = empty
+
+hero :: Alternative f => [Argument] -> [Input] -> f Output
+hero [] = characterFields artoo
+hero [("episode", ScalarInt n)] = characterFields $ getHero n
+hero _ = const empty
+
+human :: (Alternative m, Monad m) => [Argument] -> [Input] -> m Output
+human [("id", ScalarString i)] ins = flip characterFields ins =<< getHuman i
+human _ _ = empty
+
+droid :: (Alternative m, Monad m) => [Argument] -> [Input] -> m Output
+droid [("id", ScalarString i)] ins = flip characterFields ins =<< getDroid i
+droid _ _ = empty
+
+episode :: Alternative f => Int -> f Output
+episode 4 = pure $ OutputEnum "NEWHOPE"
+episode 5 = pure $ OutputEnum "EMPIRE"
+episode 6 = pure $ OutputEnum "JEDI"
+episode _ = empty
+
+characterField :: Alternative f => Character -> Input -> f (HashMap Text Output)
+characterField char (InputField "id" [] []) =
+ pure . HashMap.singleton "id" . OutputScalar . ScalarString . id_ $ char
+characterField char (InputField "name" [] []) =
+ pure . HashMap.singleton "name" . OutputScalar . ScalarString . name $ char
+characterField char (InputField "friends" [] ins) =
+ fmap (HashMap.singleton "friends" . OutputList)
+ . traverse (`characterFields` ins)
+ . getFriends
+ $ char
+characterField char (InputField "appearsIn" [] []) =
+ fmap (HashMap.singleton "appearsIn" . OutputList)
+ . traverse episode
+ . appearsIn
+ $ char
+characterField _ _ = empty
+
+characterFields :: Alternative f => Character -> [Input] -> f Output
+characterFields char = fmap (OutputObject . fold) . traverse (characterField char)