-
Notifications
You must be signed in to change notification settings - Fork 83
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
Vendor Stable Pool V2 Artifacts #371
Conversation
If you just want to "pretend" to use a result to satisfy the type checker you can do this: let _ = compute_result_i_dont_care_about(); If you are interested in the result you have to give it a name: let some_name = compute_result_i_care_about(); |
Thank @MartinquaXD for taking a look at this! Now that you're interested I can provide a bit more context on this (auto generated file):
More specifically: we see this in the new factory contract: Which doesn't appear to be part of the other one. In both we have this: From what I can tell this event |
I didn't see that this came from generated code. 🤦♂️ |
My hunch appears to be correct: This event doesn't come with any values, We may need to update ethcontract to support this (cc @nlordell). I have created an issue in ethcontract-rs: cowprotocol/ethcontract-rs#796 |
It looks like this is a clippy warning, so no hard build error. We don't have to block this PR on fixing this in ethcontract (but it should be fixed eventually). // Workaround for ethcontract generated code running into this warning.
#![allow(clippy::let_unit_value)] at the very top of |
@@ -108,6 +111,48 @@ impl FactoryIndexing for BalancerV2StablePoolFactory { | |||
} | |||
} | |||
|
|||
// TODO - this probably doesn't need to be so clearly duplicated. |
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.
Ben and I talked about this. I felt this was fine for now. When there is a V3 it might be worth it to deduplicate.
Based on #368, intended to close #343 as the second step in a two step process.
This PR vendors the new versions of Stable Pool Factory and StablePool (names here are the originals with V2 on the end) as
abi_only
.Note that, we use the bytecode to deploy the contract for the e2e tests: We may want to ask balancer to supply it. However, in the meantime we don't intend on adding any e2e tests for this particular factory contract.
New one.
https://github.com/balancer-labs/balancer-v2-monorepo/blob/903d34e491a5e9c5d59dabf512c7addf1ccf9bbd/pkg/deployments/tasks/20220609-stable-pool-v2/abi/StablePoolFactory.json
Old one.
https://github.com/balancer-labs/balancer-v2-monorepo/blob/ad1442113b26ec22081c2047e2ec95355a7f12ba/pkg/deployments/tasks/20210624-stable-pool/abi/StablePoolFactory.json
TEST PLAN
Checkout main and run the orderbook: expect the warning as described in #343.
Checkout this branch and run the orderbook: Notice that there is no more warning.
Furthermore, I have validated that these pools are being included as follows:
Run the unit test:
sources::balancer_v2::pool_fetching::tests::balancer_pool_fetcher_print
with the
pair
set asand an additional print statement:
which showed that this pool
0x2d011adf89f0576c9b722c28269fcb5d50c2d179
was indeed categorized as a stable pool.