-
Notifications
You must be signed in to change notification settings - Fork 334
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
Implement bep3 evm native conversion logic #1848
Conversation
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.
looks good
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.
Really good test cases covering dust, too small of balance, and insuffient balances on both the sdk and erc20 sides.
Let's just add some defensive testing to ensure all four bep3 assets are covered. In addition to using a map for denom lookup, removing unused code, and making extracted helpers private (or adding unit tests for them).
Looks great otherwise. Refactoring implementation is optional -- just added my thoughts there on readability & complexity.
8ef7925
to
a401485
Compare
) | ||
|
||
var ( | ||
bep3Denoms = map[string]bool{ |
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.
Nice, normally I'd say use a map[string]struct{}
, but with 4 items the benefited clarify and simpler logic in isBep3Asset
is nice 👍
return quotient | ||
} | ||
|
||
// bep3ERC20AmountToCoinMintAndERC20LockAmount converts 18 decimals erc20 bep3 |
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.
appreciate the doc comments 👍
} | ||
|
||
func (suite *Bep3ConversionTestSuite) TestConvertCoinToERC20_Bep3() { | ||
for _, denom := range bep3Denoms { |
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.
This actually makes the tests quite a bit easier to read -- easy to see that all denoms are tested and much more resistant to refactorings that could drop a denom, accidentally rename one, break the check some other unique way, etc
amountToLock := amount.BigInt() | ||
amountToMint := amount.BigInt() | ||
|
||
if isBep3Asset(pair.Denom) { |
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 see what you mean now, and this is a nice approach showing there is are two paths in the logic: One for bep3 assets, and one for not. Also, makes it clear that the amounts are only modified in the bep3 case, but also keeps the dirty details down a level in a function call.
* Implement bep3 evm native conversion logic * Update changelog * Fix indentation * Add bep3 conversion keeper tests * make DefaultBEP3ConversionDenoms private * refactor bep3 conversion * update bep3 tests to cover all bep3 assets * minor refactor (cherry picked from commit 3afb656)
* Implement bep3 evm native conversion logic * Update changelog * Fix indentation * Add bep3 conversion keeper tests * make DefaultBEP3ConversionDenoms private * refactor bep3 conversion * update bep3 tests to cover all bep3 assets * minor refactor (cherry picked from commit 3afb656) Co-authored-by: Draco <draco@dracoli.com>
Description
Replaces #1834
Checklist