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`
178 lines
4.9 KiB
Haskell
178 lines
4.9 KiB
Haskell
{- |
|
|
Module : Spec.Effect.TreasuryWithdrawalEffect
|
|
Maintainer : seungheon.ooh@gmail.com
|
|
Description: Sample based testing for Treasury Withdrawal Effect
|
|
|
|
This module specs the Treasury Withdrawal Effect.
|
|
-}
|
|
module Spec.Effect.TreasuryWithdrawal (specs) where
|
|
|
|
import Agora.Effect.TreasuryWithdrawal (
|
|
TreasuryWithdrawalDatum (TreasuryWithdrawalDatum),
|
|
)
|
|
import PlutusLedgerApi.V1.Value qualified as Value
|
|
import Sample.Effect.TreasuryWithdrawal (
|
|
buildReceiversOutputFromDatum,
|
|
buildScriptContext,
|
|
inputCollateral,
|
|
inputGAT,
|
|
inputTreasury,
|
|
inputUser,
|
|
outputTreasury,
|
|
outputUser,
|
|
treasuries,
|
|
users,
|
|
validator,
|
|
)
|
|
import Test.Specification (
|
|
SpecificationTree,
|
|
effectFailsWith,
|
|
effectSucceedsWith,
|
|
group,
|
|
)
|
|
import Test.Util (sortValue)
|
|
|
|
specs :: [SpecificationTree]
|
|
specs =
|
|
[ group
|
|
"effect"
|
|
[ effectSucceedsWith
|
|
"Simple"
|
|
validator
|
|
datum1
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 1 (asset1 10)
|
|
]
|
|
$ outputTreasury 1 (asset1 7) :
|
|
buildReceiversOutputFromDatum datum1
|
|
)
|
|
, effectSucceedsWith
|
|
"Simple with multiple treasuries "
|
|
validator
|
|
datum1
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 1 (asset1 10)
|
|
, inputTreasury 2 (asset1 100)
|
|
, inputTreasury 3 (asset1 500)
|
|
]
|
|
$ [ outputTreasury 1 (asset1 7)
|
|
, outputTreasury 2 (asset1 100)
|
|
, outputTreasury 3 (asset1 500)
|
|
]
|
|
++ buildReceiversOutputFromDatum datum1
|
|
)
|
|
, effectSucceedsWith
|
|
"Mixed Assets"
|
|
validator
|
|
datum2
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 1 (asset1 20)
|
|
, inputTreasury 2 (asset2 20)
|
|
]
|
|
$ [ outputTreasury 1 (asset1 13)
|
|
, outputTreasury 2 (asset2 14)
|
|
]
|
|
++ buildReceiversOutputFromDatum datum2
|
|
)
|
|
, effectFailsWith
|
|
"Pay to uknown 3rd party"
|
|
validator
|
|
datum2
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 1 (asset1 20)
|
|
, inputTreasury 2 (asset2 20)
|
|
]
|
|
$ [ outputUser 100 (asset1 2)
|
|
, outputTreasury 1 (asset1 11)
|
|
, outputTreasury 2 (asset2 14)
|
|
]
|
|
++ buildReceiversOutputFromDatum datum2
|
|
)
|
|
, effectFailsWith
|
|
"Missing receiver"
|
|
validator
|
|
datum2
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 1 (asset1 20)
|
|
, inputTreasury 2 (asset2 20)
|
|
]
|
|
$ [ outputTreasury 1 (asset1 13)
|
|
, outputTreasury 2 (asset2 14)
|
|
]
|
|
++ drop 1 (buildReceiversOutputFromDatum datum2)
|
|
)
|
|
, effectFailsWith
|
|
"Unauthorized treasury"
|
|
validator
|
|
datum3
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputCollateral 10
|
|
, inputTreasury 999 (asset1 20)
|
|
]
|
|
$ outputTreasury 999 (asset1 17) :
|
|
buildReceiversOutputFromDatum datum3
|
|
)
|
|
, effectFailsWith
|
|
"Prevent transactions besides the withdrawal"
|
|
validator
|
|
datum3
|
|
( buildScriptContext
|
|
[ inputGAT
|
|
, inputTreasury 1 (asset1 20)
|
|
, inputTreasury 999 (asset1 20)
|
|
, inputUser 99 (asset2 100)
|
|
]
|
|
$ [ outputTreasury 1 (asset1 17)
|
|
, outputUser 100 (asset2 100)
|
|
]
|
|
++ buildReceiversOutputFromDatum datum3
|
|
)
|
|
]
|
|
]
|
|
where
|
|
asset1 =
|
|
Value.singleton
|
|
"0d586e057e76238f8c56c0752507bfa45ae13b04f8497a311d4aaa48"
|
|
"OrangeBottle"
|
|
asset2 =
|
|
Value.singleton
|
|
"7e6aa764bceeba1f7acf47d20f1a2a85440afa2928f8ae96376f4d85"
|
|
"19721121"
|
|
datum1 =
|
|
TreasuryWithdrawalDatum
|
|
[ (head users, asset1 1)
|
|
, (users !! 1, asset1 1)
|
|
, (users !! 2, asset1 1)
|
|
]
|
|
[ treasuries !! 1
|
|
, treasuries !! 2
|
|
, treasuries !! 3
|
|
]
|
|
datum2 =
|
|
TreasuryWithdrawalDatum
|
|
[ (head users, sortValue $ asset2 5 <> asset1 4)
|
|
, (users !! 1, sortValue $ asset2 1 <> asset1 2)
|
|
, (users !! 2, asset1 1)
|
|
]
|
|
[ head treasuries
|
|
, treasuries !! 1
|
|
, treasuries !! 2
|
|
]
|
|
datum3 =
|
|
TreasuryWithdrawalDatum
|
|
[ (head users, asset1 1)
|
|
, (users !! 1, asset1 1)
|
|
, (users !! 2, asset1 1)
|
|
]
|
|
[treasuries !! 1]
|