2022-06-25 22:05:58 +03:00
|
|
|
{-# LANGUAGE QuasiQuotes #-}
|
|
|
|
|
|
|
|
-- | Query Tests for Data Connector Backend using a Mock Agent
|
2022-06-29 04:07:12 +03:00
|
|
|
module Test.DataConnector.MockAgent.BasicQuerySpec
|
2022-06-25 22:05:58 +03:00
|
|
|
( spec,
|
|
|
|
)
|
|
|
|
where
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
import Data.Aeson qualified as Aeson
|
|
|
|
import Data.Aeson.KeyMap qualified as KM
|
|
|
|
import Data.List.NonEmpty qualified as NE
|
2022-07-19 04:51:42 +03:00
|
|
|
import Harness.Backend.DataConnector (TestCase (..))
|
2022-06-25 22:05:58 +03:00
|
|
|
import Harness.Backend.DataConnector qualified as DataConnector
|
|
|
|
import Harness.Quoter.Graphql (graphql)
|
2022-07-20 08:20:49 +03:00
|
|
|
import Harness.Quoter.Yaml (yaml)
|
2022-06-25 22:05:58 +03:00
|
|
|
import Harness.Test.BackendType (BackendType (..), defaultBackendTypeString, defaultSource)
|
|
|
|
import Harness.Test.Context qualified as Context
|
|
|
|
import Harness.TestEnvironment (TestEnvironment)
|
|
|
|
import Hasura.Backends.DataConnector.API qualified as API
|
|
|
|
import Test.Hspec (SpecWith, describe, it)
|
|
|
|
import Prelude
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
spec :: SpecWith TestEnvironment
|
|
|
|
spec =
|
|
|
|
Context.runWithLocalTestEnvironment
|
|
|
|
[ Context.Context
|
|
|
|
{ name = Context.Backend Context.DataConnector,
|
|
|
|
mkLocalTestEnvironment = DataConnector.mkLocalTestEnvironmentMock,
|
|
|
|
setup = DataConnector.setupMock sourceMetadata DataConnector.mockBackendConfig,
|
|
|
|
teardown = DataConnector.teardownMock,
|
|
|
|
customOptions = Nothing
|
|
|
|
}
|
|
|
|
]
|
|
|
|
tests
|
|
|
|
|
|
|
|
sourceMetadata :: Aeson.Value
|
|
|
|
sourceMetadata =
|
|
|
|
let source = defaultSource DataConnector
|
|
|
|
backendType = defaultBackendTypeString DataConnector
|
|
|
|
in [yaml|
|
2022-07-20 08:20:49 +03:00
|
|
|
name : *source
|
|
|
|
kind: *backendType
|
|
|
|
tables:
|
|
|
|
- table: Album
|
|
|
|
configuration:
|
|
|
|
custom_root_fields:
|
|
|
|
select: albums
|
|
|
|
select_by_pk: albums_by_pk
|
|
|
|
column_config:
|
|
|
|
AlbumId:
|
|
|
|
custom_name: id
|
|
|
|
Title:
|
|
|
|
custom_name: title
|
|
|
|
ArtistId:
|
|
|
|
custom_name: artist_id
|
|
|
|
object_relationships:
|
|
|
|
- name: artist
|
|
|
|
using:
|
|
|
|
manual_configuration:
|
|
|
|
remote_table: Artist
|
|
|
|
column_mapping:
|
|
|
|
ArtistId: ArtistId
|
|
|
|
- table: Artist
|
|
|
|
configuration:
|
|
|
|
custom_root_fields:
|
|
|
|
select: artists
|
|
|
|
select_by_pk: artists_by_pk
|
|
|
|
column_config:
|
|
|
|
ArtistId:
|
|
|
|
custom_name: id
|
|
|
|
Name:
|
|
|
|
custom_name: name
|
|
|
|
array_relationships:
|
|
|
|
- name: albums
|
|
|
|
using:
|
|
|
|
manual_configuration:
|
|
|
|
remote_table: Album
|
|
|
|
column_mapping:
|
|
|
|
ArtistId: ArtistId
|
|
|
|
configuration: {}
|
|
|
|
|]
|
2022-06-25 22:05:58 +03:00
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
tests :: Context.Options -> SpecWith (TestEnvironment, DataConnector.MockAgentEnvironment)
|
2022-06-29 04:07:12 +03:00
|
|
|
tests opts = do
|
2022-06-25 22:05:58 +03:00
|
|
|
describe "Basic Tests" $ do
|
|
|
|
it "works with simple object query" $
|
|
|
|
DataConnector.runMockedTest opts $
|
2022-07-19 04:51:42 +03:00
|
|
|
let required =
|
|
|
|
DataConnector.TestCaseRequired
|
|
|
|
{ _givenRequired =
|
|
|
|
let albums =
|
2022-07-26 05:28:57 +03:00
|
|
|
[ [ ("id", API.mkColumnFieldValue $ Aeson.Number 1),
|
|
|
|
("title", API.mkColumnFieldValue $ Aeson.String "For Those About To Rock We Salute You")
|
2022-07-20 08:20:49 +03:00
|
|
|
]
|
|
|
|
]
|
|
|
|
in DataConnector.chinookMock {DataConnector._queryResponse = \_ -> rowsResponse albums},
|
2022-07-19 04:51:42 +03:00
|
|
|
_whenRequestRequired =
|
|
|
|
[graphql|
|
|
|
|
query getAlbum {
|
|
|
|
albums(limit: 1) {
|
|
|
|
id
|
|
|
|
title
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|],
|
|
|
|
_thenRequired =
|
|
|
|
[yaml|
|
|
|
|
data:
|
|
|
|
albums:
|
|
|
|
- id: 1
|
|
|
|
title: For Those About To Rock We Salute You
|
|
|
|
|]
|
|
|
|
}
|
|
|
|
in (DataConnector.defaultTestCase required)
|
|
|
|
{ _whenQuery =
|
|
|
|
Just
|
|
|
|
( API.QueryRequest
|
2022-07-20 08:20:49 +03:00
|
|
|
{ _qrTable = API.TableName "Album",
|
2022-07-19 04:51:42 +03:00
|
|
|
_qrTableRelationships = [],
|
|
|
|
_qrQuery =
|
|
|
|
API.Query
|
|
|
|
{ _qFields =
|
2022-07-20 08:20:49 +03:00
|
|
|
Just $
|
|
|
|
KM.fromList
|
2022-07-27 08:27:34 +03:00
|
|
|
[ ("id", API.ColumnField (API.ColumnName "AlbumId")),
|
|
|
|
("title", API.ColumnField (API.ColumnName "Title"))
|
2022-07-20 08:20:49 +03:00
|
|
|
],
|
|
|
|
_qAggregates = Nothing,
|
2022-07-19 04:51:42 +03:00
|
|
|
_qLimit = Just 1,
|
|
|
|
_qOffset = Nothing,
|
2022-07-27 08:27:34 +03:00
|
|
|
_qWhere = Just (API.And []),
|
2022-07-19 04:51:42 +03:00
|
|
|
_qOrderBy = Nothing
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
2022-06-25 22:05:58 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
it "works with order_by id" $
|
|
|
|
DataConnector.runMockedTest opts $
|
2022-07-19 04:51:42 +03:00
|
|
|
let required =
|
|
|
|
DataConnector.TestCaseRequired
|
|
|
|
{ _givenRequired =
|
|
|
|
let albums =
|
2022-07-26 05:28:57 +03:00
|
|
|
[ [ ("id", API.mkColumnFieldValue $ Aeson.Number 1),
|
|
|
|
("title", API.mkColumnFieldValue $ Aeson.String "For Those About To Rock We Salute You")
|
2022-07-20 08:20:49 +03:00
|
|
|
],
|
2022-07-26 05:28:57 +03:00
|
|
|
[ ("id", API.mkColumnFieldValue $ Aeson.Number 2),
|
|
|
|
("title", API.mkColumnFieldValue $ Aeson.String "Balls to the Wall")
|
2022-07-20 08:20:49 +03:00
|
|
|
],
|
2022-07-26 05:28:57 +03:00
|
|
|
[ ("id", API.mkColumnFieldValue $ Aeson.Number 3),
|
|
|
|
("title", API.mkColumnFieldValue $ Aeson.String "Restless and Wild")
|
2022-07-20 08:20:49 +03:00
|
|
|
]
|
|
|
|
]
|
|
|
|
in DataConnector.chinookMock {DataConnector._queryResponse = \_ -> rowsResponse albums},
|
2022-07-19 04:51:42 +03:00
|
|
|
_whenRequestRequired =
|
|
|
|
[graphql|
|
2022-07-20 08:20:49 +03:00
|
|
|
query getAlbum {
|
|
|
|
albums(limit: 3, order_by: {id: asc}) {
|
|
|
|
id
|
|
|
|
title
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|],
|
2022-07-19 04:51:42 +03:00
|
|
|
_thenRequired =
|
|
|
|
[yaml|
|
2022-07-20 08:20:49 +03:00
|
|
|
data:
|
|
|
|
albums:
|
|
|
|
- id: 1
|
|
|
|
title: For Those About To Rock We Salute You
|
|
|
|
- id: 2
|
|
|
|
title: Balls to the Wall
|
|
|
|
- id: 3
|
|
|
|
title: Restless and Wild
|
|
|
|
|]
|
2022-07-19 04:51:42 +03:00
|
|
|
}
|
|
|
|
in (DataConnector.defaultTestCase required)
|
|
|
|
{ _whenQuery =
|
|
|
|
Just
|
|
|
|
( API.QueryRequest
|
2022-07-20 08:20:49 +03:00
|
|
|
{ _qrTable = API.TableName "Album",
|
2022-07-19 04:51:42 +03:00
|
|
|
_qrTableRelationships = [],
|
|
|
|
_qrQuery =
|
|
|
|
API.Query
|
|
|
|
{ _qFields =
|
2022-07-20 08:20:49 +03:00
|
|
|
Just $
|
|
|
|
KM.fromList
|
2022-07-27 08:27:34 +03:00
|
|
|
[ ("id", API.ColumnField (API.ColumnName "AlbumId")),
|
|
|
|
("title", API.ColumnField (API.ColumnName "Title"))
|
2022-07-20 08:20:49 +03:00
|
|
|
],
|
|
|
|
_qAggregates = Nothing,
|
2022-07-19 04:51:42 +03:00
|
|
|
_qLimit = Just 3,
|
|
|
|
_qOffset = Nothing,
|
2022-07-27 08:27:34 +03:00
|
|
|
_qWhere = Just (API.And []),
|
2022-07-20 08:20:49 +03:00
|
|
|
_qOrderBy = Just (API.OrderBy (API.ColumnName "AlbumId") API.Ascending NE.:| [])
|
2022-07-19 04:51:42 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
2022-07-20 08:20:49 +03:00
|
|
|
|
|
|
|
rowsResponse :: [[(Aeson.Key, API.FieldValue)]] -> API.QueryResponse
|
|
|
|
rowsResponse rows = API.QueryResponse (Just $ KM.fromList <$> rows) Nothing
|