From 4923d982e64de624e5cd1b972d06c9800627ea31 Mon Sep 17 00:00:00 2001 From: Mateusz Galazyn Date: Tue, 10 Sep 2024 14:54:29 +0200 Subject: [PATCH] Refactor: Remove Test.Cardano.Api.Typed and Test.Golden.Cardano.Api.Typed modules --- cardano-api/cardano-api.cabal | 22 ++-- .../Golden/Cardano/Api/{Typed => }/Script.hs | 2 +- .../Test/Cardano/Api/{Typed => }/Address.hs | 4 +- .../Test/Cardano/Api/{Typed => }/Bech32.hs | 2 +- .../Test/Cardano/Api/{Typed => }/CBOR.hs | 4 +- .../Test/Cardano/Api/{Typed => }/Envelope.hs | 4 +- .../cardano-api-test/Test/Cardano/Api/Json.hs | 17 +++ .../Test/Cardano/Api/KeysByron.hs | 2 +- .../Test/Cardano/Api/{Typed => }/Ord.hs | 2 +- .../Test/Cardano/Api/{Typed => }/Orphans.hs | 2 +- .../Test/Cardano/Api/{Typed => }/RawBytes.hs | 4 +- .../TxBody.hs => Transaction/Autobalance.hs} | 99 +------------- .../Test/Cardano/Api/TxBody.hs | 122 ++++++++++++++++++ .../Test/Cardano/Api/Typed/JSON.hs | 46 ------- .../Test/Cardano/Api/{Typed => }/Value.hs | 2 +- .../test/cardano-api-test/cardano-api-test.hs | 36 +++--- 16 files changed, 186 insertions(+), 184 deletions(-) rename cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/{Typed => }/Script.hs (99%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Address.hs (95%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Bech32.hs (95%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/CBOR.hs (99%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Envelope.hs (98%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Ord.hs (98%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Orphans.hs (95%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/RawBytes.hs (98%) rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed/TxBody.hs => Transaction/Autobalance.hs} (62%) create mode 100644 cardano-api/test/cardano-api-test/Test/Cardano/Api/TxBody.hs delete mode 100644 cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/JSON.hs rename cardano-api/test/cardano-api-test/Test/Cardano/Api/{Typed => }/Value.hs (98%) diff --git a/cardano-api/cardano-api.cabal b/cardano-api/cardano-api.cabal index 010bb3da82..4a7751e640 100644 --- a/cardano-api/cardano-api.cabal +++ b/cardano-api/cardano-api.cabal @@ -340,7 +340,11 @@ test-suite cardano-api-test time, other-modules: + Test.Cardano.Api.Address + Test.Cardano.Api.Bech32 + Test.Cardano.Api.CBOR Test.Cardano.Api.Crypto + Test.Cardano.Api.Envelope Test.Cardano.Api.EpochLeadership Test.Cardano.Api.Eras Test.Cardano.Api.Genesis @@ -349,17 +353,13 @@ test-suite cardano-api-test Test.Cardano.Api.KeysByron Test.Cardano.Api.Ledger Test.Cardano.Api.Metadata + Test.Cardano.Api.Ord + Test.Cardano.Api.Orphans Test.Cardano.Api.ProtocolParameters - Test.Cardano.Api.Typed.Address - Test.Cardano.Api.Typed.Bech32 - Test.Cardano.Api.Typed.CBOR - Test.Cardano.Api.Typed.Envelope - Test.Cardano.Api.Typed.JSON - Test.Cardano.Api.Typed.Ord - Test.Cardano.Api.Typed.Orphans - Test.Cardano.Api.Typed.RawBytes - Test.Cardano.Api.Typed.TxBody - Test.Cardano.Api.Typed.Value + Test.Cardano.Api.RawBytes + Test.Cardano.Api.Transaction.Autobalance + Test.Cardano.Api.TxBody + Test.Cardano.Api.Value ghc-options: -threaded @@ -412,6 +412,6 @@ test-suite cardano-api-golden Test.Golden.Cardano.Api.Genesis Test.Golden.Cardano.Api.Ledger Test.Golden.Cardano.Api.ProtocolParameters - Test.Golden.Cardano.Api.Typed.Script + Test.Golden.Cardano.Api.Script Test.Golden.Cardano.Api.Value Test.Golden.ErrorsSpec diff --git a/cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Typed/Script.hs b/cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Script.hs similarity index 99% rename from cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Typed/Script.hs rename to cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Script.hs index ff433ac31c..f4eceeb706 100644 --- a/cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Typed/Script.hs +++ b/cardano-api/test/cardano-api-golden/Test/Golden/Cardano/Api/Script.hs @@ -1,6 +1,6 @@ {-# LANGUAGE TypeApplications #-} -module Test.Golden.Cardano.Api.Typed.Script +module Test.Golden.Cardano.Api.Script ( test_golden_SimpleScriptV1_All , test_golden_SimpleScriptV1_Any , test_golden_SimpleScriptV1_MofN diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Address.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Address.hs similarity index 95% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Address.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Address.hs index 0f2ebe33aa..87a53f13b2 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Address.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Address.hs @@ -1,6 +1,6 @@ {-# LANGUAGE FlexibleContexts #-} -module Test.Cardano.Api.Typed.Address +module Test.Cardano.Api.Address ( tests ) where @@ -11,7 +11,7 @@ import qualified Data.Aeson as Aeson import Test.Gen.Cardano.Api.Typed (genAddressByron, genAddressShelley) -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import Hedgehog (Property) import qualified Hedgehog as H diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Bech32.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Bech32.hs similarity index 95% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Bech32.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Bech32.hs index 5a3179fd69..0627c9dccd 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Bech32.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Bech32.hs @@ -1,4 +1,4 @@ -module Test.Cardano.Api.Typed.Bech32 +module Test.Cardano.Api.Bech32 ( tests ) where diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/CBOR.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/CBOR.hs similarity index 99% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/CBOR.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/CBOR.hs index 217caa9e73..3bf25a923e 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/CBOR.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/CBOR.hs @@ -4,7 +4,7 @@ -- TODO remove when serialiseTxLedgerCddl is removed {-# OPTIONS_GHC -Wno-deprecations #-} -module Test.Cardano.Api.Typed.CBOR +module Test.Cardano.Api.CBOR ( tests ) where @@ -16,7 +16,7 @@ import Data.Proxy (Proxy (..)) import Test.Gen.Cardano.Api.Typed -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import Hedgehog (Property, forAll, property, tripping) import qualified Hedgehog as H diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Envelope.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Envelope.hs similarity index 98% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Envelope.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Envelope.hs index d006e51700..af7b0c19a3 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Envelope.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Envelope.hs @@ -1,7 +1,7 @@ {-# LANGUAGE CPP #-} {-# LANGUAGE FlexibleContexts #-} -module Test.Cardano.Api.Typed.Envelope +module Test.Cardano.Api.Envelope ( tests ) where @@ -10,7 +10,7 @@ import Cardano.Api import Test.Gen.Cardano.Api.Typed -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import Hedgehog (Property) import qualified Hedgehog as H diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Json.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Json.hs index 50175923b8..e8122a77de 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Json.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Json.hs @@ -6,6 +6,7 @@ module Test.Cardano.Api.Json ) where +import Cardano.Api import Cardano.Api.Orphans () import Cardano.Api.Shelley @@ -14,8 +15,11 @@ import Data.Aeson (eitherDecode, encode) import Test.Gen.Cardano.Api (genAlonzoGenesis) import Test.Gen.Cardano.Api.Typed +import Test.Cardano.Api.Orphans () + import Hedgehog (Property, forAll, tripping) import qualified Hedgehog as H +import qualified Hedgehog.Gen as Gen import Test.Tasty (TestTree, testGroup) import Test.Tasty.Hedgehog (testProperty) @@ -56,6 +60,17 @@ prop_json_roundtrip_scriptdata_detailed_json = H.property $ do sData <- forAll genHashableScriptData tripping sData scriptDataToJsonDetailedSchema scriptDataFromJsonDetailedSchema +prop_roundtrip_praos_nonce_JSON :: Property +prop_roundtrip_praos_nonce_JSON = H.property $ do + pNonce <- forAll $ Gen.just genMaybePraosNonce + tripping pNonce encode eitherDecode + +prop_roundtrip_protocol_parameters_JSON :: Property +prop_roundtrip_protocol_parameters_JSON = H.property $ do + AnyCardanoEra era <- forAll $ Gen.element [minBound .. maxBound] + pp <- forAll (genProtocolParameters era) + tripping pp encode eitherDecode + tests :: TestTree tests = testGroup @@ -67,4 +82,6 @@ tests = , testProperty "json roundtrip txout tx context" prop_json_roundtrip_txout_tx_context , testProperty "json roundtrip txout utxo context" prop_json_roundtrip_txout_utxo_context , testProperty "json roundtrip scriptdata detailed json" prop_json_roundtrip_scriptdata_detailed_json + , testProperty "json roundtrip praos nonce" prop_roundtrip_praos_nonce_JSON + , testProperty "json roundtrip protocol parameters" prop_roundtrip_protocol_parameters_JSON ] diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/KeysByron.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/KeysByron.hs index 28b0fc4571..670bcc8644 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/KeysByron.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/KeysByron.hs @@ -7,7 +7,7 @@ where import Cardano.Api (AsType (AsByronKey, AsSigningKey), Key (deterministicSigningKey)) -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import qualified Test.Gen.Cardano.Crypto.Seed as Gen import Hedgehog (Property) diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Ord.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Ord.hs similarity index 98% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Ord.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Ord.hs index a5c65ff096..7544bd891d 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Ord.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Ord.hs @@ -1,4 +1,4 @@ -module Test.Cardano.Api.Typed.Ord +module Test.Cardano.Api.Ord ( tests ) where diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Orphans.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Orphans.hs similarity index 95% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Orphans.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Orphans.hs index f5b2cdf7d4..3d26964d4a 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Orphans.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Orphans.hs @@ -5,7 +5,7 @@ {-# LANGUAGE TypeOperators #-} {-# OPTIONS_GHC -Wno-orphans #-} -module Test.Cardano.Api.Typed.Orphans () where +module Test.Cardano.Api.Orphans () where import Cardano.Api.Shelley diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/RawBytes.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/RawBytes.hs similarity index 98% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/RawBytes.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/RawBytes.hs index b90f1c410d..3ca4b8f10b 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/RawBytes.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/RawBytes.hs @@ -1,7 +1,7 @@ {-# LANGUAGE CPP #-} {-# LANGUAGE FlexibleContexts #-} -module Test.Cardano.Api.Typed.RawBytes +module Test.Cardano.Api.RawBytes ( tests ) where @@ -10,7 +10,7 @@ import Cardano.Api import Test.Gen.Cardano.Api.Typed -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import Hedgehog (Property) import qualified Hedgehog as H diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/TxBody.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Transaction/Autobalance.hs similarity index 62% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/TxBody.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Transaction/Autobalance.hs index 58e91572b9..4051453a30 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/TxBody.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Transaction/Autobalance.hs @@ -1,5 +1,4 @@ {-# LANGUAGE GADTs #-} -{-# LANGUAGE LambdaCase #-} {-# LANGUAGE NumericUnderscores #-} {-# LANGUAGE OverloadedLists #-} {-# LANGUAGE RankNTypes #-} @@ -10,7 +9,7 @@ {- HLINT ignore "Use list comprehension" -} {- HLINT ignore "Use camelCase" -} -module Test.Cardano.Api.Typed.TxBody +module Test.Cardano.Api.Transaction.Autobalance ( tests ) where @@ -18,7 +17,7 @@ where import Cardano.Api import qualified Cardano.Api.Ledger as L import Cardano.Api.Script -import Cardano.Api.Shelley (Address (..), LedgerProtocolParameters (..), ShelleyLedgerEra) +import Cardano.Api.Shelley (Address (..), LedgerProtocolParameters (..)) import qualified Cardano.Ledger.Mary.Value as L import qualified Cardano.Ledger.Shelley.Scripts as L @@ -29,15 +28,11 @@ import qualified Cardano.Slotting.Time as CS import qualified Data.ByteString as B import Data.Function import qualified Data.Map.Strict as M -import Data.Maybe (isJust) import qualified Data.Time.Format as DT -import Data.Type.Equality (TestEquality (testEquality)) import GHC.Exts (IsList (..), IsString (..)) import GHC.Stack -import Test.Gen.Cardano.Api.Typed - -import Test.Cardano.Api.Typed.Orphans () +import Test.Cardano.Api.Orphans () import Hedgehog (MonadTest, Property, (===)) import qualified Hedgehog as H @@ -45,85 +40,6 @@ import qualified Hedgehog.Extras as H import Test.Tasty (TestTree, testGroup) import Test.Tasty.Hedgehog (testProperty) --- | Check the txOuts in a TxBodyContent after a ledger roundtrip. -prop_roundtrip_txbodycontent_txouts :: forall era. ShelleyBasedEra era -> Property -prop_roundtrip_txbodycontent_txouts era = H.property $ do - (body, content :: TxBodyContent BuildTx era) <- - shelleyBasedEraConstraints era $ H.forAll $ genValidTxBody era - -- Convert ledger body back via 'getTxBodyContent' and 'fromLedgerTxBody' - let (TxBody content') = body - matchTxOuts (txOuts content) (txOuts content') - where - matchTxOuts :: MonadTest m => [TxOut CtxTx era] -> [TxOut CtxTx era] -> m () - matchTxOuts as bs = - mapM_ matchTxOut $ zip as bs - - matchTxOut :: MonadTest m => (TxOut CtxTx era, TxOut CtxTx era) -> m () - matchTxOut (a, b) = do - let TxOut aAddress aValue aDatum aRefScript = a - let TxOut bAddress bValue bDatum bRefScript = b - aAddress === bAddress - aValue === bValue - matchDatum (aDatum, bDatum) - matchRefScript (aRefScript, bRefScript) - - -- NOTE: We accept TxOutDatumInTx instead of TxOutDatumHash as it may be - -- correctly resolved given a datum matching the hash was generated. - matchDatum :: MonadTest m => (TxOutDatum CtxTx era, TxOutDatum CtxTx era) -> m () - matchDatum = \case - (TxOutDatumHash _ dh, TxOutDatumInTx _ d) -> - dh === hashScriptDataBytes d - (a, b) -> - a === b - - -- NOTE: After Allegra, all eras interpret SimpleScriptV1 as SimpleScriptV2 - -- because V2 is a superset of V1. So we accept that as a valid conversion. - matchRefScript :: MonadTest m => (ReferenceScript era, ReferenceScript era) -> m () - matchRefScript (a, b) - | isSimpleScriptV2 a && isSimpleScriptV2 b = - shelleyBasedEraConstraints era $ - refScriptToShelleyScript era a - === refScriptToShelleyScript era b - | otherwise = - a === b - - isSimpleScriptV2 :: ReferenceScript era -> Bool - isSimpleScriptV2 = isLang SimpleScriptLanguage - - isLang :: ScriptLanguage a -> ReferenceScript era -> Bool - isLang expected = \case - (ReferenceScript _ (ScriptInAnyLang actual _)) -> isJust $ testEquality expected actual - _ -> False - -prop_roundtrip_txbodycontent_conway_fields :: Property -prop_roundtrip_txbodycontent_conway_fields = H.property $ do - let sbe = ShelleyBasedEraConway - (body, content) <- H.forAll $ genValidTxBody sbe - -- Convert ledger body back via 'getTxBodyContent' and 'fromLedgerTxBody' - let (TxBody content') = body - - let proposals = getProposalProcedures . unFeatured <$> txProposalProcedures content - proposals' = getProposalProcedures . unFeatured <$> txProposalProcedures content' - votes = getVotingProcedures . unFeatured <$> txVotingProcedures content - votes' = getVotingProcedures . unFeatured <$> txVotingProcedures content' - currTreasury = unFeatured <$> txCurrentTreasuryValue content - currTreasury' = unFeatured <$> txCurrentTreasuryValue content' - treasuryDonation = unFeatured <$> txTreasuryDonation content - treasuryDonation' = unFeatured <$> txTreasuryDonation content' - - proposals === proposals' - votes === votes' - currTreasury === currTreasury' - treasuryDonation === treasuryDonation' - where - getVotingProcedures TxVotingProceduresNone = Nothing - getVotingProcedures (TxVotingProcedures vps _) = Just vps - getProposalProcedures - :: TxProposalProcedures build era - -> Maybe [L.ProposalProcedure (ShelleyLedgerEra era)] - getProposalProcedures TxProposalProceduresNone = Nothing - getProposalProcedures txpp@(TxProposalProcedures _ _) = Just . toList $ convProposalProcedures txpp - -- | Test that the fee is the same when spending minted asset manually or when autobalancing it prop_make_transaction_body_autobalance_return_correct_fee_for_multi_asset :: Property prop_make_transaction_body_autobalance_return_correct_fee_for_multi_asset = H.propertyOnce $ do @@ -296,14 +212,7 @@ tests :: TestTree tests = testGroup "Test.Cardano.Api.Typed.TxBody" - [ testProperty "roundtrip txbodycontent txouts Babbage" $ - prop_roundtrip_txbodycontent_txouts ShelleyBasedEraBabbage - , testProperty "roundtrip txbodycontent txouts Conway" $ - prop_roundtrip_txbodycontent_txouts ShelleyBasedEraConway - , testProperty - "roundtrip txbodycontent new conway fields" - prop_roundtrip_txbodycontent_conway_fields - , testProperty + [ testProperty "makeTransactionBodyAutoBalance test correct fees when mutli-asset tx" prop_make_transaction_body_autobalance_return_correct_fee_for_multi_asset ] diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/TxBody.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/TxBody.hs new file mode 100644 index 0000000000..033f2f4b2c --- /dev/null +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/TxBody.hs @@ -0,0 +1,122 @@ +{-# LANGUAGE GADTs #-} +{-# LANGUAGE LambdaCase #-} +{-# LANGUAGE OverloadedLists #-} +{-# LANGUAGE RankNTypes #-} +{-# LANGUAGE ScopedTypeVariables #-} + +{- HLINT ignore "Use camelCase" -} + +module Test.Cardano.Api.TxBody + ( tests + ) +where + +import Cardano.Api +import qualified Cardano.Api.Ledger as L +import Cardano.Api.Script +import Cardano.Api.Shelley (ShelleyLedgerEra) + +import Data.Maybe (isJust) +import Data.Type.Equality (TestEquality (testEquality)) +import GHC.Exts (IsList (..)) + +import Test.Gen.Cardano.Api.Typed + +import Test.Cardano.Api.Orphans () + +import Hedgehog (MonadTest, Property, (===)) +import qualified Hedgehog as H +import Test.Tasty (TestTree, testGroup) +import Test.Tasty.Hedgehog (testProperty) + +-- | Check the txOuts in a TxBodyContent after a ledger roundtrip. +prop_roundtrip_txbodycontent_txouts :: forall era. ShelleyBasedEra era -> Property +prop_roundtrip_txbodycontent_txouts era = H.property $ do + (body, content :: TxBodyContent BuildTx era) <- + shelleyBasedEraConstraints era $ H.forAll $ genValidTxBody era + -- Convert ledger body back via 'getTxBodyContent' and 'fromLedgerTxBody' + let (TxBody content') = body + matchTxOuts (txOuts content) (txOuts content') + where + matchTxOuts :: MonadTest m => [TxOut CtxTx era] -> [TxOut CtxTx era] -> m () + matchTxOuts as bs = + mapM_ matchTxOut $ zip as bs + + matchTxOut :: MonadTest m => (TxOut CtxTx era, TxOut CtxTx era) -> m () + matchTxOut (a, b) = do + let TxOut aAddress aValue aDatum aRefScript = a + let TxOut bAddress bValue bDatum bRefScript = b + aAddress === bAddress + aValue === bValue + matchDatum (aDatum, bDatum) + matchRefScript (aRefScript, bRefScript) + + -- NOTE: We accept TxOutDatumInTx instead of TxOutDatumHash as it may be + -- correctly resolved given a datum matching the hash was generated. + matchDatum :: MonadTest m => (TxOutDatum CtxTx era, TxOutDatum CtxTx era) -> m () + matchDatum = \case + (TxOutDatumHash _ dh, TxOutDatumInTx _ d) -> + dh === hashScriptDataBytes d + (a, b) -> + a === b + + -- NOTE: After Allegra, all eras interpret SimpleScriptV1 as SimpleScriptV2 + -- because V2 is a superset of V1. So we accept that as a valid conversion. + matchRefScript :: MonadTest m => (ReferenceScript era, ReferenceScript era) -> m () + matchRefScript (a, b) + | isSimpleScriptV2 a && isSimpleScriptV2 b = + shelleyBasedEraConstraints era $ + refScriptToShelleyScript era a + === refScriptToShelleyScript era b + | otherwise = + a === b + + isSimpleScriptV2 :: ReferenceScript era -> Bool + isSimpleScriptV2 = isLang SimpleScriptLanguage + + isLang :: ScriptLanguage a -> ReferenceScript era -> Bool + isLang expected = \case + (ReferenceScript _ (ScriptInAnyLang actual _)) -> isJust $ testEquality expected actual + _ -> False + +prop_roundtrip_txbodycontent_conway_fields :: Property +prop_roundtrip_txbodycontent_conway_fields = H.property $ do + let sbe = ShelleyBasedEraConway + (body, content) <- H.forAll $ genValidTxBody sbe + -- Convert ledger body back via 'getTxBodyContent' and 'fromLedgerTxBody' + let (TxBody content') = body + + let proposals = getProposalProcedures . unFeatured <$> txProposalProcedures content + proposals' = getProposalProcedures . unFeatured <$> txProposalProcedures content' + votes = getVotingProcedures . unFeatured <$> txVotingProcedures content + votes' = getVotingProcedures . unFeatured <$> txVotingProcedures content' + currTreasury = unFeatured <$> txCurrentTreasuryValue content + currTreasury' = unFeatured <$> txCurrentTreasuryValue content' + treasuryDonation = unFeatured <$> txTreasuryDonation content + treasuryDonation' = unFeatured <$> txTreasuryDonation content' + + proposals === proposals' + votes === votes' + currTreasury === currTreasury' + treasuryDonation === treasuryDonation' + where + getVotingProcedures TxVotingProceduresNone = Nothing + getVotingProcedures (TxVotingProcedures vps _) = Just vps + getProposalProcedures + :: TxProposalProcedures build era + -> Maybe [L.ProposalProcedure (ShelleyLedgerEra era)] + getProposalProcedures TxProposalProceduresNone = Nothing + getProposalProcedures txpp@(TxProposalProcedures _ _) = Just . toList $ convProposalProcedures txpp + +tests :: TestTree +tests = + testGroup + "Test.Cardano.Api.Typed.TxBody" + [ testProperty "roundtrip txbodycontent txouts Babbage" $ + prop_roundtrip_txbodycontent_txouts ShelleyBasedEraBabbage + , testProperty "roundtrip txbodycontent txouts Conway" $ + prop_roundtrip_txbodycontent_txouts ShelleyBasedEraConway + , testProperty + "roundtrip txbodycontent new conway fields" + prop_roundtrip_txbodycontent_conway_fields + ] diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/JSON.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/JSON.hs deleted file mode 100644 index c1d9ab26ae..0000000000 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/JSON.hs +++ /dev/null @@ -1,46 +0,0 @@ -{-# LANGUAGE DerivingStrategies #-} -{-# LANGUAGE FlexibleContexts #-} -{-# LANGUAGE TypeFamilies #-} -{-# OPTIONS_GHC -Wno-orphans #-} - -module Test.Cardano.Api.Typed.JSON - ( tests - ) -where - -import Cardano.Api - -import Data.Aeson (eitherDecode, encode) - -import Test.Gen.Cardano.Api.Typed (genMaybePraosNonce, genProtocolParameters) - -import Test.Cardano.Api.Typed.Orphans () - -import Hedgehog (Property, forAll, tripping) -import qualified Hedgehog as H -import qualified Hedgehog.Gen as Gen -import Test.Tasty (TestTree, testGroup) -import Test.Tasty.Hedgehog (testProperty) - -{- HLINT ignore "Use camelCase" -} - -prop_roundtrip_praos_nonce_JSON :: Property -prop_roundtrip_praos_nonce_JSON = H.property $ do - pNonce <- forAll $ Gen.just genMaybePraosNonce - tripping pNonce encode eitherDecode - -prop_roundtrip_protocol_parameters_JSON :: Property -prop_roundtrip_protocol_parameters_JSON = H.property $ do - AnyCardanoEra era <- forAll $ Gen.element [minBound .. maxBound] - pp <- forAll (genProtocolParameters era) - tripping pp encode eitherDecode - --- ----------------------------------------------------------------------------- - -tests :: TestTree -tests = - testGroup - "Test.Cardano.Api.Typed.JSON" - [ testProperty "roundtrip praos nonce JSON" prop_roundtrip_praos_nonce_JSON - , testProperty "roundtrip protocol parameters JSON" prop_roundtrip_protocol_parameters_JSON - ] diff --git a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Value.hs b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Value.hs similarity index 98% rename from cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Value.hs rename to cardano-api/test/cardano-api-test/Test/Cardano/Api/Value.hs index 1e85200b5f..7bfc366395 100644 --- a/cardano-api/test/cardano-api-test/Test/Cardano/Api/Typed/Value.hs +++ b/cardano-api/test/cardano-api-test/Test/Cardano/Api/Value.hs @@ -1,4 +1,4 @@ -module Test.Cardano.Api.Typed.Value +module Test.Cardano.Api.Value ( tests ) where diff --git a/cardano-api/test/cardano-api-test/cardano-api-test.hs b/cardano-api/test/cardano-api-test/cardano-api-test.hs index e1ed1e081b..3b977fb1c0 100644 --- a/cardano-api/test/cardano-api-test/cardano-api-test.hs +++ b/cardano-api/test/cardano-api-test/cardano-api-test.hs @@ -6,7 +6,11 @@ import System.IO (BufferMode (LineBuffering), hSetBuffering, hSetEncod import qualified Test.Gen.Cardano.Api.Byron +import qualified Test.Cardano.Api.Address +import qualified Test.Cardano.Api.Bech32 +import qualified Test.Cardano.Api.CBOR import qualified Test.Cardano.Api.Crypto +import qualified Test.Cardano.Api.Envelope import qualified Test.Cardano.Api.EpochLeadership import qualified Test.Cardano.Api.Eras import qualified Test.Cardano.Api.Genesis @@ -15,16 +19,12 @@ import qualified Test.Cardano.Api.Json import qualified Test.Cardano.Api.KeysByron import qualified Test.Cardano.Api.Ledger import qualified Test.Cardano.Api.Metadata +import qualified Test.Cardano.Api.Ord import qualified Test.Cardano.Api.ProtocolParameters -import qualified Test.Cardano.Api.Typed.Address -import qualified Test.Cardano.Api.Typed.Bech32 -import qualified Test.Cardano.Api.Typed.CBOR -import qualified Test.Cardano.Api.Typed.Envelope -import qualified Test.Cardano.Api.Typed.JSON -import qualified Test.Cardano.Api.Typed.Ord -import qualified Test.Cardano.Api.Typed.RawBytes -import qualified Test.Cardano.Api.Typed.TxBody -import qualified Test.Cardano.Api.Typed.Value +import qualified Test.Cardano.Api.RawBytes +import qualified Test.Cardano.Api.Transaction.Autobalance +import qualified Test.Cardano.Api.TxBody +import qualified Test.Cardano.Api.Value import Test.Tasty (TestTree, defaultMain, testGroup) @@ -41,7 +41,11 @@ tests = testGroup "Cardano.Api" [ Test.Gen.Cardano.Api.Byron.tests + , Test.Cardano.Api.Address.tests + , Test.Cardano.Api.Bech32.tests + , Test.Cardano.Api.CBOR.tests , Test.Cardano.Api.Crypto.tests + , Test.Cardano.Api.Envelope.tests , Test.Cardano.Api.EpochLeadership.tests , Test.Cardano.Api.Eras.tests , Test.Cardano.Api.Genesis.tests @@ -50,14 +54,10 @@ tests = , Test.Cardano.Api.KeysByron.tests , Test.Cardano.Api.Ledger.tests , Test.Cardano.Api.Metadata.tests + , Test.Cardano.Api.Ord.tests , Test.Cardano.Api.ProtocolParameters.tests - , Test.Cardano.Api.Typed.Address.tests - , Test.Cardano.Api.Typed.Bech32.tests - , Test.Cardano.Api.Typed.CBOR.tests - , Test.Cardano.Api.Typed.Envelope.tests - , Test.Cardano.Api.Typed.JSON.tests - , Test.Cardano.Api.Typed.Ord.tests - , Test.Cardano.Api.Typed.RawBytes.tests - , Test.Cardano.Api.Typed.TxBody.tests - , Test.Cardano.Api.Typed.Value.tests + , Test.Cardano.Api.RawBytes.tests + , Test.Cardano.Api.Transaction.Autobalance.tests + , Test.Cardano.Api.TxBody.tests + , Test.Cardano.Api.Value.tests ]