{-# LANGUAGE QuasiQuotes #-} {-# LANGUAGE RecordWildCards #-} -- | Test ordering by fields. module OrderingSpec (spec) where import Harness.Constants import Harness.Feature qualified as Feature import Harness.Graphql import Harness.GraphqlEngine qualified as GraphqlEngine import Harness.Mysql as Mysql import Harness.Sql import Harness.Yaml import Test.Hspec import Prelude -------------------------------------------------------------------------------- -- Preamble spec :: Spec spec = Feature.feature Feature.Feature { Feature.backends = [ Feature.Backend { name = "MySQL", setup = mysqlSetup, teardown = mysqlTeardown } ], Feature.tests = tests } -------------------------------------------------------------------------------- -- MySQL backend mysqlSetup :: IO () mysqlSetup = do -- Clear and reconfigure the metadata GraphqlEngine.post_ "/v1/metadata" [yaml| type: replace_metadata args: version: 3 sources: - name: mysql kind: mysql tables: [] configuration: database: *mysqlDatabase user: *mysqlUser password: *mysqlPassword host: *mysqlHost port: *mysqlPort pool_settings: {} |] -- Setup tables Mysql.run_ [sql| CREATE TABLE author ( id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(45) UNIQUE KEY ); |] Mysql.run_ [sql| INSERT INTO author (name) VALUES ( 'Author 1'), ( 'Author 2'); |] -- Track the tables GraphqlEngine.post_ "/v1/metadata" [yaml| type: mysql_track_table args: source: mysql table: schema: hasura name: author |] mysqlTeardown :: IO () mysqlTeardown = do Mysql.run_ [sql| DROP TABLE author; |] -------------------------------------------------------------------------------- -- Tests tests :: Spec tests = do it "Order by id ascending" $ shouldReturnYaml ( GraphqlEngine.postGraphql [graphql| query { hasura_author (order_by: {id: asc}) { name id } } |] ) [yaml| data: hasura_author: - name: Author 1 id: 1 - name: Author 2 id: 2 |] it "Order by id descending" $ shouldReturnYaml ( GraphqlEngine.postGraphql [graphql| query { hasura_author (order_by: {id: desc}) { name id } } |] ) [yaml| data: hasura_author: - name: Author 2 id: 2 - name: Author 1 id: 1 |]