commit ec70bfd539fe2e27fd48f5f76395400287ac72d7
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Tue Oct 18 18:58:59 2022 -0500
use LSE
commit 25fff9b3ad1f2dde4cd7cf36977530b06a87d23c
Merge: 01cd3aa 1821dd6
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Tue Oct 18 18:17:45 2022 -0500
Merge branch 'staging' into seungheonoh/ply
commit 01cd3aa7a235e6fe6658246ca1026fa26dc71a83
Author: Hongrui Fang <chfanghr@gmail.com>
Date: Tue Oct 11 12:02:03 2022 +0800
update benchmark
commit a8513244892ce33cfdc9edf8cd501c4985ae8008
Author: Hongrui Fang <chfanghr@gmail.com>
Date: Tue Oct 11 11:59:22 2022 +0800
fix tests
commit 20ca40823485c2e2f78253643cf4453ac7b7ddd5
Author: Hongrui Fang <chfanghr@gmail.com>
Date: Tue Oct 11 11:57:37 2022 +0800
better import
commit a19fe49424210891bd03db71e4083fc1e0edfd98
Author: Hongrui Fang <chfanghr@gmail.com>
Date: Tue Oct 11 11:08:20 2022 +0800
update flake inputs
commit c93b21f1f9441e5c6f54525bf7c6a54757ec36cc
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Mon Oct 10 12:54:12 2022 -0500
tried to make tests pass
commit 1046ae1237299a33c58b48661bdb6d325a22147e
Merge: 2bf4e36 363bd83
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Mon Oct 10 12:18:48 2022 -0500
Merge branch 'staging' into seungheonoh/ply
commit 2bf4e3627c1b229f58078695082da85c80efd560
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Mon Oct 10 10:48:36 2022 -0500
remove junkpile
commit a1dbc9ad9e531fe0d0a0480c4aef9cf9ffa90f1d
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Mon Oct 10 10:47:25 2022 -0500
versions
commit 4542a06ac733858297d3a48c53368fad19dedc43
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Thu Oct 6 22:57:48 2022 -0500
script exporting interface
commit 6bd8c1a1d57e4bf9dc25c3068a9c8eae6bf6a19d
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Thu Oct 6 22:58:41 2022 -0500
fixed tests
commit d3ce2cf95633d336f3e621833677bd5bf10ee2c8
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Sun Oct 2 00:55:18 2022 -0500
fixed tests
commit 1ae64c9f692652b77b0506013853b2ba44267c65
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Sat Oct 1 13:28:20 2022 -0500
linker
commit db88cb75c7b74843141ad8ab4e6522b66d0dcfbc
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Sat Oct 1 01:03:50 2022 -0500
exporting scripts
commit 6389fce28e885a8a7f8669629c266f59c0edb51f
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Sat Oct 1 00:51:49 2022 -0500
made scripts parameterized on the script level
commit aea1e518a8890550bdebd0e5251da11d915c53a9
Author: Seungheon Oh <seungheon.ooh@gmail.com>
Date: Wed Sep 28 19:53:29 2022 -0500
Use `TypedScriptEnvelope` for `Agora.Bootstrap`
140 lines
4.1 KiB
Haskell
140 lines
4.1 KiB
Haskell
{-# LANGUAGE TemplateHaskell #-}
|
|
|
|
{- |
|
|
Module: Spec.Treasury
|
|
Description: Tests for Agora treasury.
|
|
Maintainer: jack@mlabs.city
|
|
|
|
This module exports `specs`, a list of `TestTree`s, which ensure
|
|
that Agora's treasury component works as desired.
|
|
|
|
Tests need to fail when:
|
|
|
|
1. The reedeemer is of inproper form. TODO: Inquire.
|
|
2. The script purpose is not minting.
|
|
3. `singleAuthorityTokenBurned` returns false.
|
|
a. @n /= -1@ GATs burned.
|
|
b. An input returns 'False' for 'authorityTokensValidIn'
|
|
i. A wallet input has a GAT.
|
|
ii. A script has a GAT, the token name for which does /not/
|
|
match the script's validator hash.
|
|
-}
|
|
module Spec.Treasury (specs) where
|
|
|
|
import PlutusLedgerApi.V1.Credential (
|
|
StakingCredential (StakingHash),
|
|
)
|
|
import PlutusLedgerApi.V1.Value qualified as Value (singleton)
|
|
import PlutusLedgerApi.V2 (DCert (DCertDelegRegKey), Validator)
|
|
import PlutusLedgerApi.V2.Contexts (
|
|
ScriptContext (scriptContextPurpose, scriptContextTxInfo),
|
|
ScriptPurpose (Certifying, Minting, Rewarding),
|
|
TxInfo (txInfoInputs, txInfoMint),
|
|
)
|
|
import Sample.Shared (trCredential, trValidator)
|
|
import Sample.Treasury (
|
|
gatCs,
|
|
gatTn,
|
|
trCtxGATNameNotAddress,
|
|
validCtx,
|
|
walletIn,
|
|
)
|
|
import Test.Specification (
|
|
SpecificationTree,
|
|
group,
|
|
validatorFailsWith,
|
|
validatorSucceedsWith,
|
|
)
|
|
|
|
compiledTreasuryValidator :: Validator
|
|
compiledTreasuryValidator = trValidator
|
|
|
|
specs :: [SpecificationTree]
|
|
specs =
|
|
[ group
|
|
"Validator"
|
|
[ group
|
|
"Positive"
|
|
[ validatorSucceedsWith
|
|
"Allows for effect changes"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
validCtx
|
|
, validatorSucceedsWith
|
|
"Fails when GAT token name is not script address"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
trCtxGATNameNotAddress
|
|
]
|
|
, group
|
|
"Negative"
|
|
[ group
|
|
"Fails with ScriptPurpose not Spending"
|
|
[ validatorFailsWith
|
|
"Minting"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
validCtx
|
|
{ scriptContextPurpose = Minting ""
|
|
}
|
|
, validatorFailsWith
|
|
"Rewarding"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
validCtx
|
|
{ scriptContextPurpose =
|
|
Rewarding $
|
|
StakingHash trCredential
|
|
}
|
|
, validatorFailsWith
|
|
"Certifying"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
validCtx
|
|
{ scriptContextPurpose =
|
|
Certifying $
|
|
DCertDelegRegKey $
|
|
StakingHash trCredential
|
|
}
|
|
]
|
|
, validatorFailsWith -- TODO: Use QuickCheck.
|
|
"Fails when multiple GATs burned"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
validCtx
|
|
{ scriptContextTxInfo =
|
|
validCtx.scriptContextTxInfo
|
|
{ txInfoMint =
|
|
Value.singleton
|
|
gatCs
|
|
gatTn
|
|
(-2)
|
|
}
|
|
}
|
|
, validatorFailsWith
|
|
"Fails with wallet as input"
|
|
compiledTreasuryValidator
|
|
()
|
|
()
|
|
( let txInfo = validCtx.scriptContextTxInfo
|
|
inputs = txInfo.txInfoInputs
|
|
newInputs =
|
|
[ head inputs
|
|
, walletIn
|
|
]
|
|
in validCtx
|
|
{ scriptContextTxInfo =
|
|
txInfo
|
|
{ txInfoInputs = newInputs
|
|
}
|
|
}
|
|
)
|
|
]
|
|
]
|
|
]
|