mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-16 18:42:30 +03:00
b84db36ebb
* basic doc for actions * custom_types, sync and async actions * switch to graphql-parser-hs on github * update docs * metadata import/export * webhook calls are now supported * relationships in sync actions * initialise.sql is now in sync with the migration file * fix metadata tests * allow specifying arguments of actions * fix blacklist check on check_build_worthiness job * track custom_types and actions related tables * handlers are now triggered on async actions * default to pgjson unless a field is involved in relationships, for generating definition list * use 'true' for action filter for non admin role * fix create_action_permission sql query * drop permissions when dropping an action * add a hdb_role view (and relationships) to fetch all roles in the system * rename 'webhook' key in action definition to 'handler' * allow templating actions wehook URLs with env vars * add 'update_action' /v1/query type * allow forwarding client headers by setting `forward_client_headers` in action definition * add 'headers' configuration in action definition * handle webhook error response based on status codes * support array relationships for custom types * implement single row mutation, see https://github.com/hasura/graphql-engine/issues/3731 * single row mutation: rename 'pk_columns' -> 'columns' and no-op refactor * use top level primary key inputs for delete_by_pk & account select permissions for single row mutations * use only REST semantics to resolve the webhook response * use 'pk_columns' instead of 'columns' for update_by_pk input * add python basic tests for single row mutations * add action context (name) in webhook payload * Async action response is accessible for non admin roles only if the request session vars equals to action's * clean nulls, empty arrays for actions, custom types in export metadata * async action mutation returns only the UUID of the action * unit tests for URL template parser * Basic sync actions python tests * fix output in async query & add async tests * add admin secret header in async actions python test * document async action architecture in Resolve/Action.hs file * support actions returning array of objects * tests for list type response actions * update docs with actions and custom types metadata API reference * update actions python tests as per #f8e1330 Co-authored-by: Tirumarai Selvan <tirumarai.selvan@gmail.com> Co-authored-by: Aravind Shankar <face11301@gmail.com> Co-authored-by: Rakesh Emmadi <12475069+rakeshkky@users.noreply.github.com>
126 lines
5.1 KiB
Haskell
126 lines
5.1 KiB
Haskell
module Main (main) where
|
|
|
|
import Hasura.Prelude
|
|
|
|
import Control.Concurrent.MVar
|
|
import Control.Natural ((:~>) (..))
|
|
import Data.Time.Clock (getCurrentTime)
|
|
import Options.Applicative
|
|
import System.Environment (getEnvironment)
|
|
import System.Exit (exitFailure)
|
|
import Test.Hspec
|
|
|
|
import qualified Data.Aeson as A
|
|
import qualified Data.ByteString.Lazy.Char8 as BL
|
|
import qualified Database.PG.Query as Q
|
|
import qualified Network.HTTP.Client as HTTP
|
|
import qualified Network.HTTP.Client.TLS as HTTP
|
|
import qualified Test.Hspec.Runner as Hspec
|
|
|
|
import Hasura.Db (PGExecCtx (..))
|
|
import Hasura.RQL.Types (SQLGenCtx (..), adminUserInfo)
|
|
import Hasura.RQL.Types.Run
|
|
import Hasura.Server.Init (RawConnInfo, mkConnInfo, mkRawConnInfo,
|
|
parseRawConnInfo, runWithEnv)
|
|
import Hasura.Server.Migrate
|
|
import Hasura.Server.Version
|
|
|
|
import qualified Data.Parser.CacheControlSpec as CacheControlParser
|
|
import qualified Data.Parser.URLTemplate as URLTemplate
|
|
import qualified Data.TimeSpec as TimeSpec
|
|
import qualified Hasura.IncrementalSpec as IncrementalSpec
|
|
import qualified Hasura.RQL.MetadataSpec as MetadataSpec
|
|
import qualified Hasura.Server.MigrateSpec as MigrateSpec
|
|
import qualified Hasura.Server.TelemetrySpec as TelemetrySpec
|
|
|
|
data TestSuites
|
|
= AllSuites !RawConnInfo
|
|
-- ^ Run all test suites. It probably doesn't make sense to be able to specify additional
|
|
-- hspec args here.
|
|
| SingleSuite ![String] !TestSuite
|
|
-- ^ Args to pass through to hspec (as if from 'getArgs'), and the specific suite to run.
|
|
|
|
data TestSuite
|
|
= UnitSuite
|
|
| PostgresSuite !RawConnInfo
|
|
|
|
main :: IO ()
|
|
main = withVersion $$(getVersionFromEnvironment) $ parseArgs >>= \case
|
|
AllSuites pgConnOptions -> do
|
|
postgresSpecs <- buildPostgresSpecs pgConnOptions
|
|
runHspec [] (unitSpecs *> postgresSpecs)
|
|
SingleSuite hspecArgs suite -> runHspec hspecArgs =<< case suite of
|
|
UnitSuite -> pure unitSpecs
|
|
PostgresSuite pgConnOptions -> buildPostgresSpecs pgConnOptions
|
|
|
|
unitSpecs :: Spec
|
|
unitSpecs = do
|
|
describe "Data.Parser.CacheControl" CacheControlParser.spec
|
|
describe "Data.Parser.URLTemplate" URLTemplate.spec
|
|
describe "Hasura.Incremental" IncrementalSpec.spec
|
|
describe "Hasura.RQL.Metadata" MetadataSpec.spec
|
|
describe "Data.Time" TimeSpec.spec
|
|
describe "Hasura.Server.Telemetry" TelemetrySpec.spec
|
|
|
|
buildPostgresSpecs :: (HasVersion) => RawConnInfo -> IO Spec
|
|
buildPostgresSpecs pgConnOptions = do
|
|
env <- getEnvironment
|
|
|
|
rawPGConnInfo <- flip onLeft printErrExit $ runWithEnv env (mkRawConnInfo pgConnOptions)
|
|
pgConnInfo <- flip onLeft printErrExit $ mkConnInfo rawPGConnInfo
|
|
|
|
let setupCacheRef = do
|
|
pgPool <- Q.initPGPool pgConnInfo Q.defaultConnParams { Q.cpConns = 1 } print
|
|
|
|
httpManager <- HTTP.newManager HTTP.tlsManagerSettings
|
|
let runContext = RunCtx adminUserInfo httpManager (SQLGenCtx False)
|
|
pgContext = PGExecCtx pgPool Q.Serializable
|
|
|
|
runAsAdmin :: Run a -> IO a
|
|
runAsAdmin =
|
|
peelRun runContext pgContext Q.ReadWrite
|
|
>>> runExceptT
|
|
>=> flip onLeft printErrJExit
|
|
|
|
schemaCache <- snd <$> runAsAdmin (migrateCatalog =<< liftIO getCurrentTime)
|
|
cacheRef <- newMVar schemaCache
|
|
pure $ NT (runAsAdmin . flip MigrateSpec.runCacheRefT cacheRef)
|
|
|
|
pure $ beforeAll setupCacheRef $
|
|
describe "Hasura.Server.Migrate" $ MigrateSpec.spec pgConnInfo
|
|
|
|
parseArgs :: IO TestSuites
|
|
parseArgs = execParser $ info (helper <*> (parseNoCommand <|> parseSubCommand)) $
|
|
fullDesc <> header "Hasura GraphQL Engine test suite"
|
|
where
|
|
parseNoCommand = AllSuites <$> parseRawConnInfo
|
|
parseSubCommand = SingleSuite <$> parseHspecPassThroughArgs <*> subCmd
|
|
where
|
|
subCmd = subparser $ mconcat
|
|
[ command "unit" $ info (pure UnitSuite) $
|
|
progDesc "Only run unit tests"
|
|
, command "postgres" $ info (helper <*> (PostgresSuite <$> parseRawConnInfo)) $
|
|
progDesc "Only run Postgres integration tests"
|
|
]
|
|
-- Add additional arguments and tweak as needed:
|
|
hspecArgs = ["match", "skip"]
|
|
-- parse to a list of arguments as they'd appear from 'getArgs':
|
|
parseHspecPassThroughArgs :: Parser [String]
|
|
parseHspecPassThroughArgs = fmap concat $ for hspecArgs $ \nm->
|
|
fmap (maybe [] (\a -> ["--"<>nm , a])) $ optional $
|
|
strOption ( long nm <>
|
|
metavar "<PATTERN>" <>
|
|
help "Flag passed through to hspec (see hspec docs)." )
|
|
|
|
|
|
runHspec :: [String] -> Spec -> IO ()
|
|
runHspec hspecArgs m = do
|
|
config <- Hspec.readConfig Hspec.defaultConfig hspecArgs
|
|
Hspec.evaluateSummary =<< Hspec.runSpec m config
|
|
|
|
printErrExit :: String -> IO a
|
|
printErrExit = (*> exitFailure) . putStrLn
|
|
|
|
printErrJExit :: (A.ToJSON a) => a -> IO b
|
|
printErrJExit = (*> exitFailure) . BL.putStrLn . A.encode
|