Bidding Task State Machine
The bidding task state machine is a system designed to manage the bidding process for tasks, taking into account task details such as price and timeout. In this setup, each task allows a maximum of three bidders to compete simultaneously, with each bidder being assigned a job to complete.
Bidders have the ability to set a limit on the number of bids they can process at the same time. This feature prevents them from accepting new bids once they reach their specified limit, enabling bidders to effectively manage their workload and participate in multiple tasks without overextending themselves.
States
The Bidding State Machine has several predefined states:
created: This is the initial state when a task is first created. The task stays in this state until bidding is opened.
accepting_bids: In this state, the task is open for bidders to place their bids. The task remains in this state until bidding is closed, the bid is cancelled, or the bid fails.
bidding_closed: This state indicates that the bidding process for the task has ended. The task transitions to this state from the 'accepting_bids' state. From here, the task can either be marked as 'submitted' or 'failed'.
submitted: This state signifies that the task has been submitted successfully. The task moves to this state from the 'bidding_closed' state. Once a task is in the 'submitted' state, it can then be completed.
completed: This is the final state indicating that the task has been completed successfully. The task transitions to this state from the 'submitted' state.
failed: This state indicates that the task has failed. The task can enter this state from the 'bidding_closed' state. If a task fails, it can be reset to the 'created' state.
cancelled: This state signifies that the bid for the task has been cancelled. The task can enter this state from the 'accepting_bids' state. If a bid is cancelled or fails, the task can be reset to the 'created' state.
The transitions between these states are managed by the state machine, which ensures that the task moves through its lifecycle in a controlled and predictable manner.
open_bidding
: Transition from Created to Accepting_Bids.close_bidding
: Transition from Accepting_Bids to Processing.cancel_bid
: Transition from Accepting_Bids to Cancelled.failed_bids
: Transition from Accepting_Bids to Cancelled.complete_task
: Transition from Submitted to Completed.mark_as_submitted
: Transition from Processing to Submitted.mark_as_failed
: Transition from Processing to Failed.reset_accepting_bids_to_created
: Transition from Accepting_Bids to Created.reset_failed_bids_to_created
: Transition from Failed to Created.
The Bidding State Machine has defined transitions between states:
Transition Between States
open_bidding: Transition from 'Created' to 'Accepting_Bids'.
close_bidding: Transition from 'Accepting_Bids' to 'Processing'.
cancel_bid: Transition from 'Accepting_Bids' to 'Cancelled'.
failed_bids: Transition from 'Accepting_Bids' to 'Cancelled'.
complete_task: Transition from 'Submitted' to 'Completed'.
mark_as_submitted: Transition from 'Processing' to 'Submitted'.
mark_as_failed: Transition from 'Processing' to 'Failed'.
reset_accepting_bids_to_created: Transition from 'Accepting_Bids' to 'Created'.
reset_failed_bids_to_created: Transition from 'Failed' to 'Created'.
Rules
The bidding task state machine should include the following rules:
A bidder cannot place a bid if they have exceeded their limit on the number of jobs they can process simultaneously.
Once a bidder has completed a job, they cannot be assigned any further jobs on the same task.
If the task is cancelled, all bids and jobs associated with the task are cancelled as well
Last updated