mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-02-02 09:56:30 +00:00
962fc1cd95
* openAPI: StorageRequestCreation: reward => pricePerByte, collateral => collateralPerByte * purchasing: reward => pricePerByte, collateral => collateralPerByte * Updates availabilities and reservations to use totalCollateral, minPricePerByte, and maxCollateralPerByte * Uses correct div operator when operating on UInt256 * proposal updating totalCollateral in availability * makes sure that reading currentCollateral happens before freeing slot * Updates naming * fixes tests: unit and contracts * uses feat/price-per-byte branch for codex-contracts-eth * temporarily disables integration tests on CI * introduces high level <<totalCollateral>> property for a cleaner external interface * updates integration tests * Applies review comments * Updates description of totalCollateral in SalesAvailability * updates codex-contracts-eth (price-per-byte)
43 lines
1.3 KiB
Nim
43 lines
1.3 KiB
Nim
import pkg/questionable
|
|
import pkg/chronos
|
|
import pkg/codex/contracts/requests
|
|
import pkg/codex/sales/states/ignored
|
|
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 'ignored'":
|
|
let request = StorageRequest.example
|
|
let slotIndex = (request.ask.slots div 2).u256
|
|
let market = MockMarket.new()
|
|
let clock = MockClock.new()
|
|
|
|
var state: SaleIgnored
|
|
var agent: SalesAgent
|
|
var returnBytesWas = false
|
|
var reprocessSlotWas = false
|
|
|
|
setup:
|
|
let onCleanUp = proc(
|
|
returnBytes = false, reprocessSlot = false, returnedCollateral = UInt256.none
|
|
) {.async.} =
|
|
returnBytesWas = returnBytes
|
|
reprocessSlotWas = reprocessSlot
|
|
|
|
let context = SalesContext(market: market, clock: clock)
|
|
agent = newSalesAgent(context, request.id, slotIndex, request.some)
|
|
agent.onCleanUp = onCleanUp
|
|
state = SaleIgnored.new()
|
|
|
|
test "calls onCleanUp with values assigned to SaleIgnored":
|
|
state = SaleIgnored(reprocessSlot: true, returnBytes: true)
|
|
discard await state.run(agent)
|
|
check eventually returnBytesWas == true
|
|
check eventually reprocessSlotWas == true
|