From 0d30b2db55da541e1226486d12c5ce17473c486d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joosep=20J=C3=A4=C3=A4ger?= Date: Mon, 16 Dec 2024 19:06:49 +0200 Subject: [PATCH] Included the hash in plutus script translation --- cabal.project | 4 ++-- .../Conformance/ExecSpecRule/Conway/Utxow.hs | 11 +++++++++++ .../src/Test/Cardano/Ledger/Conformance/Orphans.hs | 14 ++++++++++++-- .../Conformance/SpecTranslate/Conway/Base.hs | 2 +- .../src/Test/Cardano/Ledger/Conformance/Utils.hs | 5 ++++- 5 files changed, 30 insertions(+), 6 deletions(-) diff --git a/cabal.project b/cabal.project index 052dc9489aa..dae9761a41e 100644 --- a/cabal.project +++ b/cabal.project @@ -24,8 +24,8 @@ source-repository-package -- !WARNING!: -- MAKE SURE THIS POINTS TO A COMMIT IN `MAlonzo-code` BEFORE MERGE! subdir: generated - --sha256: sha256-by921yC1MaZI58kyrtEGGKqmt9jMnVsPLfQtP4raJPw= - tag: be51adff014214c15fed718d396bb8a6d955f9e1 + --sha256: sha256-/YE/qwup2ijMB7bo5eWyBIM+gXZ3Z1g0NZyNSfRwoPY= + tag: 93041ddbf659e0dbc1981d73fecb439b0209d484 -- NOTE: If you would like to update the above, look for the `MAlonzo-code` -- branch in the `formal-ledger-specifications` repo and copy the SHA of diff --git a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/ExecSpecRule/Conway/Utxow.hs b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/ExecSpecRule/Conway/Utxow.hs index 4bac7beb919..18e447e2376 100644 --- a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/ExecSpecRule/Conway/Utxow.hs +++ b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/ExecSpecRule/Conway/Utxow.hs @@ -14,8 +14,12 @@ module Test.Cardano.Ledger.Conformance.ExecSpecRule.Conway.Utxow () where import Cardano.Ledger.Conway (ConwayEra) import Cardano.Ledger.Conway.TxCert (ConwayTxCert) +import Cardano.Ledger.Conway.UTxO (getConwayWitsVKeyNeeded) +import Cardano.Ledger.Core (EraTx (..)) +import Cardano.Ledger.Shelley.LedgerState (UTxOState (..)) import Data.Bifunctor (Bifunctor (..)) import qualified Data.Text as T +import Lens.Micro ((^.)) import qualified Lib as Agda import qualified Prettyprinter as PP import Test.Cardano.Ledger.Conformance ( @@ -41,6 +45,7 @@ import Test.Cardano.Ledger.Constrained.Conway ( ) import qualified Test.Cardano.Ledger.Generic.PrettyCore as PP import Test.Cardano.Ledger.Shelley.Utils (runSTS) +import Test.Cardano.Ledger.TreeDiff (showExpr) instance ( IsConwayUniv fn @@ -69,6 +74,12 @@ instance in PP.vcat [ "UTXOW" + , "Impl:" + , "witsVKeyNeeded" + , PP.ppString . showExpr $ + getConwayWitsVKeyNeeded @ConwayEra (utxosUtxo st) (sig ^. bodyTxL) + , "witsVKeyHashes" + , "Spec:" , PP.ppString result , mempty , "UTXO" diff --git a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Orphans.hs b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Orphans.hs index dd0b89df90e..9cf6c50714a 100644 --- a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Orphans.hs +++ b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Orphans.hs @@ -149,8 +149,18 @@ instance NFData LEnv instance ToExpr a => ToExpr (HSSet a) instance ToExpr Credential where - toExpr (KeyHashObj h) = App "KeyHashObj" [agdaHashToExpr 28 h, toExpr h] - toExpr (ScriptObj h) = App "ScriptObj" [agdaHashToExpr 28 h, toExpr h] + toExpr (KeyHashObj h) = + App + "KeyHashObj" + [ agdaHashToExpr standardAddrHashSize h + , toExpr h + ] + toExpr (ScriptObj h) = + App + "ScriptObj" + [ agdaHashToExpr standardAddrHashSize h + , toExpr h + ] instance (ToExpr k, ToExpr v) => ToExpr (HSMap k v) diff --git a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/SpecTranslate/Conway/Base.hs b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/SpecTranslate/Conway/Base.hs index ecf0cd3e77e..eb5b1573ae6 100644 --- a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/SpecTranslate/Conway/Base.hs +++ b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/SpecTranslate/Conway/Base.hs @@ -245,7 +245,7 @@ instance type SpecRep (AlonzoScript era) = Agda.Script toSpecRep (TimelockScript s) = Left <$> toSpecRep s - toSpecRep (PlutusScript _) = pure $ Right () + toSpecRep (PlutusScript s) = Right . (,()) <$> toSpecRep s instance ( EraTxOut era diff --git a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Utils.hs b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Utils.hs index 21c7e20f5eb..16701709995 100644 --- a/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Utils.hs +++ b/libs/cardano-ledger-conformance/src/Test/Cardano/Ledger/Conformance/Utils.hs @@ -6,7 +6,7 @@ module Test.Cardano.Ledger.Conformance.Utils where import Cardano.Crypto.Hash (ByteString, Hash, HashAlgorithm, hashFromBytes, hashToBytes, sizeHash) import Cardano.Crypto.Util (bytesToNatural, naturalToBytes) -import Cardano.Ledger.Hashes (HASH) +import Cardano.Ledger.Hashes (ADDRHASH, HASH) import qualified Data.ByteString.Base16 as B16 import Data.Data (Proxy (..)) import Test.Cardano.Ledger.TreeDiff (Expr, ToExpr (..)) @@ -14,6 +14,9 @@ import Test.Cardano.Ledger.TreeDiff (Expr, ToExpr (..)) standardHashSize :: Int standardHashSize = fromIntegral . sizeHash $ Proxy @HASH +standardAddrHashSize :: Int +standardAddrHashSize = fromIntegral . sizeHash $ Proxy @ADDRHASH + agdaHashToBytes :: Int -> Integer -> ByteString agdaHashToBytes hs = B16.encode . naturalToBytes hs . fromInteger