mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-03-01 14:50:41 +00:00
* perf: contract storage optimizations * Apply optimization changes * Apply optimizing parameters sizing * Update codex-contracts-eth * bump latest changes in contracts branch * Change requestDurationLimit to uint64 * fix tests * fix tests --------- Co-authored-by: Arnaud <arnaud@status.im> Co-authored-by: Eric <5089238+emizzle@users.noreply.github.com>
55 lines
1.7 KiB
Nim
55 lines
1.7 KiB
Nim
import pkg/questionable
|
|
import pkg/chronos
|
|
import pkg/codex/contracts/requests
|
|
import pkg/codex/sales/states/cancelled
|
|
import pkg/codex/sales/salesagent
|
|
import pkg/codex/sales/salescontext
|
|
import pkg/codex/market
|
|
|
|
import ../../../asynctest
|
|
import ../../examples
|
|
import ../../helpers
|
|
import ../../helpers/mockmarket
|
|
import ../../helpers/mockclock
|
|
|
|
asyncchecksuite "sales state 'cancelled'":
|
|
let request = StorageRequest.example
|
|
let slotIndex = request.ask.slots div 2
|
|
let clock = MockClock.new()
|
|
|
|
let currentCollateral = UInt256.example
|
|
|
|
var market: MockMarket
|
|
var state: SaleCancelled
|
|
var agent: SalesAgent
|
|
var returnBytesWas = bool.none
|
|
var reprocessSlotWas = bool.none
|
|
var returnedCollateralValue = UInt256.none
|
|
|
|
setup:
|
|
market = MockMarket.new()
|
|
let onCleanUp = proc(
|
|
returnBytes = false, reprocessSlot = false, returnedCollateral = UInt256.none
|
|
) {.async.} =
|
|
returnBytesWas = some returnBytes
|
|
reprocessSlotWas = some reprocessSlot
|
|
returnedCollateralValue = returnedCollateral
|
|
|
|
let context = SalesContext(market: market, clock: clock)
|
|
agent = newSalesAgent(context, request.id, slotIndex, request.some)
|
|
agent.onCleanUp = onCleanUp
|
|
state = SaleCancelled.new()
|
|
|
|
test "calls onCleanUp with returnBytes = false, reprocessSlot = true, and returnedCollateral = currentCollateral":
|
|
market.fillSlot(
|
|
requestId = request.id,
|
|
slotIndex = slotIndex,
|
|
proof = Groth16Proof.default,
|
|
host = Address.example,
|
|
collateral = currentCollateral,
|
|
)
|
|
discard await state.run(agent)
|
|
check eventually returnBytesWas == some true
|
|
check eventually reprocessSlotWas == some false
|
|
check eventually returnedCollateralValue == some currentCollateral
|