{-# LANGUAGE QuasiQuotes #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE ViewPatterns #-} -- This file is part of the Wire Server implementation. -- -- Copyright (C) 2020 Wire Swiss GmbH -- -- This program is free software: you can redistribute it and/or modify it under -- the terms of the GNU Affero General Public License as published by the Free -- Software Foundation, either version 3 of the License, or (at your option) any -- later version. -- -- This program is distributed in the hope that it will be useful, but WITHOUT -- ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -- FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more -- details. -- -- You should have received a copy of the GNU Affero General Public License along -- with this program. If not, see . module Test.Schema.MetaSchemaSpec ( spec, ) where import Data.Aeson import Data.Text (Text) import HaskellWorks.Hspec.Hedgehog (require) import Hedgehog import qualified Hedgehog.Gen as Gen import qualified Hedgehog.Range as Range import Network.URI.Static (uri) import Test.Hspec import Web.Scim.Capabilities.MetaSchema import Web.Scim.Schema.AuthenticationScheme import Web.Scim.Schema.Common (ScimBool (ScimBool), URI (..)) import Web.Scim.Schema.Schema (Schema (..)) import Prelude hiding (filter) prop_roundtrip :: (ToJSON a, FromJSON a, Show a, Eq a) => Gen a -> Property prop_roundtrip gen = property $ do config <- forAll gen tripping config toJSON fromJSON spec :: Spec spec = do describe "MetaSchema" $ do -- the extra 'decode' in the golden tests is to make attribute order not count for Eq. it "`Supported ()` golden test" $ do decode @Value (encode (Supported (ScimBool True) ())) `shouldBe` decode @Value ("{\"supported\":true}") it "`Supported a` golden test" $ do decode @Value (encode (Supported (ScimBool True) (FilterConfig 3))) `shouldBe` decode @Value "{\"supported\":true,\"maxResults\":3}" it "`Supported ()` roundtrips" $ do require (prop_roundtrip (genSupported (pure ()))) it "`BulkConfig` roundtrips" $ do require (prop_roundtrip genBulkConfig) it "`FilterConfig` roundtrips" $ do require (prop_roundtrip genFilterConfig) it "`AuthenticationSchemeEncoding` roundtrips" $ do require (prop_roundtrip genAuthenticationSchemeEncoding) it "`Configuration` roundtrips" $ do require (prop_roundtrip genConfiguration) genConfiguration :: Gen Configuration genConfiguration = do Configuration <$> Gen.maybe genUri <*> pure [User20] <*> genSupported (pure ()) <*> genSupported genBulkConfig <*> genSupported genFilterConfig <*> genSupported (pure ()) <*> genSupported (pure ()) <*> genSupported (pure ()) <*> Gen.list (Range.linear 0 100) genAuthenticationSchemeEncoding genBulkConfig :: Gen BulkConfig genBulkConfig = do BulkConfig <$> Gen.int (Range.linear 0 100) <*> Gen.int (Range.linear 0 100) genFilterConfig :: Gen FilterConfig genFilterConfig = do FilterConfig <$> Gen.int (Range.linear 0 100) genAuthenticationSchemeEncoding :: Gen AuthenticationSchemeEncoding genAuthenticationSchemeEncoding = do AuthenticationSchemeEncoding <$> genSimpleText <*> genSimpleText <*> genSimpleText <*> Gen.maybe genUri <*> Gen.maybe genUri genSupported :: forall a. Gen a -> Gen (Supported a) genSupported gen = do Supported <$> (ScimBool <$> Gen.bool) <*> gen genUri :: Gen URI genUri = Gen.element [URI [uri|https://example.com|], URI [uri|gopher://glab.io|], URI [uri|ssh://nothing/blorg|]] genSimpleText :: Gen Text genSimpleText = Gen.element ["one", "green", "sharp"]