aiken/examples/acceptance_tests/script_context/validators/mint.ak

44 lines
1.1 KiB
Plaintext

use aiken/dict
use aiken/list
use aiken/transaction.{Mint, ScriptContext, Transaction}
use aiken/transaction/value
validator {
fn mint(redeemer: Data, ctx: ScriptContext) {
and {
assert_purpose(ctx),
assert_mint(ctx.purpose, ctx.transaction),
assert_redeemers(ctx, redeemer),
}
}
}
fn assert_purpose(ctx: ScriptContext) {
expect [my_policy_id] =
ctx.transaction.mint
|> value.from_minted_value
|> value.without_lovelace
|> value.policies
expect Mint(policy_id) = ctx.purpose
my_policy_id == policy_id
}
fn assert_mint(purpose, transaction: Transaction) {
expect Mint(policy_id) = purpose
let tokens =
value.tokens(transaction.mint |> value.from_minted_value, policy_id)
when dict.get(tokens, #"666f6f") is {
None -> fail @"token not found"
Some(quantity) -> quantity == 1337
}
}
fn assert_redeemers(ctx: ScriptContext, my_redeemer) {
expect Some(Pair(_, redeemer)) =
list.find(ctx.transaction.redeemers, fn(kv) { kv.1st == ctx.purpose })
my_redeemer == redeemer && list.length(ctx.transaction.redeemers) == 1
}