Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
fix flaky test #3295
fix flaky test #3295
Changes from 2 commits
3f7d15f
3b570bc
bfe5d2f
c989d93
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
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.
If you wanna be fancy can derive this from the constant in sdk:
The +1 on the end is a buffer in case stake doesn't start activating immediately.
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.
The 3 here is essentially the 3 non-bootstrap validators, right?Does this compute the time for the stake to completely activate? Because I think the test just waits for the bootstrap node stake to fall below 1/3, which would be significantly soonerNo, actually I think the 3 is right. It just represents increasing the total amount of stake 3x, right?
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.
Also, I'm not sure if we need the +1 because this isn't trying to find the epoch in which we will hit the threshold. It's just computing number of epochs it will take once we start activating the stake
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.
ya the 3 is from the 1/3. Original equation is
Where:
S
isDEFAULT_NODE_STAKE
the bootstrap node's stakeR
is 9% akaNEW_WARMUP_COOLDOWN_RATE
X
isnum_expected_epochs
Essentially the denominator represents the total stake of the system at each epoch, it increases by 9%
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.
I'm definitely pro-code reuse tho; if we want to keep the timeout around, maybe a non-pub helper that takes an
Option<Duration>
, and then:wait_for_max_stake_below_threshold
calls helper withNone
wait_for_max_stake_below_threshold_with_timeout
calls helper withSome(timeout)
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.
style
If you are going to be modifying this, I suggest writing it completely in the imperative style or completely in the functional style. A mix of two styles is negatively affecting my ability to read the code, as it does not work fully with either of the existing intuitions that I have.
Imperative style:
Functional style:
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.
Is it okay if we do this in a follow-up? Hoping to limit to functional change for this commit
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.
Absolutely.
This was a suggestion in case you were going to change this code.
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.
If someone is specifically using the
_with_timeout()
variant when there is a no-timeout variant as well, I would think they'd have a timeout in mind and the parameter should beDuration
, notOption<Duration>
.As an example, another function from this file:
agave/rpc-client/src/rpc_client.rs
Lines 297 to 302 in ec781d3