graphql-engine/server/src-test/Hasura/RQL/MetadataSpec.hs

22 lines
830 B
Haskell
Raw Normal View History

module Hasura.RQL.MetadataSpec (spec) where
import Hasura.Prelude
import Data.Aeson (eitherDecodeStrict)
import Test.Hspec
import Test.QuickCheck
import Hasura.EncJSON
import Hasura.RQL.DDL.Metadata.Generator (genMetadata)
import Hasura.RQL.Types.Metadata (Metadata, metadataToOrdJSON)
spec :: Spec
spec = describe "metadataToOrdJSON" $ do
it "produces JSON that can be parsed by the FromJSON instance for Metadata" $
withMaxSuccess 20 $
forAll (resize 3 genMetadata) $ \metadata ->
let encodedString = encJToBS $ encJFromOrderedValue $ metadataToOrdJSON metadata
in case eitherDecodeStrict @Metadata encodedString of
Left err -> counterexample err False
Right _ -> property True