-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
simulation: Switch the log method from a single string to string buil… #2282
Conversation
@@ -157,7 +157,7 @@ test_sim_gaia_nondeterminism: | |||
|
|||
test_sim_gaia_fast: | |||
@echo "Running quick Gaia simulation. This may take several minutes..." | |||
@go test ./cmd/gaia/app -run TestFullGaiaSimulation -SimulationEnabled=true -SimulationNumBlocks=150 -v -timeout 24h | |||
@go test ./cmd/gaia/app -run TestFullGaiaSimulation -SimulationEnabled=true -SimulationNumBlocks=200 -v -timeout 24h |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After 200 it slows down again cuz of the governance slashing issue. But it burns through the first 200 in ~20 seconds!
5f7db4b
to
36eadf3
Compare
…ders This rapidly speeds up simulation in testing mode.
36eadf3
to
89423f6
Compare
Codecov Report
@@ Coverage Diff @@
## develop #2282 +/- ##
===========================================
+ Coverage 63.82% 63.83% +0.01%
===========================================
Files 140 140
Lines 8668 8666 -2
===========================================
Hits 5532 5532
+ Misses 2756 2754 -2
Partials 380 380 |
Also once this PR is merged, it will be super easy to make simulation print out the log on a panic |
932c1fc
to
400daf1
Compare
Huh is this faster than just using a byteslice instead of a string for the log messages? Seems like a possible memory leak to keep so many stringbuilders around. |
Using a single byte slice still has the re-allocation problem. (E.g when it's too full you need to re allocate the whole thing). My thinking with this is that it will be easier to then just start to purge these from memory by writing to disk every few blocks, and then deleting that string builder. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
utACK
PositivePowerInvariant(k)(t, app, log) | ||
ValidatorSetInvariant(k)(t, app, log) | ||
return func(app *baseapp.BaseApp) error { | ||
err := SupplyInvariants(ck, k, am)(app) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
would that Golang had monads
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can only wish :(
OK! |
…ders
This rapidly speeds up simulation in testing mode.
ref #1924
The idea here is basically instead of using a single "log" which everyone appends to all the time, instead have a log builder, which we have a centralized way of writing to/fro. Additionally invariants no longer print out the log, but instead return an error. This enables them to be easily reused / be located elsewhere from the simulation module.
In general it makes the types simulation wants you to make more extendable and easier to understand.
Targeted PR against correct branch (see CONTRIBUTING.md)
Linked to github-issue with discussion and accepted design OR link to spec that describes this work.
Wrote tests
Added entries in
PENDING.md
with issue #rereviewed
Files changed
in the github PR explorerFor Admin Use: