nim-raft/tests/basic_cluster.nim

58 lines
1.8 KiB
Nim
Raw Normal View History

2023-08-31 20:52:52 +00:00
# nim-raft
# Copyright (c) 2023 Status Research & Development GmbH
# Licensed under either of
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
# at your option.
# This file may not be copied, modified, or distributed except according to
# those terms.
import basic_timers
import basic_state_machine
import std/tables
2023-09-04 09:47:27 +00:00
import std/random
2023-08-31 22:00:39 +00:00
export raft_api
2023-08-31 20:52:52 +00:00
type
BasicRaftNode* = RaftNode[SmCommand, SmState]
BasicRaftCluster* = ref object
2023-09-03 03:27:27 +00:00
nodes*: Table[RaftNodeId, BasicRaftNode]
2023-08-31 20:52:52 +00:00
proc BasicRaftClusterRaftMessageSendCallbackCreate(cluster: BasicRaftCluster): RaftMessageSendCallback =
2023-09-01 02:55:55 +00:00
proc (msg: RaftMessageBase): Future[RaftMessageResponseBase] {.async, gcsafe.} =
2023-09-03 03:27:27 +00:00
result = await cluster.nodes[msg.receiverId].RaftNodeMessageDeliver(msg)
2023-08-31 20:52:52 +00:00
proc BasicRaftClusterStart*(cluster: BasicRaftCluster) =
2023-09-03 03:27:27 +00:00
for id, node in cluster.nodes:
RaftNodeStart(node)
2023-09-06 16:18:02 +00:00
proc BasicRaftClusterGetLeaderId*(cluster: BasicRaftCluster): UUID =
result = DefaultUUID
2023-09-03 03:27:27 +00:00
for id, node in cluster.nodes:
if RaftNodeIsLeader(node):
return RaftNodeIdGet(node)
2023-09-04 09:47:27 +00:00
proc BasicRaftClusterClientRequest*(cluster: BasicRaftCluster, req: RaftNodeClientRequest): Future[RaftNodeClientResponse] {.async.} =
case req.op:
of rncroRequestSmState:
var
2023-09-06 16:18:02 +00:00
nodeId = cluster.nodesIds[BasicRaftClusterGetLeaderId(cluster)]
result = await cluster.nodes[nodeId].RaftNodeServeClientRequest(req)
2023-09-04 09:47:27 +00:00
of rncroExecSmCommand:
discard
2023-08-31 20:52:52 +00:00
proc BasicRaftClusterInit*(nodesIds: seq[RaftNodeId]): BasicRaftCluster =
2023-09-04 09:47:27 +00:00
randomize()
2023-08-31 20:52:52 +00:00
new(result)
for nodeId in nodesIds:
var
peersIds = nodesIds
peersIds.del(peersIds.find(nodeId))
2023-09-03 03:27:27 +00:00
result.nodes[nodeId] = BasicRaftNode.new(nodeId, peersIds, BasicRaftClusterRaftMessageSendCallbackCreate(result))
2023-08-31 20:52:52 +00:00