fix: unknown state goes to payout when slot state is finished (#555)

This commit is contained in:
Adam Uhlíř 2023-09-27 15:57:41 +02:00 committed by GitHub
parent 25ea7fd0b2
commit 2f1c778d02
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 7 additions and 3 deletions

View File

@ -6,6 +6,7 @@ import ./finished
import ./failed
import ./errored
import ./cancelled
import ./payout
logScope:
topics = "marketplace sales unknown"
@ -47,7 +48,9 @@ method run*(state: SaleUnknown, machine: Machine): Future[?State] {.async.} =
return some State(SaleErrored(error: error))
of SlotState.Filled:
return some State(SaleFilled())
of SlotState.Finished, SlotState.Paid:
of SlotState.Finished:
return some State(SalePayout())
of SlotState.Paid:
return some State(SaleFinished())
of SlotState.Failed:
return some State(SaleFailed())

View File

@ -8,6 +8,7 @@ import pkg/codex/sales/states/errored
import pkg/codex/sales/states/filled
import pkg/codex/sales/states/finished
import pkg/codex/sales/states/failed
import pkg/codex/sales/states/payout
import ../../helpers/mockmarket
import ../../examples
import ../../helpers
@ -45,10 +46,10 @@ checksuite "sales state 'unknown'":
let next = await state.run(agent)
check !next of SaleFilled
test "switches to finished state when on chain state is 'finished'":
test "switches to payout state when on chain state is 'finished'":
market.slotState[slotId] = SlotState.Finished
let next = await state.run(agent)
check !next of SaleFinished
check !next of SalePayout
test "switches to finished state when on chain state is 'paid'":
market.slotState[slotId] = SlotState.Paid