Skip to content

Commit

Permalink
Add round trip property tests for FlatTerms
Browse files Browse the repository at this point in the history
  • Loading branch information
DeepakKapiswe committed Mar 27, 2019
1 parent d02a9d3 commit 30eff8a
Showing 1 changed file with 55 additions and 0 deletions.
55 changes: 55 additions & 0 deletions cborg/tests/Tests/Properties.hs
Original file line number Diff line number Diff line change
Expand Up @@ -45,12 +45,14 @@ import Data.Bits (complement)
import qualified Numeric.Half as Half
import Data.Function (on)
import Data.Proxy
import Control.Applicative (liftA2)

import Codec.CBOR.Term
import Codec.CBOR.Read
import Codec.CBOR.Write
import Codec.CBOR.Decoding
import Codec.CBOR.Encoding
import Codec.CBOR.FlatTerm (toFlatTerm, fromFlatTerm)

import Test.Tasty (TestTree, testGroup, localOption)
import Test.Tasty.QuickCheck (testProperty, QuickCheckMaxSize(..))
Expand Down Expand Up @@ -380,6 +382,38 @@ prop_decodeRefdecodeImp _ x =
t = Proxy :: Proxy t


-- | The property corresponding to the following part of the commuting diagram.
--
-- This is a round trip property, with the production implementation of the
-- encoder and decoder, involving toFlatTerm and fromFlatTerm.
--
-- > canon
-- > Ref -------▷Ref ▶ FlatTerm ▶
-- > | ╱ │
-- > | ╱toFlatTerm │
-- > | ╱ │dec
-- > fromRef| ▶Enc▶ │fromFlatTerm
-- > | / │
-- > | /enc │
-- > ▽ / ▼
-- > Imp ─────────────────────▶Imp
-- > id
--
-- > (fromFlatTerm dec_imp . toFlatTerm . enc_imp) imp = Right imp
--
prop_toFromFlatTerm :: forall t. Token t => Proxy t -> t -> Bool
prop_toFromFlatTerm _ x =

liftA2 eq (fn enc) (Right imp) == Right True

where
imp = fromRef . canonicaliseRef $ x
eq = eqImp t
enc = encodeImp t imp
fn e = fromFlatTerm (decodeImp (Proxy :: Proxy t)) $ toFlatTerm e
t = Proxy :: Proxy t


--------------------------------------------------------------------------------
-- Token class instances for unsigned types
--
Expand Down Expand Up @@ -1189,4 +1223,25 @@ testTree =
, testProperty "Simple" (prop_decodeRefdecodeImp (Proxy :: Proxy Ref.Simple))
, testProperty "Term" (prop_decodeRefdecodeImp (Proxy :: Proxy Ref.Term))
]
, testGroup "(fromFlatTerm dec_imp . toFlatTerm . enc_imp) imp = Right imp"
[ testProperty "Word8" (prop_toFromFlatTerm (Proxy :: Proxy TokWord8))
, testProperty "Word16" (prop_toFromFlatTerm (Proxy :: Proxy TokWord16))
, testProperty "Word32" (prop_toFromFlatTerm (Proxy :: Proxy TokWord32))
, testProperty "Word64" (prop_toFromFlatTerm (Proxy :: Proxy TokWord64))
, testProperty "Word" (prop_toFromFlatTerm (Proxy :: Proxy TokWord))
-- , testProperty "NegWord" (prop_toFromFlatTerm (Proxy :: Proxy TokNegWord))
, testProperty "Int8" (prop_toFromFlatTerm (Proxy :: Proxy TokInt8))
, testProperty "Int16" (prop_toFromFlatTerm (Proxy :: Proxy TokInt16))
, testProperty "Int32" (prop_toFromFlatTerm (Proxy :: Proxy TokInt32))
, testProperty "Int64" (prop_toFromFlatTerm (Proxy :: Proxy TokInt64))
, testProperty "Int" (prop_toFromFlatTerm (Proxy :: Proxy TokInt))
, testProperty "Integer" (prop_toFromFlatTerm (Proxy :: Proxy TokInteger))
, testProperty "Half" (prop_toFromFlatTerm (Proxy :: Proxy TokHalf))
, testProperty "Float" (prop_toFromFlatTerm (Proxy :: Proxy TokFloat))
, testProperty "Double" (prop_toFromFlatTerm (Proxy :: Proxy TokDouble))
, testProperty "Tag" (prop_toFromFlatTerm (Proxy :: Proxy TokTag))
, testProperty "Tag64" (prop_toFromFlatTerm (Proxy :: Proxy TokTag64))
, testProperty "Simple" (prop_toFromFlatTerm (Proxy :: Proxy Ref.Simple))
, testProperty "Term" (prop_toFromFlatTerm (Proxy :: Proxy Ref.Term))
]
]

0 comments on commit 30eff8a

Please sign in to comment.