{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
{-# OPTIONS_GHC -Wno-orphans #-}

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 (
  ExecSpecRule (..),
  SpecTranslate,
  runSpecTransM,
  showOpaqueErrorString,
  toSpecRep,
  unComputationResult,
 )
import Test.Cardano.Ledger.Conformance.ExecSpecRule.Conway.Base (externalFunctions)
import Test.Cardano.Ledger.Conformance.ExecSpecRule.Conway.Utxo (genUtxoExecContext)
import Test.Cardano.Ledger.Conformance.SpecTranslate.Conway.Base (
  ConwayTxBodyTransContext,
 )
import Test.Cardano.Ledger.Conformance.SpecTranslate.Conway.Utxow ()
import Test.Cardano.Ledger.Constrained.Conway (
  IsConwayUniv,
  UtxoExecContext,
  utxoEnvSpec,
  utxoStateSpec,
  utxoTxSpec,
 )
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
  , SpecTranslate ConwayTxBodyTransContext (ConwayTxCert ConwayEra)
  ) =>
  ExecSpecRule fn "UTXOW" ConwayEra
  where
  type ExecContext fn "UTXOW" ConwayEra = UtxoExecContext ConwayEra

  genExecContext :: HasCallStack => Gen (ExecContext fn "UTXOW" ConwayEra)
genExecContext = Gen (UtxoExecContext ConwayEra)
genUtxoExecContext
  environmentSpec :: HasCallStack =>
ExecContext fn "UTXOW" ConwayEra
-> Specification fn (ExecEnvironment fn "UTXOW" ConwayEra)
environmentSpec = forall (fn :: [*] -> * -> *).
IsConwayUniv fn =>
UtxoExecContext ConwayEra -> Specification fn (UtxoEnv ConwayEra)
utxoEnvSpec
  stateSpec :: HasCallStack =>
ExecContext fn "UTXOW" ConwayEra
-> ExecEnvironment fn "UTXOW" ConwayEra
-> Specification fn (ExecState fn "UTXOW" ConwayEra)
stateSpec = forall (fn :: [*] -> * -> *).
IsConwayUniv fn =>
UtxoExecContext ConwayEra
-> UtxoEnv ConwayEra -> Specification fn (UTxOState ConwayEra)
utxoStateSpec
  signalSpec :: HasCallStack =>
ExecContext fn "UTXOW" ConwayEra
-> ExecEnvironment fn "UTXOW" ConwayEra
-> ExecState fn "UTXOW" ConwayEra
-> Specification fn (ExecSignal fn "UTXOW" ConwayEra)
signalSpec ExecContext fn "UTXOW" ConwayEra
ctx ExecEnvironment fn "UTXOW" ConwayEra
_ ExecState fn "UTXOW" ConwayEra
_ = forall (fn :: [*] -> * -> *) era.
(IsConwayUniv fn, HasSpec fn (AlonzoTx era)) =>
UtxoExecContext era -> Specification fn (AlonzoTx era)
utxoTxSpec ExecContext fn "UTXOW" ConwayEra
ctx
  runAgdaRule :: HasCallStack =>
SpecRep (ExecEnvironment fn "UTXOW" ConwayEra)
-> SpecRep (ExecState fn "UTXOW" ConwayEra)
-> SpecRep (ExecSignal fn "UTXOW" ConwayEra)
-> Either
     OpaqueErrorString (SpecRep (ExecState fn "UTXOW" ConwayEra))
runAgdaRule SpecRep (ExecEnvironment fn "UTXOW" ConwayEra)
env SpecRep (ExecState fn "UTXOW" ConwayEra)
st SpecRep (ExecSignal fn "UTXOW" ConwayEra)
sig =
    forall a. ComputationResult Text a -> Either OpaqueErrorString a
unComputationResult forall a b. (a -> b) -> a -> b
$ T_ExternalFunctions_8
-> UTxOEnv
-> UTxOState
-> Tx
-> T_ComputationResult_46 Text UTxOState
Agda.utxowStep T_ExternalFunctions_8
externalFunctions SpecRep (ExecEnvironment fn "UTXOW" ConwayEra)
env SpecRep (ExecState fn "UTXOW" ConwayEra)
st SpecRep (ExecSignal fn "UTXOW" ConwayEra)
sig
  extraInfo :: HasCallStack =>
Globals
-> ExecContext fn "UTXOW" ConwayEra
-> Environment (EraRule "UTXOW" ConwayEra)
-> State (EraRule "UTXOW" ConwayEra)
-> Signal (EraRule "UTXOW" ConwayEra)
-> Either
     OpaqueErrorString
     (State (EraRule "UTXOW" ConwayEra),
      [Event (EraRule "UTXOW" ConwayEra)])
-> Doc AnsiStyle
extraInfo Globals
globals ExecContext fn "UTXOW" ConwayEra
ctx Environment (EraRule "UTXOW" ConwayEra)
env State (EraRule "UTXOW" ConwayEra)
st Signal (EraRule "UTXOW" ConwayEra)
sig Either
  OpaqueErrorString
  (State (EraRule "UTXOW" ConwayEra),
   [Event (EraRule "UTXOW" ConwayEra)])
_ =
    let
      result :: String
result =
        forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either forall a. Show a => a -> String
show Text -> String
T.unpack forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall ctx a. ctx -> SpecTransM ctx a -> Either Text a
runSpecTransM ExecContext fn "UTXOW" ConwayEra
ctx forall a b. (a -> b) -> a -> b
$
          T_ExternalFunctions_8 -> UTxOEnv -> UTxOState -> Tx -> Text
Agda.utxowDebug T_ExternalFunctions_8
externalFunctions
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall ctx a.
SpecTranslate ctx a =>
a -> SpecTransM ctx (SpecRep a)
toSpecRep Environment (EraRule "UTXOW" ConwayEra)
env
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall ctx a.
SpecTranslate ctx a =>
a -> SpecTransM ctx (SpecRep a)
toSpecRep State (EraRule "UTXOW" ConwayEra)
st
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall ctx a.
SpecTranslate ctx a =>
a -> SpecTransM ctx (SpecRep a)
toSpecRep Signal (EraRule "UTXOW" ConwayEra)
sig
      stFinal :: Either
  OpaqueErrorString
  (State (EraRule "UTXO" ConwayEra),
   [Event (EraRule "UTXO" ConwayEra)])
stFinal = forall (p :: * -> * -> *) a b c.
Bifunctor p =>
(a -> b) -> p a c -> p b c
first forall a. ToExpr a => a -> OpaqueErrorString
showOpaqueErrorString forall a b. (a -> b) -> a -> b
$ forall (rule :: Symbol) era.
(BaseM (EraRule rule era) ~ ShelleyBase, STS (EraRule rule era)) =>
Globals
-> Environment (EraRule rule era)
-> State (EraRule rule era)
-> Signal (EraRule rule era)
-> Either
     (NonEmpty (PredicateFailure (EraRule rule era)))
     (State (EraRule rule era), [Event (EraRule rule era)])
runSTS @"UTXO" @ConwayEra Globals
globals Environment (EraRule "UTXOW" ConwayEra)
env State (EraRule "UTXOW" ConwayEra)
st Signal (EraRule "UTXOW" ConwayEra)
sig
      utxoInfo :: Doc AnsiStyle
utxoInfo = forall (fn :: [*] -> * -> *) (rule :: Symbol) era.
(ExecSpecRule fn rule era, HasCallStack) =>
Globals
-> ExecContext fn rule era
-> Environment (EraRule rule era)
-> State (EraRule rule era)
-> Signal (EraRule rule era)
-> Either
     OpaqueErrorString
     (State (EraRule rule era), [Event (EraRule rule era)])
-> Doc AnsiStyle
extraInfo @fn @"UTXO" @ConwayEra Globals
globals ExecContext fn "UTXOW" ConwayEra
ctx Environment (EraRule "UTXOW" ConwayEra)
env State (EraRule "UTXOW" ConwayEra)
st Signal (EraRule "UTXOW" ConwayEra)
sig Either
  OpaqueErrorString
  (State (EraRule "UTXO" ConwayEra),
   [Event (EraRule "UTXO" ConwayEra)])
stFinal
     in
      forall ann. [Doc ann] -> Doc ann
PP.vcat
        [ Doc AnsiStyle
"UTXOW"
        , Doc AnsiStyle
"Impl:"
        , Doc AnsiStyle
"witsVKeyNeeded"
        , forall a. String -> Doc a
PP.ppString forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. ToExpr a => a -> String
showExpr forall a b. (a -> b) -> a -> b
$
            forall era.
(EraTx era, ConwayEraTxBody era) =>
UTxO era -> TxBody era -> Set (KeyHash 'Witness)
getConwayWitsVKeyNeeded @ConwayEra (forall era. UTxOState era -> UTxO era
utxosUtxo State (EraRule "UTXOW" ConwayEra)
st) (Signal (EraRule "UTXOW" ConwayEra)
sig forall s a. s -> Getting a s a -> a
^. forall era. EraTx era => Lens' (Tx era) (TxBody era)
bodyTxL)
        , Doc AnsiStyle
"witsVKeyHashes"
        , Doc AnsiStyle
"Spec:"
        , forall a. String -> Doc a
PP.ppString String
result
        , forall a. Monoid a => a
mempty
        , Doc AnsiStyle
"UTXO"
        , Doc AnsiStyle
utxoInfo
        ]