mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 04:24:35 +03:00
e953efeb40
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/7758 Co-authored-by: Tom Harding <6302310+i-am-tom@users.noreply.github.com> GitOrigin-RevId: 311f6c4a5c629c18a55d75a5d5a74f826078e86d
100 lines
2.8 KiB
Haskell
100 lines
2.8 KiB
Haskell
{-# LANGUAGE DeriveGeneric #-}
|
|
{-# LANGUAGE DerivingStrategies #-}
|
|
{-# LANGUAGE FlexibleInstances #-}
|
|
{-# LANGUAGE LambdaCase #-}
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
{-# LANGUAGE ScopedTypeVariables #-}
|
|
{-# OPTIONS_GHC -Wno-unused-imports -Wno-orphans -Wno-name-shadowing #-}
|
|
|
|
module Jsonb (specJsonb) where
|
|
|
|
import Control.Monad.Except
|
|
import Control.Monad.Identity
|
|
import Control.Monad.Reader
|
|
import Data.Aeson qualified as J
|
|
import Data.ByteString qualified as BS
|
|
import Data.String
|
|
import Database.PG.Query
|
|
import Database.PG.Query.Connection
|
|
import Database.PostgreSQL.LibPQ.Internal
|
|
import GHC.Generics
|
|
import System.Environment qualified as Env
|
|
import Test.Hspec
|
|
import Prelude
|
|
|
|
newtype TestValue = TestValue {hey :: Int}
|
|
deriving stock (Show, Generic)
|
|
|
|
instance J.FromJSON TestValue
|
|
|
|
instance Show (ViaJSON TestValue) where
|
|
show (ViaJSON tv) = show tv
|
|
|
|
getPgUri :: (MonadIO m) => m BS.ByteString
|
|
getPgUri = liftIO $ fromString <$> Env.getEnv "DATABASE_URL"
|
|
|
|
getPostgresConnect :: (MonadIO m) => m ConnInfo
|
|
getPostgresConnect = do
|
|
dbUri <- getPgUri
|
|
pure $
|
|
defaultConnInfo
|
|
{ ciDetails = CDDatabaseURI dbUri
|
|
}
|
|
|
|
specJsonb :: Spec
|
|
specJsonb = do
|
|
describe "Decoding JSON and JSONB" $ do
|
|
it "Querying 'json' from PostgreSQL succeeds" $ do
|
|
pg <- getPostgresConnect
|
|
result <-
|
|
runTxT
|
|
pg
|
|
(rawQE show "select '{\"hey\":42}'::json" [] False)
|
|
|
|
result `shouldSatisfy` \case
|
|
(Right (SingleRow (Identity (_ :: BS.ByteString)))) -> True
|
|
Left e -> error e
|
|
|
|
it "Querying 'jsonb' from PostgreSQL succeeds" $ do
|
|
pg <- getPostgresConnect
|
|
result <-
|
|
runTxT
|
|
pg
|
|
(rawQE show "select '{\"hey\":42}'::jsonb" [] False)
|
|
|
|
result `shouldSatisfy` \case
|
|
Right (SingleRow (Identity (_ :: BS.ByteString))) -> True
|
|
Left e -> error e
|
|
|
|
it "Querying 'json' from PostgreSQL into ViaJSON type succeeds" $ do
|
|
pg <- getPostgresConnect
|
|
result <-
|
|
runTxT
|
|
pg
|
|
(rawQE show "select '{\"hey\":42}'::json" [] False)
|
|
|
|
result `shouldSatisfy` \case
|
|
Right (SingleRow (Identity (ViaJSON (_ :: TestValue)))) -> True
|
|
Left e -> error e
|
|
|
|
it "Querying 'jsonb' from PostgreSQL into ViaJSON type succeeds" $ do
|
|
pg <- getPostgresConnect
|
|
result <-
|
|
runTxT
|
|
pg
|
|
(rawQE show "select '{\"hey\":42}'::jsonb" [] False)
|
|
|
|
result `shouldSatisfy` \case
|
|
Right (SingleRow (Identity (ViaJSON (_ :: TestValue)))) -> True
|
|
Left e -> error e
|
|
|
|
instance FromPGConnErr String where
|
|
fromPGConnErr = show
|
|
|
|
runTxT :: forall a. ConnInfo -> TxET String IO a -> IO (Either String a)
|
|
runTxT conn q = do
|
|
pool <- initPGPool conn defaultConnParams (const (return ()))
|
|
x <- runExceptT $ runTx' pool q
|
|
destroyPGPool pool
|
|
pure x
|