test: fix bound related bug in fork tests #278
Merged
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.
Resolves #277.
Bug fixed by this PR
The following lines bound
vars.amounts[i]
to [1, BIGNUM] but notparams.leafData[i].amount
.v2-periphery/test/fork/merkle-streamer/MerkleStreamerLL.t.sol
Lines 76 to 78 in a0712ca
That means if
params.leafData[i].amount
is 0,vars.aggregateAmount
would be 0 butvars.amounts[i]
would be non-zero.This would lead to the token dealing with 0 amount but
.claim()
would be called with non-zero value ofvars.amounts
causingERC20: transfer amount exceeds balance
since there would be 0 balance in merkleStreamerLL contract.v2-periphery/test/fork/merkle-streamer/MerkleStreamerLL.t.sol
Line 124 in a0712ca
v2-periphery/test/fork/merkle-streamer/MerkleStreamerLL.t.sol
Lines 153 to 158 in a0712ca