2020-04-09 18:15:00 +02:00
|
|
|
# beacon_chain
|
2021-08-25 14:51:52 +00:00
|
|
|
# Copyright (c) 2018-2021 Status Research & Development GmbH
|
2020-04-09 18:15:00 +02:00
|
|
|
# Licensed and distributed under either of
|
|
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
2021-04-28 18:41:02 +02:00
|
|
|
# import ../interpreter # included to be able to use "suite"
|
2020-04-09 18:15:00 +02:00
|
|
|
|
2021-08-25 14:51:52 +00:00
|
|
|
func setup_finality_01(): tuple[fork_choice: ForkChoiceBackend, ops: seq[Operation]] =
|
2020-04-09 18:15:00 +02:00
|
|
|
var balances = @[Gwei(1), Gwei(1)]
|
|
|
|
let GenesisRoot = fakeHash(0)
|
|
|
|
|
|
|
|
# Initialize the fork choice context
|
2020-08-18 16:56:32 +02:00
|
|
|
result.fork_choice = ForkChoiceBackend.init(
|
2021-11-25 19:41:39 +01:00
|
|
|
justifiedCheckpoint = Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
|
|
|
finalizedCheckpoint = Checkpoint(root: GenesisRoot, epoch: Epoch(0))
|
2020-08-18 16:56:32 +02:00
|
|
|
)
|
2020-04-09 18:15:00 +02:00
|
|
|
|
|
|
|
# ----------------------------------
|
|
|
|
|
|
|
|
# Head should be genesis
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: FindHead,
|
2021-11-25 19:41:39 +01:00
|
|
|
justified_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
|
|
|
finalized_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
2020-04-09 18:15:00 +02:00
|
|
|
justified_state_balances: balances,
|
|
|
|
expected_head: GenesisRoot
|
|
|
|
)
|
|
|
|
|
|
|
|
# Build the following chain
|
|
|
|
#
|
|
|
|
# 0 <- just: 0, fin: 0
|
|
|
|
# |
|
|
|
|
# 1 <- just: 0, fin: 0
|
|
|
|
# |
|
|
|
|
# 2 <- just: 1, fin: 0
|
|
|
|
# |
|
|
|
|
# 3 <- just: 2, fin: 1
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: ProcessBlock,
|
|
|
|
root: fakeHash(1),
|
|
|
|
parent_root: GenesisRoot,
|
2021-11-25 19:41:39 +01:00
|
|
|
blk_justified_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
|
|
|
blk_finalized_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0))
|
2020-04-09 18:15:00 +02:00
|
|
|
)
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: ProcessBlock,
|
|
|
|
root: fakeHash(2),
|
|
|
|
parent_root: fakeHash(1),
|
2021-11-25 19:41:39 +01:00
|
|
|
blk_justified_checkpoint: Checkpoint(root: fakeHash(1), epoch: Epoch(1)),
|
|
|
|
blk_finalized_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0))
|
2020-04-09 18:15:00 +02:00
|
|
|
)
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: ProcessBlock,
|
|
|
|
root: fakeHash(3),
|
|
|
|
parent_root: fakeHash(2),
|
2021-11-25 19:41:39 +01:00
|
|
|
blk_justified_checkpoint: Checkpoint(root: fakeHash(2), epoch: Epoch(2)),
|
|
|
|
blk_finalized_checkpoint: Checkpoint(root: fakeHash(1), epoch: Epoch(1))
|
2020-04-09 18:15:00 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
# Ensure that with justified epoch 0 we find 3
|
|
|
|
#
|
|
|
|
# 0 <- start
|
|
|
|
# |
|
|
|
|
# 1
|
|
|
|
# |
|
|
|
|
# 2
|
|
|
|
# |
|
|
|
|
# 3 <- head
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: FindHead,
|
2021-11-25 19:41:39 +01:00
|
|
|
justified_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
|
|
|
finalized_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
2020-04-09 18:15:00 +02:00
|
|
|
justified_state_balances: balances,
|
|
|
|
expected_head: fakeHash(3)
|
|
|
|
)
|
|
|
|
|
|
|
|
# Ensure that with justified epoch 1 we find 2
|
|
|
|
#
|
|
|
|
# 0
|
|
|
|
# |
|
|
|
|
# 1
|
|
|
|
# |
|
|
|
|
# 2 <- start
|
|
|
|
# |
|
|
|
|
# 3 <- head
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: FindHead,
|
2021-11-25 19:41:39 +01:00
|
|
|
justified_checkpoint: Checkpoint(root: fakeHash(1), epoch: Epoch(1)),
|
|
|
|
finalized_checkpoint: Checkpoint(root: GenesisRoot, epoch: Epoch(0)),
|
2020-04-09 18:15:00 +02:00
|
|
|
justified_state_balances: balances,
|
|
|
|
expected_head: fakeHash(2)
|
|
|
|
)
|
|
|
|
|
|
|
|
# Ensure that with justified epoch 2 we find 3
|
|
|
|
#
|
|
|
|
# 0
|
|
|
|
# |
|
|
|
|
# 1
|
|
|
|
# |
|
|
|
|
# 2
|
|
|
|
# |
|
|
|
|
# 3 <- start + head
|
|
|
|
result.ops.add Operation(
|
|
|
|
kind: FindHead,
|
2021-11-25 19:41:39 +01:00
|
|
|
justified_checkpoint: Checkpoint(root: fakeHash(2), epoch: Epoch(2)),
|
|
|
|
finalized_checkpoint: Checkpoint(root: fakeHash(1), epoch: Epoch(1)),
|
2020-04-09 18:15:00 +02:00
|
|
|
justified_state_balances: balances,
|
|
|
|
expected_head: fakeHash(3)
|
|
|
|
)
|
|
|
|
|
|
|
|
proc test_ffg01() =
|
2021-04-28 18:41:02 +02:00
|
|
|
test "fork_choice - testing finality #01":
|
2020-04-09 18:15:00 +02:00
|
|
|
# for i in 0 ..< 4:
|
|
|
|
# echo " block (", i, ") hash: ", fakeHash(i)
|
|
|
|
# echo " ------------------------------------------------------"
|
|
|
|
|
|
|
|
var (ctx, ops) = setup_finality_01()
|
|
|
|
ctx.run(ops)
|
|
|
|
|
|
|
|
test_ffg01()
|