Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Block by Block Synchronous Sate Sync #812

Open
wants to merge 126 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 101 commits
Commits
Show all changes
126 commits
Select commit Hold shift + click to select a range
702cc81
WIP debugging
gokutheengineer Apr 13, 2023
bbf5458
wip
gokutheengineer Apr 13, 2023
6e65731
Add debug channels
Olshansk Apr 13, 2023
b3a953f
tests pass
gokutheengineer Apr 14, 2023
89fad5d
clean
gokutheengineer Apr 14, 2023
0fabffc
clean
gokutheengineer Apr 14, 2023
3ae3b88
clean, add comments
gokutheengineer Apr 14, 2023
e1091d0
syncs and adds blocks
gokutheengineer Apr 14, 2023
fd52e69
proceeds except when leader is one of new nodes
gokutheengineer Apr 14, 2023
c730357
leader election works
gokutheengineer Apr 14, 2023
f9a3424
debugging leader re-election
gokutheengineer Apr 15, 2023
1810cda
debug
gokutheengineer Apr 16, 2023
5a909ad
syncs up successfully, if itis not leader
gokutheengineer Apr 16, 2023
7cd1f4b
clean
gokutheengineer Apr 16, 2023
74def84
wip
gokutheengineer Apr 19, 2023
97d3f87
Merge branch 'main' into consensus/state-sync-channels
gokutheengineer Apr 19, 2023
48a912b
update state sync module
gokutheengineer Apr 19, 2023
92c2acf
clean, add comments
gokutheengineer Apr 19, 2023
de491dd
clean
gokutheengineer Apr 19, 2023
05161bd
fix typos
gokutheengineer Apr 19, 2023
5e70748
Update consensus/e2e_tests/utils_test.go
gokutheengineer Apr 21, 2023
9c17b18
Update consensus/e2e_tests/state_sync_test.go
gokutheengineer Apr 21, 2023
3270ee9
Update consensus/e2e_tests/utils_test.go
gokutheengineer Apr 21, 2023
a8fd744
Update consensus/module_consensus_state_sync.go
gokutheengineer Apr 21, 2023
1c4eb53
fixes
gokutheengineer Apr 25, 2023
c081464
move isValidator to persistence
gokutheengineer Apr 25, 2023
64bbfb1
address comments
gokutheengineer Apr 25, 2023
0a4140a
add block committed event
gokutheengineer Apr 26, 2023
c42790d
merge
gokutheengineer May 3, 2023
0034be9
update config
gokutheengineer May 3, 2023
386de6d
wip fixes
gokutheengineer May 3, 2023
92328c5
tests pass
gokutheengineer May 3, 2023
74675d1
clean commented parts
gokutheengineer May 3, 2023
8224e9a
address comments
gokutheengineer May 4, 2023
da8bdd8
updates
gokutheengineer May 4, 2023
a481e51
clean
gokutheengineer May 4, 2023
0671fd1
add generated helm docs
invalid-email-address May 4, 2023
959f60a
address comments, fix errors
gokutheengineer May 4, 2023
5068558
Merge branch 'state-sync' of github.com:pokt-network/pocket into stat…
gokutheengineer May 4, 2023
992a7d9
nits
gokutheengineer May 4, 2023
582d6f0
add helper
gokutheengineer May 5, 2023
97fb9ef
Lowercase some local testing types for consensus
Olshansk May 24, 2023
19a3a2e
Rename PKs to privKeys
Olshansk May 24, 2023
81af631
Remove privKeys from placeholderBlocks
Olshansk May 24, 2023
f74fb4c
Cleaning up some test code
Olshansk May 24, 2023
3619377
Finished reviewing consensus/e2e_tests/utils_test.go
Olshansk May 24, 2023
8150b76
Simplified state sync module interface
Olshansk May 24, 2023
373dc48
All tests still passing
Olshansk May 24, 2023
a0ddcfc
review consensus/fsm_handler.go
Olshansk May 25, 2023
f01d704
Remove isValidator
Olshansk May 25, 2023
66a0148
Merge with main
Olshansk May 25, 2023
84e2bc3
Tests pass after merging to main
Olshansk May 25, 2023
a0ec8d6
Rename background processes
Olshansk May 26, 2023
85f2156
Reviewed the block application loop
Olshansk May 26, 2023
476ade9
Reviewed server.go
Olshansk May 26, 2023
7dc5870
Cleaning up some code
Olshansk May 26, 2023
9945564
Cleanup consensus module a bit
Olshansk May 26, 2023
8d9f824
Completely removed the state sync from the consensus module
Olshansk May 26, 2023
1b16ab5
Merge branch 'main' into issues/352/state_sync
Olshansk May 26, 2023
60966cb
Interim commit to help me pick up
Olshansk May 30, 2023
0d760ba
Merge with main
Olshansk Jun 8, 2023
f86b491
add generated helm docs
invalid-email-address Jun 8, 2023
f7e0fbe
Add some notes & qualifiers to the protocol state sync document
Olshansk Jun 8, 2023
a4b7a7b
Moved WithDebugEventsChannel into a file with the test tag
Olshansk Jun 8, 2023
239661f
Moved some helpers into a debug helper file
Olshansk Jun 8, 2023
da3684e
Code cleanup figuring things out before diving into the business logi…
Olshansk Jun 8, 2023
0bcc33a
Add some comments
Olshansk Jun 8, 2023
ab8db90
Removed SetBlock
Olshansk Jun 9, 2023
759788e
Cleanup to some of the consensus testing utilities
Olshansk Jun 9, 2023
5205d9a
Update factory functions for consensus submodules
Olshansk Jun 9, 2023
b24871f
Updated StartSynchronousStateSync
Olshansk Jun 9, 2023
e82e41d
WIP - simplifying the test
Olshansk Jun 9, 2023
5696d48
Using broadcast instead of send with a loop where appropriate
Olshansk Jun 9, 2023
54fcd1b
A little bit of cleanup
Olshansk Jun 12, 2023
f0570da
Reverted utility module changes
Olshansk Jun 12, 2023
51864e2
Interim commit while working on 'TestStateSync_UnsyncedPeerSyncs_Succ…
Olshansk Jun 12, 2023
3a6cd23
State sync test passes with time.Sleep hack
Olshansk Jun 13, 2023
839cb3d
Merge with main
Olshansk Jun 13, 2023
c82860a
Merge with main
Olshansk Jun 13, 2023
b20b43a
Merge with main
Olshansk Jun 14, 2023
ed16e80
Some code cleanup while validating that unit tests all pass and doing…
Olshansk Jun 14, 2023
918e65b
Renamed eventsChannel to sharedNetworkEvents in consensus
Olshansk Jun 14, 2023
d2ed2bb
Added runtime/debug_helpers.go
Olshansk Jun 14, 2023
d2d7d01
Removed waitForNetworkFSMEvents
Olshansk Jun 14, 2023
8f540f2
Removed waitForNetworkFSMEvents
Olshansk Jun 14, 2023
7a1e146
Removed all the 'OLSH' comments
Olshansk Jun 14, 2023
c9bdebf
Removed an unnecessary check for m.utilityUnitOfWork
Olshansk Jun 14, 2023
1fa2a69
Removed unnecessary checks in hotstuff_replica
Olshansk Jun 14, 2023
730a1bf
Reverted changelogs
Olshansk Jun 15, 2023
c1057b0
Removed unused debug channels
Olshansk Jun 15, 2023
17384e9
Removed publishStateSyncBlockCommittedEvent
Olshansk Jun 15, 2023
2771a84
Renamed module_state_sync to state_sync_helpers
Olshansk Jun 15, 2023
54f6bce
Consolidated handlers and helpers for state sync
Olshansk Jun 15, 2023
e9fd550
Minor formatting issues in the .feature files
Olshansk Jun 15, 2023
5a4ec3b
Merge branch 'main' into issues/352/state_sync
Olshansk Jun 26, 2023
4efaa53
Merge with main
Olshansk Jun 29, 2023
54caf5b
Merge branch 'main' into issues/352/state_sync
Olshansk Jun 30, 2023
680f49b
Merge branch 'main' into issues/352/state_sync
Olshansk Jul 11, 2023
0cdcd9a
Merge branch 'main' into issues/352/state_sync
Olshansk Jul 12, 2023
d6d6b99
Merge with main
Olshansk Jul 18, 2023
c9fe524
Merge with main
Olshansk Jul 21, 2023
6856feb
Merge branch 'main' into issues/352/state_sync
Olshansk Jul 24, 2023
e6d0d5d
Merge with main
Olshansk Jul 26, 2023
c2cc4ae
Remove code from merge conflict
Olshansk Jul 26, 2023
209d8cc
Tend to go lint errors
Olshansk Jul 27, 2023
21e4441
Merge branch 'main' into issues/352/state_sync
Olshansk Jul 28, 2023
e74cc90
E2E State Sync Test
Olshansk Jul 28, 2023
9d840ed
Linting improvements
Olshansk Jul 29, 2023
9118167
Merge with main
Olshansk Aug 1, 2023
8418390
Merge with main
Olshansk Aug 1, 2023
2395a61
Update e2e/tests/steps_init_test.go
Olshansk Aug 1, 2023
489978f
Update documentation related to installing rsync
Olshansk Aug 1, 2023
4cc8405
Added # IMPROVE(#959): Remove time-based waits from tests
Olshansk Aug 2, 2023
da5c48f
Merge with main
Olshansk Aug 2, 2023
2792210
Follow up on minor comments
Olshansk Aug 2, 2023
9ce7882
s/validator/node in a few places
Olshansk Aug 2, 2023
4df3e28
Add account.feature and validator.feature
Olshansk Aug 2, 2023
34f635a
Remove kubectl_check from install_cli_deps
Olshansk Aug 2, 2023
1289063
Remove kubectl_check from install_cli_deps
Olshansk Aug 2, 2023
031c10c
Skip E2E test
Olshansk Aug 3, 2023
f5c68ba
Updated TODOs
Olshansk Aug 3, 2023
fa5577c
Added tags to the ./argo-linux-amd64 commands when running e2e-tests
Olshansk Aug 3, 2023
8a4dc0b
Merge with issues/829/state_sync_test
Olshansk Aug 3, 2023
46cd8e5
Merge with main
Olshansk Aug 3, 2023
819f990
Updated a few comments
Olshansk Aug 3, 2023
6ffe41d
Last week's state sync debugging changes
Olshansk Aug 7, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion app/client/cli/debug.go
Original file line number Diff line number Diff line change
Expand Up @@ -303,7 +303,7 @@ func fetchPeerstore(cmd *cobra.Command) (typesP2P.Peerstore, error) {

// sendConsensusNewHeightEventToP2PModule mimicks the consensus module sending a ConsensusNewHeightEvent to the p2p module
// This is necessary because the debug client is not a validator and has no consensus module but it has to update the peerstore
// depending on the changes in the validator set.
// depending on the changes in the validator set, which is based on the on-chain state.
// TODO(#613): Make the debug client mimic a full node.
func sendConsensusNewHeightEventToP2PModule(height uint64, bus modules.Bus) error {
newHeightEvent, err := messaging.PackMessage(&messaging.ConsensusNewHeightEvent{Height: height})
Expand Down
1 change: 0 additions & 1 deletion build/Dockerfile.debian.dev
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,6 @@ RUN make protogen_local && \
RUN go get -d -v ./app/pocket
RUN go build -o /usr/local/bin/pocket ./app/pocket
RUN go build -tags=debug -o /usr/local/bin/p1 ./app/client

RUN go build -o /usr/local/bin/cluster-manager ./build/localnet/cluster-manager

CMD ["/usr/local/bin/pocket"]
196 changes: 113 additions & 83 deletions build/localnet/Tiltfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
load("ext://helm_resource", "helm_resource", "helm_repo")
load("ext://namespace", "namespace_create")
load("ext://restart_process", "docker_build_with_restart")
load('ext://tests/golang', 'test_go')
load("ext://tests/golang", "test_go")

tiltfile_dir = os.path.dirname(config.main_dir)
root_dir = os.path.dirname(tiltfile_dir + "/../..")
Expand All @@ -13,7 +13,7 @@ localnet_config_defaults = {
"validators": {"count": 4},
"servicers": {"count": 1},
"fishermen": {"count": 1},
"full_nodes": {"count": 1}
"full_nodes": {"count": 1},
}

localnet_config_file = read_yaml(localnet_config_path, default=localnet_config_defaults)
Expand Down Expand Up @@ -49,6 +49,7 @@ deps = [

deps_full_path = [root_dir + "/" + depdir for depdir in deps]


# Avoid downloading dependencies if no missing/outdated charts are found
def check_helm_dependencies_for_chart(path):
check_helm_dependencies = local(
Expand All @@ -58,6 +59,7 @@ def check_helm_dependencies_for_chart(path):
if helm_dependencies_not_ok_count > 1:
local("helm dependency update " + path)


check_helm_dependencies_for_chart("dependencies")

k8s_yaml(helm("dependencies", name="dependencies"))
Expand All @@ -78,24 +80,24 @@ local_resource(
root_dir=root_dir
),
deps=deps_full_path,
labels=['watchers']
labels=["watchers"],
)
local_resource(
"debug client: Watch & Compile",
"GOOS=linux go build -tags=debug -o {root_dir}/bin/p1-linux {root_dir}/app/client/*.go".format(
root_dir=root_dir
),
deps=deps_full_path,
labels=['watchers']
labels=["watchers"],
)
# Builds the cluster manager binary
local_resource(
'cluster manager: Watch & Compile',
'GOOS=linux go build -o {root_dir}/bin/cluster-manager {root_dir}/build/localnet/cluster-manager/*.go'.format(
"cluster manager: Watch & Compile",
"GOOS=linux go build -o {root_dir}/bin/cluster-manager {root_dir}/build/localnet/cluster-manager/*.go".format(
root_dir=root_dir
),
deps=deps_full_path,
labels=['watchers']
labels=["watchers"],
)

# Builds and maintains the pocket container image after the binary is built on local machine, restarts a process on code change
Expand Down Expand Up @@ -141,12 +143,12 @@ WORKDIR /
COPY bin/cluster-manager /usr/local/bin/cluster-manager
COPY bin/p1-linux /usr/local/bin/p1
""",
only=['bin/cluster-manager', 'bin/p1-linux'],
only=["bin/cluster-manager", "bin/p1-linux"],
entrypoint=["/usr/local/bin/cluster-manager"],
live_update=[
sync("bin/cluster-manager", "/usr/local/bin/cluster-manager"),
sync("bin/p1-linux", "/usr/local/bin/p1"),
]
],
)

# Pushes localnet manifests to the cluster.
Expand All @@ -162,9 +164,9 @@ k8s_yaml(
)

k8s_yaml(["manifests/cli-client.yaml"])
k8s_resource('dev-cli-client', labels=['client'])
k8s_yaml(['manifests/cluster-manager.yaml'])
k8s_resource('pocket-v1-cluster-manager', labels=['cluster-manager'])
k8s_resource("dev-cli-client", labels=["client"])
k8s_yaml(["manifests/cluster-manager.yaml"])
k8s_resource("pocket-v1-cluster-manager", labels=["cluster-manager"])

chart_dir = root_dir + "/charts/pocket"
check_helm_dependencies_for_chart(chart_dir)
Expand All @@ -173,112 +175,140 @@ check_helm_dependencies_for_chart(chart_dir)
def formatted_actor_number(n):
return local('printf "%03d" ' + str(n))


# Provisions validators
actor_number = 0
for x in range(localnet_config["validators"]["count"]):
actor_number = actor_number + 1
formatted_number = formatted_actor_number(actor_number)

k8s_yaml(helm(chart_dir,
name="validator-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=validators-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"nodeType=validator",
],
values=[chart_dir + "/pocket-validator-overrides.yaml"] if os.path.exists(chart_dir + "/pocket-validator-overrides.yaml") else [],))

k8s_resource("validator-%s-pocket" % formatted_number, labels=['pocket-validators'])
k8s_yaml(
helm(
chart_dir,
name="validator-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=validators-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"nodeType=validator",
],
values=[chart_dir + "/pocket-validator-overrides.yaml"]
if os.path.exists(chart_dir + "/pocket-validator-overrides.yaml")
else [],
)
)

k8s_resource("validator-%s-pocket" % formatted_number, labels=["pocket-validators"])

# Provisions servicer nodes
actor_number = 0
for x in range(localnet_config["servicers"]["count"]):
actor_number = actor_number + 1
formatted_number = formatted_actor_number(actor_number)

k8s_yaml(helm(chart_dir,
name="servicer-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=servicers-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"config.servicer.enabled=true",
"nodeType=servicer",
],
values=[chart_dir + "/pocket-servicer-overrides.yaml"] if os.path.exists(chart_dir + "/pocket-servicer-overrides.yaml") else [],))

k8s_resource("servicer-%s-pocket" % formatted_number, labels=['pocket-servicers'])
k8s_yaml(
helm(
chart_dir,
name="servicer-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=servicers-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"config.servicer.enabled=true",
"nodeType=servicer",
],
values=[chart_dir + "/pocket-servicer-overrides.yaml"]
if os.path.exists(chart_dir + "/pocket-servicer-overrides.yaml")
else [],
)
)

k8s_resource("servicer-%s-pocket" % formatted_number, labels=["pocket-servicers"])

# Provisions fishermen nodes
actor_number = 0
for x in range(localnet_config["fishermen"]["count"]):
actor_number = actor_number + 1
formatted_number = formatted_actor_number(actor_number)

k8s_yaml(helm(chart_dir,
name="fisherman-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=fishermen-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"config.fisherman.enabled=true",
"nodeType=fisherman",
],
values=[chart_dir + "/pocket-fisherman-overrides.yaml"] if os.path.exists(chart_dir + "/pocket-fisherman-overrides.yaml") else [],))

k8s_resource("fisherman-%s-pocket" % formatted_number, labels=['pocket-fishermen'])
k8s_yaml(
helm(
chart_dir,
name="fisherman-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=fishermen-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"config.fisherman.enabled=true",
"nodeType=fisherman",
],
values=[chart_dir + "/pocket-fisherman-overrides.yaml"]
if os.path.exists(chart_dir + "/pocket-fisherman-overrides.yaml")
else [],
)
)

k8s_resource("fisherman-%s-pocket" % formatted_number, labels=["pocket-fishermen"])

# Provisions full nodes
actor_number = 0
for x in range(localnet_config["full_nodes"]["count"]):
actor_number = actor_number + 1
formatted_number = formatted_actor_number(actor_number)

k8s_yaml(helm(root_dir + "/charts/pocket",
name="full-node-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=misc-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"nodeType=full",
],
values=[chart_dir + "/pocket-full-node-overrides.yaml"] if os.path.exists(chart_dir + "/pocket-full-node-overrides.yaml") else [],))

k8s_resource("full-node-%s-pocket" % formatted_number, labels=['pocket-full-nodes'])
k8s_yaml(
helm(
root_dir + "/charts/pocket",
name="full-node-%s-pocket" % formatted_number,
set=[
"global.postgresql.auth.postgresPassword=LocalNetPassword",
"image.repository=pocket-image",
"privateKeySecretKeyRef.name=misc-private-keys",
"privateKeySecretKeyRef.key=%s" % formatted_number,
"genesis.preProvisionedGenesis.enabled=false",
"genesis.externalConfigMap.name=v1-localnet-genesis",
"genesis.externalConfigMap.key=genesis.json",
"postgresql.primary.persistence.enabled=false",
"nodeType=full",
],
values=[chart_dir + "/pocket-full-node-overrides.yaml"]
if os.path.exists(chart_dir + "/pocket-full-node-overrides.yaml")
else [],
)
)

k8s_resource("full-node-%s-pocket" % formatted_number, labels=["pocket-full-nodes"])

# Exposes grafana
k8s_resource(
new_name="grafana",
workload="dependencies-grafana",
extra_pod_selectors=[{"app.kubernetes.io/name": "grafana"}],
port_forwards=["42000:3000"],
labels=["monitoring"]
labels=["monitoring"],
)

# E2E test button
test_go('e2e-tests', '{root_dir}/e2e/tests'.format(root_dir=root_dir), '.',
extra_args=["-v", "-count=1", "-tags=e2e"],
labels=['e2e-tests'],
trigger_mode=TRIGGER_MODE_MANUAL,
test_go(
"e2e-tests",
"{root_dir}/e2e/tests".format(root_dir=root_dir),
".",
extra_args=["-v", "-count=1", "-tags=e2e"],
labels=["e2e-tests"],
trigger_mode=TRIGGER_MODE_MANUAL,
)
1 change: 1 addition & 0 deletions charts/pocket/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ privateKeySecretKeyRef:
| config.consensus.pacemaker_config.manual | bool | `true` | |
| config.consensus.pacemaker_config.timeout_msec | int | `10000` | |
| config.consensus.private_key | string | `""` | |
| config.consensus.server_mode_enabled | bool | `true` | |
| config.fisherman.enabled | bool | `false` | |
| config.logger.format | string | `"json"` | |
| config.logger.level | string | `"debug"` | |
Expand Down
1 change: 1 addition & 0 deletions charts/pocket/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ config:
manual: true
debug_time_between_steps_msec: 1000
private_key: "" # @ignored This value is needed but ignored - use privateKeySecretKeyRef instead
server_mode_enabled: true
utility:
max_mempool_transaction_bytes: 1073741824
max_mempool_transactions: 9000
Expand Down
13 changes: 9 additions & 4 deletions consensus/block.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,12 @@ func (m *consensusModule) commitBlock(block *coreTypes.Block) error {
return nil
}

// isBlockInMessageValidBasic does basic validation of the block in the hotstuff message such as:
// - validating if the block could/should be nil
// - the state hash of the block
// - the size of the block
// ADDTEST: Add unit tests specific to block validation
// IMPROVE: Rename to provide clarity of operation. ValidateBasic() is typically a stateless check not stateful
func (m *consensusModule) isValidMessageBlock(msg *typesCons.HotstuffMessage) (bool, error) {
func (m *consensusModule) isBlockInMessageValidBasic(msg *typesCons.HotstuffMessage) (bool, error) {
Olshansk marked this conversation as resolved.
Show resolved Hide resolved
block := msg.GetBlock()
step := msg.GetStep()

Expand Down Expand Up @@ -73,12 +76,14 @@ func (m *consensusModule) isValidMessageBlock(msg *typesCons.HotstuffMessage) (b
return true, nil
}

// Creates a new Utility Unit Of Work and clears/nullifies any previous UOW if they exist
// refreshUtilityUnitOfWork is a helper that creates a new Utility Unit Of Work and clears/nullifies a previous one if it exists
func (m *consensusModule) refreshUtilityUnitOfWork() error {
// Catch-all structure to release the previous utility UOW if it wasn't properly cleaned up.
utilityUnitOfWork := m.utilityUnitOfWork

// TECHDEBT: This should, theoretically, never happen. Need to identify all
// code paths where it does and fix it.
if utilityUnitOfWork != nil {
// TODO: This should, ideally, never be called
m.logger.Warn().Bool("TODO", true).Msg(typesCons.NilUtilityUOWWarning)
if err := utilityUnitOfWork.Release(); err != nil {
m.logger.Warn().Err(err).Msg("failed to release utility unit of work")
Expand Down
Loading