2019-12-14 09:47:38 +03:00
|
|
|
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
|
|
|
module Hasura.RQL.DDL.Metadata.Generator
|
|
|
|
(genReplaceMetadata)
|
|
|
|
where
|
|
|
|
|
2020-05-13 15:33:16 +03:00
|
|
|
import Hasura.GraphQL.Utils (simpleGraphQLQuery)
|
2019-12-14 09:47:38 +03:00
|
|
|
import Hasura.Prelude
|
|
|
|
import Hasura.RQL.DDL.Headers
|
|
|
|
import Hasura.RQL.DDL.Metadata.Types
|
|
|
|
import Hasura.RQL.Types
|
|
|
|
import Hasura.Server.Utils
|
|
|
|
import Hasura.SQL.Types
|
2020-05-13 15:33:16 +03:00
|
|
|
|
|
|
|
import qualified Hasura.RQL.DDL.ComputedField as ComputedField
|
|
|
|
import qualified Hasura.RQL.DDL.Permission as Permission
|
|
|
|
import qualified Hasura.RQL.DDL.Permission.Internal as Permission
|
|
|
|
import qualified Hasura.RQL.DDL.QueryCollection as Collection
|
|
|
|
import qualified Hasura.RQL.DDL.Relationship as Relationship
|
|
|
|
import qualified Hasura.RQL.DDL.Schema as Schema
|
|
|
|
|
|
|
|
import System.Cron.Types
|
|
|
|
|
|
|
|
import qualified Data.Aeson as J
|
|
|
|
import qualified Data.Text as T
|
|
|
|
import qualified Data.Vector as V
|
|
|
|
import qualified Language.GraphQL.Draft.Parser as G
|
|
|
|
import qualified Language.GraphQL.Draft.Syntax as G
|
|
|
|
import qualified Language.Haskell.TH.Syntax as TH
|
|
|
|
import qualified Network.URI as N
|
|
|
|
import qualified System.Cron.Parser as Cr
|
2019-12-14 09:47:38 +03:00
|
|
|
|
|
|
|
import Test.QuickCheck
|
2020-05-13 15:33:16 +03:00
|
|
|
import Test.QuickCheck.Instances.Semigroup ()
|
|
|
|
import Test.QuickCheck.Instances.Time ()
|
|
|
|
import Test.QuickCheck.Instances.UnorderedContainers ()
|
2019-12-14 09:47:38 +03:00
|
|
|
|
|
|
|
genReplaceMetadata :: Gen ReplaceMetadata
|
|
|
|
genReplaceMetadata = do
|
|
|
|
version <- arbitrary
|
|
|
|
ReplaceMetadata version
|
|
|
|
<$> arbitrary
|
|
|
|
<*> genFunctionsMetadata version
|
|
|
|
<*> arbitrary
|
|
|
|
<*> arbitrary
|
|
|
|
<*> arbitrary
|
2020-02-13 20:38:23 +03:00
|
|
|
<*> arbitrary
|
|
|
|
<*> arbitrary
|
2020-05-13 15:33:16 +03:00
|
|
|
<*> arbitrary
|
2019-12-14 09:47:38 +03:00
|
|
|
where
|
|
|
|
genFunctionsMetadata :: MetadataVersion -> Gen FunctionsMetadata
|
|
|
|
genFunctionsMetadata = \case
|
|
|
|
MVVersion1 -> FMVersion1 <$> arbitrary
|
|
|
|
MVVersion2 -> FMVersion2 <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.Name where
|
|
|
|
arbitrary = G.Name . T.pack <$> listOf1 (elements ['a'..'z'])
|
|
|
|
|
|
|
|
instance Arbitrary MetadataVersion where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
2020-02-13 20:38:23 +03:00
|
|
|
instance Arbitrary TableCustomRootFields where
|
2019-12-14 09:47:38 +03:00
|
|
|
arbitrary = uniqueRootFields
|
|
|
|
where
|
|
|
|
uniqueRootFields = do
|
2020-02-13 20:38:23 +03:00
|
|
|
(a, b, c, d, e, f, g, h, i) <- arbitrary
|
|
|
|
if null $ duplicates [a, b, c, d, e, f, g, h, i] then
|
|
|
|
pure $ TableCustomRootFields a b c d e f g h i
|
2019-12-14 09:47:38 +03:00
|
|
|
else uniqueRootFields
|
|
|
|
|
|
|
|
instance Arbitrary TableConfig where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
2020-01-14 10:09:10 +03:00
|
|
|
instance (Arbitrary a) => Arbitrary (Relationship.RelUsing a) where
|
2019-12-14 09:47:38 +03:00
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance (Arbitrary a) => Arbitrary (Relationship.RelDef a) where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Relationship.RelManualConfig where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Relationship.ArrRelUsingFKeyOn where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance (Arbitrary a) => Arbitrary (Permission.PermDef a) where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ComputedField.ComputedFieldDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ComputedFieldMeta where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary J.Value where
|
|
|
|
arbitrary = sized sizedArbitraryValue
|
|
|
|
where
|
|
|
|
sizedArbitraryValue n
|
|
|
|
| n <= 0 = oneof [pure J.Null, boolean, number, string]
|
|
|
|
| otherwise = resize n' $ oneof [pure J.Null, boolean, number, string, array, object']
|
|
|
|
where
|
|
|
|
n' = n `div` 2
|
|
|
|
boolean = J.Bool <$> arbitrary
|
|
|
|
number = (J.Number . fromRational . toRational :: Int -> J.Value) <$> arbitrary
|
|
|
|
string = J.String <$> arbitrary
|
|
|
|
array = J.Array . V.fromList <$> arbitrary
|
|
|
|
object' = J.Object <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ColExp where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary (GExists ColExp) where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary (GBoolExp ColExp) where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary BoolExp where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Permission.PermColSpec where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Permission.InsPerm where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Permission.SelPerm where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Permission.UpdPerm where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Permission.DelPerm where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary SubscribeColumns where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary SubscribeOpSpec where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary TriggerOpsDef where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary RetryConf where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary HeaderValue where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary HeaderConf where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary EventTriggerConf where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary TableMeta where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Schema.FunctionConfig where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Schema.TrackFunctionV2 where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary QualifiedTable where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary QualifiedFunction where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
-- FIXME:- URI type do not have Arbitrary class implemented.
|
|
|
|
-- For time being a singe URI value is generated every time
|
|
|
|
instance Arbitrary N.URI where
|
|
|
|
arbitrary = pure $ N.URI "http:" (Just $ N.URIAuth "" "localhost" ":8080" ) "/path" "" ""
|
|
|
|
|
|
|
|
instance Arbitrary RemoteSchemaDef where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary AddRemoteSchemaQuery where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
-- FIXME:- The GraphQL AST has 'Gen' by Hedgehog testing package which lacks the
|
|
|
|
-- 'Arbitrary' class implementation. For time being, a single query is generated every time.
|
|
|
|
instance Arbitrary Collection.GQLQueryWithText where
|
|
|
|
arbitrary = pure $ Collection.GQLQueryWithText ( simpleGraphQLQuery
|
|
|
|
, Collection.GQLQuery simpleQuery
|
|
|
|
)
|
|
|
|
where
|
|
|
|
simpleQuery = $(either (fail . T.unpack) TH.lift $ G.parseExecutableDoc simpleGraphQLQuery)
|
|
|
|
|
|
|
|
instance Arbitrary Collection.ListedQuery where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Collection.CollectionDef where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Collection.CreateCollection where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary Collection.CollectionReq where
|
|
|
|
arbitrary = genericArbitrary
|
2020-02-13 20:38:23 +03:00
|
|
|
|
|
|
|
instance Arbitrary G.NamedType where
|
|
|
|
arbitrary = G.NamedType <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.Description where
|
|
|
|
arbitrary = G.Description <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.Nullability where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.ListType where
|
|
|
|
arbitrary = G.ListType <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.GType where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary G.EnumValue where
|
|
|
|
arbitrary = G.EnumValue <$> arbitrary
|
|
|
|
|
|
|
|
instance Arbitrary InputObjectTypeName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary InputObjectFieldName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary GraphQLType where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary InputObjectFieldDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary InputObjectTypeDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary RelType where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary RelationshipName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ObjectFieldName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary TypeRelationshipDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ObjectTypeName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ObjectFieldDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ObjectTypeDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ScalarTypeDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary EnumTypeName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary EnumValueDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary EnumTypeDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary CustomTypes where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ArgumentName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ArgumentDefinition where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
2020-04-16 10:25:19 +03:00
|
|
|
instance Arbitrary ActionMutationKind where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ActionType where
|
2020-02-13 20:38:23 +03:00
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance (Arbitrary a) => Arbitrary (ActionDefinition a) where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ActionName where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary InputWebhook where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ActionPermissionMetadata where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary ActionMetadata where
|
|
|
|
arbitrary = genericArbitrary
|
2020-05-13 15:33:16 +03:00
|
|
|
|
|
|
|
instance Arbitrary CronTriggerMetadata where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary WebhookConf where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary STRetryConf where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary NonNegativeDiffTime where
|
|
|
|
arbitrary = genericArbitrary
|
|
|
|
|
|
|
|
instance Arbitrary CronSchedule where
|
|
|
|
arbitrary = elements sampleCronSchedules
|
|
|
|
|
|
|
|
sampleCronSchedules :: [CronSchedule]
|
|
|
|
sampleCronSchedules = rights $ map Cr.parseCronSchedule $
|
|
|
|
[ "* * * * *"
|
|
|
|
-- every minute
|
|
|
|
, "5 * * * *"
|
|
|
|
-- every hour at the 5th minute
|
|
|
|
, "\5 * * * *"
|
|
|
|
-- every 5 minutes
|
|
|
|
, "* 5 * * *"
|
|
|
|
-- every minute of the 5th hour of the day
|
|
|
|
, "5 5 * * *"
|
|
|
|
-- fifth minute of the fifth hour every day
|
|
|
|
, "0 0 5 * *"
|
|
|
|
-- 00:00 of the 5th day of every month
|
|
|
|
, "0 0 1 1 *"
|
|
|
|
-- 00:00 of 1st of January
|
|
|
|
, "0 0 * * 0"
|
|
|
|
-- Every sunday at 00:00
|
|
|
|
]
|