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

[FVM] removing legacy controller from storage #2713

Merged
merged 39 commits into from
Jul 15, 2022

Conversation

ramtinms
Copy link
Contributor

@ramtinms ramtinms commented Jun 28, 2022

This PR

remaining work

  • update EN RPC proto at flow repo and bump the version here
  • update flow emulator and update the dkg code to use the new one

@ramtinms ramtinms marked this pull request as draft June 28, 2022 03:53
Base automatically changed from ramtin/fvm-cleanup-legacy-controller to master June 28, 2022 04:31
@ramtinms ramtinms requested review from fxamacker and SupunS June 28, 2022 04:55
@ramtinms ramtinms marked this pull request as ready for review June 28, 2022 04:56
@github-actions
Copy link
Contributor

github-actions bot commented Jun 28, 2022

FVM Benchstat comparison

This branch with compared with the base branch onflow:master commit 45b6ede

The command (for i in {1..N}; do go test ./fvm --bench . --tags relic -shuffle=on --benchmem --run ^$; done) was used.

Bench tests were run a total of 10 times on each branch.

Collapsed results for better readability

old.txtnew.txt
time/opdelta
RuntimeTransaction/reference_tx-231.3ms ± 3%31.0ms ± 4%~(p=0.203 n=8+10)
RuntimeTransaction/convert_int_to_string-232.7ms ± 3%32.7ms ± 3%~(p=0.574 n=8+8)
RuntimeTransaction/convert_int_to_string_and_concatenate_it-236.8ms ±15%34.5ms ± 2%~(p=0.101 n=10+8)
RuntimeTransaction/get_signer_address-231.6ms ± 3%31.4ms ± 2%~(p=0.442 n=8+8)
RuntimeTransaction/get_public_account-235.1ms ± 3%35.2ms ± 4%~(p=0.905 n=10+9)
RuntimeTransaction/get_account_and_get_balance-2554ms ± 2%554ms ± 2%~(p=0.971 n=10+10)
RuntimeTransaction/get_account_and_get_available_balance-2449ms ± 2%452ms ± 3%~(p=0.278 n=9+10)
RuntimeTransaction/get_account_and_get_storage_used-240.0ms ± 2%40.1ms ± 4%~(p=0.631 n=10+10)
RuntimeTransaction/get_account_and_get_storage_capacity-2418ms ± 2%420ms ± 2%~(p=0.393 n=10+10)
RuntimeTransaction/get_signer_vault-239.7ms ± 3%39.3ms ± 2%~(p=0.200 n=8+9)
RuntimeTransaction/get_signer_receiver-250.4ms ± 1%50.0ms ± 2%~(p=0.053 n=9+10)
RuntimeTransaction/transfer_tokens-2200ms ± 3%200ms ± 3%~(p=0.971 n=10+10)
RuntimeTransaction/load_and_save_empty_string_on_signers_address-239.5ms ± 3%39.1ms ± 4%~(p=0.143 n=10+10)
RuntimeTransaction/load_and_save_long_string_on_signers_address-286.0ms ± 2%86.1ms ± 3%~(p=0.684 n=10+10)
RuntimeTransaction/create_new_account-21.23s ± 1%1.23s ± 3%~(p=0.905 n=9+10)
RuntimeTransaction/call_empty_contract_function-234.8ms ± 3%34.3ms ± 3%~(p=0.156 n=10+9)
RuntimeTransaction/emit_event-249.6ms ± 3%49.5ms ± 2%~(p=0.971 n=10+10)
RuntimeTransaction/borrow_array_from_storage-2128ms ± 2%128ms ± 2%~(p=0.796 n=10+10)
RuntimeTransaction/copy_array_from_storage-2128ms ± 4%127ms ± 1%~(p=0.720 n=10+9)
RuntimeNFTBatchTransfer-2128ms ± 2%126ms ± 2%−1.47%(p=0.019 n=9+9)
 
computationdelta
RuntimeTransaction/reference_tx-2202 ± 0%202 ± 0%~(all equal)
RuntimeTransaction/convert_int_to_string-2402 ± 0%402 ± 0%~(all equal)
RuntimeTransaction/convert_int_to_string_and_concatenate_it-2502 ± 0%502 ± 0%~(all equal)
RuntimeTransaction/get_signer_address-2302 ± 0%302 ± 0%~(all equal)
RuntimeTransaction/get_public_account-2402 ± 0%402 ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_balance-21.00k ± 0%1.00k ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_available_balance-22.50k ± 0%2.50k ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_storage_used-2402 ± 0%402 ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_storage_capacity-21.30k ± 0%1.30k ± 0%~(all equal)
RuntimeTransaction/get_signer_vault-2402 ± 0%402 ± 0%~(all equal)
RuntimeTransaction/get_signer_receiver-2602 ± 0%602 ± 0%~(all equal)
RuntimeTransaction/transfer_tokens-23.50k ± 0%3.50k ± 0%~(all equal)
RuntimeTransaction/load_and_save_empty_string_on_signers_address-2602 ± 0%602 ± 0%~(all equal)
RuntimeTransaction/load_and_save_long_string_on_signers_address-2602 ± 0%602 ± 0%~(all equal)
RuntimeTransaction/create_new_account-2202 ± 0%202 ± 0%~(all equal)
RuntimeTransaction/call_empty_contract_function-2402 ± 0%402 ± 0%~(all equal)
RuntimeTransaction/emit_event-2602 ± 0%602 ± 0%~(all equal)
RuntimeTransaction/borrow_array_from_storage-22.60k ± 0%2.60k ± 0%~(all equal)
RuntimeTransaction/copy_array_from_storage-22.60k ± 0%2.60k ± 0%~(all equal)
 
interactionsdelta
RuntimeTransaction/reference_tx-247.4k ± 0%47.4k ± 0%~(all equal)
RuntimeTransaction/convert_int_to_string-247.4k ± 0%47.4k ± 0%~(all equal)
RuntimeTransaction/convert_int_to_string_and_concatenate_it-247.4k ± 0%47.4k ± 0%~(all equal)
RuntimeTransaction/get_signer_address-247.4k ± 0%47.4k ± 0%~(all equal)
RuntimeTransaction/get_public_account-247.4k ± 0%47.4k ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_balance-216.7M ± 0%16.7M ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_available_balance-25.30M ± 0%5.30M ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_storage_used-250.2k ± 0%50.2k ± 0%~(all equal)
RuntimeTransaction/get_account_and_get_storage_capacity-25.30M ± 0%5.30M ± 0%~(all equal)
RuntimeTransaction/get_signer_vault-248.6k ± 0%48.6k ± 0%~(all equal)
RuntimeTransaction/get_signer_receiver-249.0k ± 0%49.0k ± 0%~(all equal)
RuntimeTransaction/transfer_tokens-249.8k ± 0%49.8k ± 0%~(all equal)
RuntimeTransaction/load_and_save_empty_string_on_signers_address-250.9k ± 0%50.9k ± 0%~(all equal)
RuntimeTransaction/load_and_save_long_string_on_signers_address-255.9k ± 0%55.9k ± 0%~(all equal)
RuntimeTransaction/create_new_account-28.43M ± 0%8.43M ± 0%~(all equal)
RuntimeTransaction/call_empty_contract_function-247.6k ± 0%47.6k ± 0%~(all equal)
RuntimeTransaction/emit_event-247.6k ± 0%47.6k ± 0%~(all equal)
RuntimeTransaction/borrow_array_from_storage-253.8k ± 0%53.8k ± 0%~(all equal)
RuntimeTransaction/copy_array_from_storage-253.8k ± 0%53.8k ± 0%~(all equal)
 
alloc/opdelta
RuntimeTransaction/copy_array_from_storage-246.9MB ± 0%46.7MB ± 0%−0.46%(p=0.000 n=8+9)
RuntimeTransaction/transfer_tokens-250.7MB ± 0%50.4MB ± 0%−0.53%(p=0.000 n=10+9)
RuntimeTransaction/get_account_and_get_available_balance-2149MB ± 0%148MB ± 0%−0.55%(p=0.000 n=10+10)
RuntimeTransaction/get_account_and_get_storage_capacity-2144MB ± 0%143MB ± 0%−0.56%(p=0.000 n=10+10)
RuntimeTransaction/borrow_array_from_storage-235.8MB ± 0%35.5MB ± 0%−0.61%(p=0.000 n=10+7)
RuntimeTransaction/get_account_and_get_balance-2199MB ± 0%198MB ± 0%−0.81%(p=0.000 n=9+10)
RuntimeTransaction/get_signer_receiver-215.5MB ± 1%15.4MB ± 0%−0.99%(p=0.000 n=10+10)
RuntimeTransaction/convert_int_to_string-29.93MB ± 1%9.82MB ± 1%−1.05%(p=0.000 n=10+10)
RuntimeTransaction/emit_event-214.7MB ± 0%14.5MB ± 1%−1.05%(p=0.000 n=10+10)
RuntimeTransaction/load_and_save_empty_string_on_signers_address-211.1MB ± 0%11.0MB ± 1%−1.08%(p=0.000 n=10+10)
RuntimeTransaction/get_account_and_get_storage_used-212.6MB ± 1%12.4MB ± 1%−1.19%(p=0.000 n=10+10)
RuntimeTransaction/get_signer_vault-211.7MB ± 1%11.5MB ± 1%−1.24%(p=0.000 n=10+10)
RuntimeTransaction/convert_int_to_string_and_concatenate_it-210.5MB ± 1%10.4MB ± 0%−1.32%(p=0.000 n=10+10)
RuntimeTransaction/get_public_account-211.2MB ± 0%11.0MB ± 1%−1.37%(p=0.000 n=10+10)
RuntimeTransaction/reference_tx-29.48MB ± 1%9.34MB ± 1%−1.50%(p=0.000 n=10+10)
RuntimeTransaction/get_signer_address-29.70MB ± 1%9.55MB ± 1%−1.63%(p=0.000 n=10+10)
RuntimeTransaction/call_empty_contract_function-210.3MB ± 0%10.1MB ± 0%−1.90%(p=0.000 n=10+7)
RuntimeTransaction/create_new_account-2295MB ± 0%287MB ± 0%−2.83%(p=0.000 n=10+10)
RuntimeNFTBatchTransfer-229.0MB ± 0%27.9MB ± 0%−3.59%(p=0.000 n=10+10)
RuntimeTransaction/load_and_save_long_string_on_signers_address-227.1MB ± 0%25.4MB ± 0%−6.21%(p=0.000 n=8+10)
 
allocs/opdelta
RuntimeTransaction/get_account_and_get_balance-23.28M ± 0%3.28M ± 0%~(p=0.684 n=10+10)
RuntimeTransaction/get_account_and_get_available_balance-22.64M ± 0%2.64M ± 0%~(p=0.305 n=10+10)
RuntimeTransaction/get_account_and_get_storage_capacity-22.50M ± 0%2.50M ± 0%~(p=0.123 n=10+10)
RuntimeTransaction/transfer_tokens-21.06M ± 0%1.06M ± 0%~(p=0.971 n=10+10)
RuntimeTransaction/load_and_save_empty_string_on_signers_address-2199k ± 0%199k ± 0%~(p=0.811 n=10+10)
RuntimeTransaction/create_new_account-24.48M ± 0%4.48M ± 0%~(p=0.165 n=10+10)
RuntimeTransaction/emit_event-2211k ± 0%211k ± 0%~(p=0.534 n=10+9)
RuntimeTransaction/copy_array_from_storage-2394k ± 0%394k ± 0%~(p=0.072 n=10+10)
RuntimeTransaction/get_signer_receiver-2289k ± 0%289k ± 0%−0.00%(p=0.004 n=10+10)
RuntimeTransaction/borrow_array_from_storage-2438k ± 0%437k ± 0%−0.00%(p=0.037 n=10+10)
RuntimeTransaction/reference_tx-2148k ± 0%148k ± 0%−0.00%(p=0.046 n=10+9)
RuntimeTransaction/convert_int_to_string_and_concatenate_it-2176k ± 0%176k ± 0%−0.00%(p=0.001 n=10+10)
RuntimeTransaction/convert_int_to_string-2162k ± 0%162k ± 0%−0.01%(p=0.001 n=9+10)
RuntimeTransaction/get_signer_vault-2200k ± 0%200k ± 0%−0.01%(p=0.000 n=9+10)
RuntimeTransaction/get_public_account-2184k ± 0%184k ± 0%−0.01%(p=0.002 n=10+10)
RuntimeTransaction/get_account_and_get_storage_used-2205k ± 0%205k ± 0%−0.01%(p=0.000 n=9+9)
RuntimeTransaction/call_empty_contract_function-2165k ± 0%165k ± 0%−0.01%(p=0.000 n=10+10)
RuntimeTransaction/get_signer_address-2153k ± 0%153k ± 0%−0.01%(p=0.001 n=10+9)
RuntimeTransaction/load_and_save_long_string_on_signers_address-2297k ± 0%297k ± 0%−0.01%(p=0.000 n=10+10)
RuntimeNFTBatchTransfer-2379k ± 0%379k ± 0%−0.01%(p=0.000 n=10+10)
 

Copy link
Member

@fxamacker fxamacker left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great! Thanks for removing controller reference in all these files!

Left some comments related to register key String() but most comments are about tests.

engine/execution/state/delta/delta_test.go Outdated Show resolved Hide resolved
model/flow/ledger.go Outdated Show resolved Hide resolved
model/flow/ledger_test.go Outdated Show resolved Hide resolved
@ramtinms ramtinms requested a review from fxamacker July 11, 2022 22:18
@codecov-commenter
Copy link

codecov-commenter commented Jul 11, 2022

Codecov Report

Merging #2713 (652aac3) into master (45b6ede) will increase coverage by 0.02%.
The diff coverage is 57.96%.

@@            Coverage Diff             @@
##           master    #2713      +/-   ##
==========================================
+ Coverage   56.37%   56.40%   +0.02%     
==========================================
  Files         686      686              
  Lines       63191    63166      -25     
==========================================
+ Hits        35625    35627       +2     
+ Misses      24547    24519      -28     
- Partials     3019     3020       +1     
Flag Coverage Δ
unittests 56.40% <57.96%> (+0.02%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

Impacted Files Coverage Δ
cmd/util/ledger/migrations/accounts.go 0.00% <0.00%> (ø)
...d/util/ledger/migrations/storage_fees_migration.go 8.88% <0.00%> (+0.19%) ⬆️
cmd/util/ledger/reporters/atree_reporter.go 0.00% <ø> (ø)
engine/execution/ingestion/engine.go 52.30% <0.00%> (ø)
fvm/errors/execution.go 2.72% <0.00%> (ø)
model/flow/ledger.go 22.50% <0.00%> (+2.04%) ⬆️
utils/debug/registerCache.go 0.00% <0.00%> (ø)
utils/debug/remoteView.go 0.00% <0.00%> (ø)
cmd/util/ledger/migrations/utils.go 12.50% <50.00%> (-2.02%) ⬇️
fvm/state/address_generator.go 39.58% <66.66%> (ø)
... and 14 more

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 45b6ede...652aac3. Read the comment docs.

@ramtinms ramtinms requested a review from Tonix517 July 11, 2022 23:52
Copy link
Contributor

@janezpodhostnik janezpodhostnik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me.

Great to have this removed finally :).

return ledger.Key{
KeyParts: []ledger.KeyPart{
ledger.NewKeyPart(0, a.Bytes()),
ledger.NewKeyPart(2, []byte(key)),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we use KeyPartOwner | KeyPartController | KeyPartKey here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed at 6706c4d

@ramtinms ramtinms merged commit 9652b94 into master Jul 15, 2022
@bors bors bot deleted the ramtin/fvm-remove-legacy-controller-from-storage branch July 15, 2022 23:56
durkmurder added a commit that referenced this pull request Jul 19, 2022
* update to Cadence v0.24.6

* Remove header caching

This 1 item caching introduces global lock and source of a 3+% slowdown.
```
$ go test -tags relic -bench='BenchmarkComputeBlock' -count 10 -run='^$' ./engine/execution/computation/.
...
$ benchstat old new
name                             old us/tx    new us/tx     delta
ComputeBlock/1/cols/16/txes-8       590 ± 3%      803 ±62%    ~     (p=0.404 n=10+10)
ComputeBlock/1/cols/32/txes-8       554 ± 2%      559 ± 2%  +0.93%  (p=0.043 n=9+8)
ComputeBlock/1/cols/64/txes-8       557 ± 4%      538 ± 2%  -3.46%  (p=0.000 n=10+10)
ComputeBlock/1/cols/128/txes-8      560 ± 1%      538 ± 2%  -3.92%  (p=0.000 n=7+9)
ComputeBlock/4/cols/16/txes-8       558 ± 3%      539 ± 1%  -3.51%  (p=0.000 n=10+10)
ComputeBlock/4/cols/32/txes-8       555 ± 1%      540 ± 1%  -2.81%  (p=0.000 n=10+10)
ComputeBlock/4/cols/64/txes-8       556 ± 2%      538 ± 2%  -3.13%  (p=0.000 n=10+10)
ComputeBlock/4/cols/128/txes-8      546 ± 1%      527 ± 2%  -3.50%  (p=0.000 n=10+10)
ComputeBlock/16/cols/16/txes-8      552 ± 3%      533 ± 2%  -3.44%  (p=0.000 n=10+10)
ComputeBlock/16/cols/32/txes-8      548 ± 1%      527 ± 2%  -3.68%  (p=0.000 n=9+10)
ComputeBlock/16/cols/64/txes-8      548 ± 1%      530 ± 1%  -3.34%  (p=0.000 n=10+10)
ComputeBlock/16/cols/128/txes-8     522 ± 1%      519 ± 2%    ~     (p=0.327 n=9+9)
```

* update crypto module version

* fix DST dashes

* update crypto version to v0.24.4

* fix import errors

* added prometheus gauges

* go fmt

* check if block is nil

* fix error check

* update help message

* update test to support Epoch Tx

* fixed mock

* comments

* update Cadence

* update Cadence

* update location creation

* add logs

* update Go SDK

* [BFT Testing] refactors gRPC interface  (#2599)

* empty wintermute test

* fix for brining up corrupted node

* added testnet.AsCorrupted() to specify corrupted node config

* added happy path from verification test; dummy orchestrator WIP implementation while BootstrapNetwork() is refactored

* dummy orchestrator WIP - added attack network

* adds corrupted identities

* implements dummy orchestrator

* wires in dummy orchestrator

* refactors wintermute

* adds log for attack network

* refactors lifecycle of attacker

* adds port exposing

* enables port exposing for corrupted nodes

* adds logging for corrupted nodes

* adds logging for default conduit factory

* fixes bug with building corrupted images

* refactors chain id as a parameter

* implements corrupted port mapping

* temp solution adds attacker docker address

* adds port mapping to test suite

* uncomments attacker registration

* fixes bug: empty publish list

* adds docker and local mode to attacker

* new Github workflow for BFT integration tests (#2418)

* added another bft branch filter

* implements dummy orchestrator tracker

* adds error for attacker address

* adds comment to corrupted connector

* removes redundant epose method

* adds a godoc

* adds comment

* removed unit-integration test category

* adds safety check for orrupted and ghost nodes

* adds godoc for dummy orchestrator

* adds more encapsulation

* adds comments

* makes generating execution receipt exportable

* (no branch): Auto stash before checking out "HEAD"

* removes corrupted execution result

* makes generating result approval exportable

* adds result approval generation to ccf

* fixes the tests

* adds attestation fixture

* adds message content as a parameter to message fixture

* fixes bug with publish

* wip

* adds test for result approval

* adds corrupted execution receipt test

* adds todos to factory

* refactors output types of wintermute orchestrator

* fixes lint issue

* removes unused variable

* Misha/6221 BFT Dummy Orchestrator - CI fix (#2445)

* CI fix - put back unit-integration test category, removed error test category check in test-setup.sh

* CI debug - test-setup.sh modified for debugging

* CI debug - run-tests.sh modified for debugging

* CI debug - run-tests.sh modified to send echo statements to standard error

* CI fix - test-setup.sh modified to send echo statements to standard error

* CI fix - added logging to test-setup.sh for unmatched test category

* CI testing - re-enabled unit test running

* CI - skipped-test-tracker.yml ready for CI test - added BFT integration tests, CI logging to test running

* CI - skipped-test-tracker.yml ready for CI test - run-tests.sh, test-setup.sh reverted to original actions to test in CI

* CI - skipped-test-tracker-integration.yml ready for CI test - added BFT integration tests, CI logging to test running

* CI - skipped-test-tracker-integration.yml, skipped-test-tracker.yml reverted back to not using tee for running tests - tests were taking too long to complete run

* CI - skipped-test-tracker-integration.yml, skipped-test-tracker.yml reverted to not using integration-bft test because it's consistently failing

* CI - skipped-test-tracker-integration.yml, skipped-test-tracker.yml reverted to not using BFT branches

* adds attack state getter

* adds wait for block by id

* adds wintermute test suite

* refactors wintermute attack orchestrator

* adds wintermute test

* Update insecure/wintermute/helpers.go

Co-authored-by: Misha <[email protected]>

* Update insecure/wintermute/helpers.go

Co-authored-by: Misha <[email protected]>

* fixes lint

* fixes receipt and approval bug with factory

* adds pass through test for receipt

* adds approval test

* adds chunk data pack with start state

* fixes bugs with wintermute orchestrator

* adds comments to attack orchestrator

* adds comments to wintermute orchestrator

* revises a comment

* adds comments

* implements test for passing through miscellaneous events

* fixes a bug

* adds testing for result approval pass through

* adds test wintermute result approval

* adds wait for approvals from any

* refactors result approval from

* makes the code more DRY

* refactors wintermute attack test

* adds comment to wintermute test

* refactors wintermute test

* adds is flag set

* lint fix

* lint fix

* nit

* refactors grpc interface

* updates grpc interface

* refactors attacknetwork interface

* refactors corrupted client

* updates mocks

* refactors corrupted connection

* refactors lifecycle management of corrupted connector

* refactors corrupted connector interface

* refactors factory

* removes grpc from attack network

* makes corrupted connector ready done aware

* fixes corrupted connector

* fixes corrupted connector tests

* re-generates mocks

* implements with mock ccfs

* wip

* removes mocks that we no longer need

* refactors corrupted connector interface

* regenerates mocks

* fixes corrupted connector tests

* wip: fixes attack network tests

* fixes all tests in attack network

* refactors mock attacker observer client

* fixes channel bug with factory

* fixes factory tests

* refactors integration tests

* refactors channel-based delivery

* fixes a bug with mock ccf

* BFT CI - fixed building all docker images for BFT tests, not just corrupted images

* increases timeout

* bumps up the timeout

* switches log level

* adds logging to factory

* switches back log levels

* fixes race condition

* skipping the test

* skipping test

* skips other tests that need a ccf grpc server

* fixes race condition in ccf

* adds more logging info

* makes attacker registration exported

* adds checking for attacker registration prior to sending messages

* updated to go 1.18

* switches all logs to debug

* unskips pass through

* adds block rate to pass through

* adds hotstuff timeout

* replaces testnet trakcer

* refactors log level

* excludes attacker

* switches all nodes to honest

* removes timeout

* skips wintermute

* comments out push approval channel

* comments in push approvals

* lint fix

* fixes lint and unskips passthrough

* skips passthrough and unskips wintermute

* skips wintermute, unskips passthrough

* bft integration tests running sequentially

* Update insecure/wintermute/attackOrchestrator.go

Co-authored-by: Jordan Schalm <[email protected]>

* Update integration/tests/bft/wintermute/wintermute_test.go

Co-authored-by: Jordan Schalm <[email protected]>

* Update integration/tests/lib/result_approval_state.go

Co-authored-by: Jordan Schalm <[email protected]>

* Update integration/tests/bft/wintermute/suite.go

Co-authored-by: Jordan Schalm <[email protected]>

* lint fix

* refactors sealing condition

* lint fix

* Update integration/tests/lib/result_approval_state.go

Co-authored-by: Jordan Schalm <[email protected]>

* adds more logging to block state

* adds more logging to state tracker

* bumps up wintermute timeout

* adds more logging to factory

* fixes a bug with factory

* fixes wintermute sealing condition

* Update integration/tests/bft/wintermute/wintermute_test.go

Co-authored-by: Jordan Schalm <[email protected]>

* Update integration/tests/common/sealing_and_verification.go

Co-authored-by: Jordan Schalm <[email protected]>

* Update integration/tests/bft/wintermute/wintermute_test.go

Co-authored-by: Peter Argue <[email protected]>

* Update insecure/wintermute/attackOrchestrator_test.go

Co-authored-by: Peter Argue <[email protected]>

* refactors wait group

* lint fix

* escalates log levels

* revises attack network tests

* revises a comment

* hammerings on corrupted node connection

* unskips factory tests

* fixes a log message

* revises corrupted connectors test

* adds a comment

* adds a comment

* adds a comment

* refactors factory

* Makefile - added clarification why need to run bft tests sequentially

* adds comments to mockAttackerObserveClient

* nit

* Update insecure/attacknetwork/corruptedConnector.go

Co-authored-by: Peter Argue <[email protected]>

* renames grpc method

* makes receive loop blocking

* go fmt

* go fmt

* moving lock from orchestrator to attacker

* adds a comment

Co-authored-by: gomisha <[email protected]>
Co-authored-by: Misha <[email protected]>
Co-authored-by: Jordan Schalm <[email protected]>
Co-authored-by: Peter Argue <[email protected]>

* fix migration test

* update test

* add legacy controller migration to the migrations

* remove time.Sleep

* update core contracts

* update outdated mocks

* add done channel to HotstuffFollower

* update HotstuffFollower mock

* fix unit tests

* update HotstuffFollower mock

* Revert "update HotstuffFollower mock"

This reverts commit fa42d25.

* close the done channel without defer

* removed tempfix comment

* fix lint

* update flow-core-contract module version

* fix linter issue

* update state commitments in tests after service account contract updates

* update to read only channel

* update state commitments

* improve error documentation for middleware

- add BenignNetworkingError sentinel that covers the entire class of benign networking errors
- add MiddlewareStartError sentinel that covers the entire class of errors returned from Middleware.start
- return appropriate sentinel errors and update godocs

* Update access_api_proxy_test.go

* comments and warning log

* fixed interface

* fix bls tests

* update to read only channel

* update to master of flow-go-sdk

* update to read only channel

* added a check for 0 execution nodes being passed

* Unskipping passing flaky test

* Moving emulator-based tests to the integration package (#2738)

* [Exec] Remove global lock from script execution

* process block responses

* remove unused import

* Update consensus/hotstuff/follower_loop.go

Co-authored-by: Leo Zhang <[email protected]>

* send proposalTask by pointer

* lint fix

* handleExecutionReceipt check for missing blocks

* call metric within the callback for handleCollection

* benchstat improvement

* go fmt

* [BFT Testing] Add BFT tests to regular CI workflows (#2725)

* added integration-bft test-category to flaky-test-monitor-integration.yml

* added integration-bft test-category to workflows - 1) CI 2) flaky-test-monitor 3) skipped-test-tracker 4) skipped-test-tracker-integration

* added corrupted Docker images to docker-build-flow target

* Makefile minor clean up

Co-authored-by: Yahya Hassanzadeh <[email protected]>

* reduce benchmark_repetitions a little

* removed uneccesary mock

* wrapping not found error

* record metrics inside callback

* fix return empty list without error

* [Exec] Remove Stop The World pauses from trx execution

* remove STW from script execution

* simplify

* fixed getTransactionResultsByBlockIDFromAnyExeNode

* factor runtime metrics to a separate file

* rename the file

* fixed lint

* add a comment to the GetHeapAllocsBytes()

* [Networking] Fixes flakey DNS cache expiry test (#2670)

* Debug logging messages for expire cache test

* Added comments to the code

* Swapped to sequential queries for testing purposes

* adding log messages

* Logging and locking cache

* switches back to sequential

* wip

* adds logger to cache and makes update atomic

* cleans up resolver test

* cleans up resolver test

* cleans up resolver

* wip

* fixes race condition

* refactors dns cache interface

* implements locking ip and txt domains

* fixes broken tests

* refactors dns locking signature

* adds test for dns cache lock

* adds comments for tests

* adds go doc

* moves locking from resolver to cache

* cleans up logs

* refactors dns cache tests

* adds update ip domain to dns cache

* adds update txt domain to dns cache

* revises a comment

* adds dns cache update test

* refactors dns cache interface

* updates dns cache docs

* refactors records

* updates dns cache docs

* fixes a bug with dns cache

* revises dns cache

* refactors with resolution result

* reverts log level for unitttests

* adds return for error path of locking a domain

* fixes a comment

* reduces test timeouts

Co-authored-by: Leon Yu <[email protected]>

* Update command used

* remove sentinels, instead document benign errors

* return errors directly

* Update engine/access/ingestion/engine.go

Co-authored-by: Peter Argue <[email protected]>

* update maxReceiptHeight

* update maxCollectionHeight

* add comment to the metric name string

Co-authored-by: Leo Zhang <[email protected]>

* add consistency to error docs

* optimize emergency-sealing check

limit emergency sealing count

add comments

update comments

rename variables and add comments

suggestions for PR #2673 (#2703)

* expanded documentation around emergency sealing and renamed a few variables to improve clarity

* typo

* Update engine/consensus/approvals/Readme.md

Co-authored-by: Leo Zhang <[email protected]>

rename config

fix tests

fix tests

Apply suggestions from code review

Co-authored-by: Jordan Schalm <[email protected]>

update comments

* comments and switch followerBlockProposal struct for inRangeBlockResponse argument

* chore(localnet): faster account creation

* wrap error message

Co-authored-by: Leo Zhang <[email protected]>

* comments

Co-authored-by: Leo Zhang <[email protected]>

* Update engine/common/follower/engine.go

Co-authored-by: Leo Zhang <[email protected]>

* comments and go fmt

* Fixed docker-build-loader docker image build failure

* tweak Programs locking + minor refactoring

- reduce Get's critical section (don't hold lock when looking up parent's entry)
- guard HasChanges

* remove disk size metrics

* Don't leak signerLock outside of Account

* chore(loader): faster worker Stop()

* add signer ids to access API

fix access/handler

fix tests

fix tests

* Add Andrew Meyer to performance stream

Adding myself to the performance stream as suggested by @SaveTheRbtz

* chore(loader): switch from Client to Access API

* [Execution] check if state commitment exists before executing scripts (#2763)

* optimize inner loop

* add tests and test fix

* lint fix

* remove wal_metrics

* [AN] - Trigger Cache Eviction on Overwrite (#2760)

* trigger eviction logic for overwriting an entry

* comment with reasoning

Co-authored-by: Vishal <[email protected]>

* chore(loader): cleanup follower

* address PR comments

* cleanup comments

* consistent naming

* remove some details from comment

* chore(loader): wait for account creation results

* go mod tidy

* Update state/protocol/util.go

Co-authored-by: Alexander Hentschel <[email protected]>

* Update access/handler.go

Co-authored-by: Alexander Hentschel <[email protected]>

* Update state/protocol/util.go

Co-authored-by: Alexander Hentschel <[email protected]>

* Update state/protocol/util.go

Co-authored-by: Alexander Hentschel <[email protected]>

* Update README.md

Update note about setting up the crypto module locally for every new version

* add unit test for unhandled sealing segment case

* handle multi-block root sealing segment

* s/Rem/Remove/g to improve code readability

* duplicate error in the return statement

* improve naming

* [BFT Testing] Fixes wintermute orchestrator race condition (#2780)

* adds some comments

* adds mutual exclusion to attack orchestrator

* removes debug lines

* Unskipping join and leave ln test

* Apply suggestions from code review

Co-authored-by: Khalil Claybon <[email protected]>

* Apply suggestions from code review

Co-authored-by: Khalil Claybon <[email protected]>

* remove timeout case

* unused import

* work in progress

* resolved circular import

* added mock, linted code

* more cleanup

* organized imports

* organized imports

* organized imports

* :-(

* still trying to convince linter :-(   :-(

* next try to convince linter

* wip

* attempt failed

* [localnet] Putting limit to EXECUTION config to avoid potential confusion

* [localnet] also apply the same limit check for Consensus node

* wip

* linted code

* reducing unnecessary changes

* complete and mature draft

* Apply suggestions from code review

Co-authored-by: Jordan Schalm <[email protected]>

* addressing reviewer comments part 2

* extended `UnknownBlockError`

* linted code

* Add comments for returned errors

* change unittest fixture to use *flow.Header instead of flow.Header

Make test code more consistent with regular code

* add explicit note that root block is self-sealing

* Invoke contracts directly instead of via currying

* chore(localnet): fix observer's trace endpoint

* fix flaky test: TestStaticEpochTransition (#2698)

* added timestamp to logs for block_state, testnet_state_tracker

* added CI flaky test debug workflow for TestEpochStaticTransition/TestStaticEpochTransition

* fixed typo in test-category in CI file

* fixed docker build image target

* updated workflow to run cron scheduler on non-master branch

* fixed bug in CI file - flaky-test-debug.yml

* Update static epoch test to use same testing flow (#2761)

* update static epoch test to use same testing flow

* updated bft-tests.yml for debugging TestEpochStaticTransition/TestStaticEpochTransition

* added scheduled run every hour

* kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition #1

* kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition #2

* #3 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #4 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #5 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #6 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #7 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #8 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #9 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* #10 kick off another CI test run for TestEpochStaticTransition/TestStaticEpochTransition

* remove sleep

* Dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* dummy commit

* 7699 dummy commit

* 3651 dummy commit

* 21538 dummy commit

* 7108 dummy commit

* 7186 dummy commit

* 1772 dummy commit

* 30464 dummy commit

* 15633 dummy commit

* 11129 dummy commit

* 15839 dummy commit

* remove dummy file

* remove dummy file

Co-authored-by: gomisha <[email protected]>

* minor cleanup

* more minor cleanup

Co-authored-by: Jordan Schalm <[email protected]>

* chore(trace): rename file

* [FVM] removing legacy controller from storage (#2713)

* remove legacy controller

* fix tests

* update chunk verifier

* update test

* update emulator to support controller removal

* update flow protobuf version

* go mod tidy

* apply PR's comments

* update flow proto files

* update flow emulator version

* go mod tidy

* update state commitment

* no in-place payload update

* expected update to state commitments

* update recent changes

* apply PR's comment

* Skipped broken tests related to active pacemaker

* Skipped more tests

* Skipped more tests

Co-authored-by: Bastian Müller <[email protected]>
Co-authored-by: bors[bot] <26634292+bors[bot]@users.noreply.github.com>
Co-authored-by: GetElastech <[email protected]>
Co-authored-by: Alexey Ivanov <[email protected]>
Co-authored-by: Tarak Ben Youssef <[email protected]>
Co-authored-by: Daniel Holmes <[email protected]>
Co-authored-by: danielholmes839 <[email protected]>
Co-authored-by: Khalil Claybon <[email protected]>
Co-authored-by: Janez Podhostnik <[email protected]>
Co-authored-by: Janez Podhostnik <[email protected]>
Co-authored-by: ramtinms <[email protected]>
Co-authored-by: Ramtin M. Seraj <[email protected]>
Co-authored-by: Simon Zhu <[email protected]>
Co-authored-by: Yahya Hassanzadeh <[email protected]>
Co-authored-by: gomisha <[email protected]>
Co-authored-by: Misha <[email protected]>
Co-authored-by: Jordan Schalm <[email protected]>
Co-authored-by: Peter Argue <[email protected]>
Co-authored-by: Faye Amacker <[email protected]>
Co-authored-by: Daniel Sainati <[email protected]>
Co-authored-by: lolpuddle <[email protected]>
Co-authored-by: Tarak Ben Youssef <[email protected]>
Co-authored-by: Leon Yu <[email protected]>
Co-authored-by: Leo Zhang <[email protected]>
Co-authored-by: Tony Z <[email protected]>
Co-authored-by: Patrick Lee <[email protected]>
Co-authored-by: Alexey Ivanov <[email protected]>
Co-authored-by: Andrew Meyer <[email protected]>
Co-authored-by: Vishal <[email protected]>
Co-authored-by: Alexander Hentschel <[email protected]>
Co-authored-by: danielholmes839 <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants