{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE UndecidableInstances #-} module Main ( main ) where import Dahdit (Binary, StaticByteSized (..), ViaGeneric (..), ViaStaticGeneric (..), Word16LE) import Data.Proxy (Proxy (..)) import Data.Word (Word8) import GHC.Generics (Generic) import Test.Dahdit.Daytripper (expectBytes, expectCodecOk, expectText) import Test.Dahdit.GenDefault (DahditTag) import Test.Daytripper (daytripperMain, mkFileRT, mkPropRT, mkUnitRT, testRT) import Test.Falsify.GenDefault qualified as FD import Test.Falsify.Generator (Gen) import Test.Tasty (testGroup) data P type I = DahditTag P genDefaultI :: (FD.GenDefault I a) => Gen a genDefaultI = FD.genDefault (Proxy @I) data DynFoo = DynFoo !Word8 !Word16LE deriving stock (Eq, Show, Generic) deriving (Binary) via (ViaGeneric DynFoo) deriving (FD.GenDefault I) via (FD.ViaGeneric I DynFoo) data StaFoo = StaFoo !Word8 !Word16LE deriving stock (Eq, Show, Generic) deriving (StaticByteSized, Binary) via (ViaStaticGeneric StaFoo) deriving (FD.GenDefault I) via (FD.ViaGeneric I StaFoo) main :: IO () main = daytripperMain $ testGroup "DahditTest" $ fmap testRT [ mkPropRT "DynFoo prop" expectCodecOk (genDefaultI @DynFoo) , mkUnitRT "DynFoo unit" (expectBytes [1, 2, 0] expectCodecOk) (DynFoo 1 2) , mkFileRT "DynFoo file" expectCodecOk "testdata/dynfoo.bin" (Just (DynFoo 1 2)) , mkPropRT "StaFoo prop" expectCodecOk (genDefaultI @StaFoo) , mkUnitRT "StaFoo unit" (expectText "\ETX\EOT\NUL" expectCodecOk) (StaFoo 3 4) , mkFileRT "DynFoo file" expectCodecOk "testdata/stafoo.bin" (Just (StaFoo 1 2)) ]