-
Notifications
You must be signed in to change notification settings - Fork 217
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
test: fusdc multichain #10618
test: fusdc multichain #10618
Conversation
Deploying agoric-sdk with Cloudflare Pages
|
5bc8a9b
to
db72909
Compare
db72909
to
cfd26c8
Compare
Base branch is changed to master. Please re-run the integration tests by adding 'force:integration' label. |
cfd26c8
to
af06ac9
Compare
e3d94c3
to
bf7b154
Compare
ad78498
to
a6faf6b
Compare
21d5049
to
287e5be
Compare
1c5abba
to
ec38514
Compare
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 gotta run.
I rushed this review a little, so you may want more eyes. But as you say, only test code, so low risk.
harden(oracleMnemonics); | ||
|
||
export const makeFeedPolicy = (nobleAgoricChannelId: IBCChannelID) => { | ||
return JSON.stringify({ |
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.
can the caller JSON.stringify
it? It would be nice to @returns { FeedPolicy }
.
await startContract(contractName, contractBuilder, { | ||
oracle: keys(oracleMnemonics).map(n => `${n}:${wallets[n]}`), | ||
usdcDenom: usdcDenom, | ||
feedPolicy: makeFeedPolicy(nobleAgoricChannelId), |
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.
startContract
wants a string for feedPolicy
? ah... it's just taking flags()
. Let's stringify
here.
Arbitrum: { | ||
cctpTokenMessengerAddress: '0x19330d10D9Cc8751218eaf51E8885D058642E08A', | ||
chainId: 42161, | ||
confirmations: 2, | ||
nobleContractAddress: '0x19330d10D9Cc8751218eaf51E8885D058642E08A', |
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.
are those arbitrary values chosen by us?
Or is there an external design constraint here? If so, let's please cite it.
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.
For context: https://developers.circle.com/stablecoins/evm-smart-contracts
That's for cctpTokenMessengerAddress
, but nobleContractAddress
could be the same or different. From codecider:
nobleContractAddress: Hex;
- The address of Noble's wrapper contract that users interact with via NobleExpress
- msg.sender of DepositAndBurn must be this address to prevent users from calling replaceDepositForBurn
I'm not sure where exactly we'd find the noble wrapper contract addresses (if they exist). Might need to ask those folks directly.
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.
yes, let's add that pointer, @samsiegart
I wonder how to track down the date the contract was deployed. A date is always a nice thing to have in a citation.
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.
See #10679. Feel free to provide suggestions for a better name in PR or offline
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.
on 2nd thought, to answer my own question, yes, we did choose this address: this is a test config. If we want to re-deploy the contract at a different address in our test env, we don't have to coordinate with anybody else.
provisionSmartWallet, | ||
startContract, | ||
} = common; | ||
deleteTestKeys(accounts).catch(); |
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 want/need this to finish before setupTestKeys(...)
, right?
deleteTestKeys(accounts).catch(); | |
await deleteTestKeys(accounts).catch(); |
we don't have lint for dangling promises in multichain-testing?
deleteTestKeys(accounts).catch(); | ||
const wallets = await setupTestKeys(accounts, values(oracleMnemonics)); | ||
|
||
// provision oracle wallets first so invitation deposits don't fail |
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/we should check that product is OK with this constraint.
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.
confirmed
multichain-testing/tools/random.ts
Outdated
export function makeRandomDigits(digits = 2n) { | ||
if (digits < 1n) throw new Error('digits must be positive'); | ||
const maxValue = Math.pow(10, Number(digits)) - 1; | ||
const num = Math.floor(Math.random() * (maxValue + 1)); |
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.
Math.random
is ambient authority. There's only 1 caller of this function. Please move it to the test script or inline it so that we're not exporting functions that close over ambient authority.
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 seemed like too much to inline - I made randomNumber
a parameter and put the Math.random()
call in the test file.
invitationSpec: { | ||
source: 'purse', | ||
instance, | ||
description: 'oracle operator invitation', // TODO export/import INVITATION_MAKERS_DESC |
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.
yeah; we should have a helper in @agoric/fast-usdc/tools/
for building this whole offer spec.
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.
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.
Created #10677
retryUntilCondition( | ||
() => vstorageClient.queryData(`published.wallet.${addr}.current`), | ||
({ offerToUsedInvitation }) => { | ||
return offerToUsedInvitation[0][0] === `${name}-accept`; |
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.
can we be sure this is the 1st offer in that table?
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.
In this test, yes, because we are using fresh mnemonics
// register forwarding address on noble | ||
const txRes = nobleTools.registerForwardingAcct( | ||
nobleAgoricChannelId, | ||
recipientAddress, | ||
); |
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.
hm. is this step in the diagrams in our current spec?
IOU a check.
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 am a little hazy - but iirc the UI's backend service and/or OCW does this step
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.
ah yes... it's there. arrow 4.
sequenceDiagram
title Fast USDC Transaction Process
participant NEA as Noble Express app<br/>[Browser]
participant NC as Noble Chain<br/>[Noble]
rect rgb(240, 248, 255)
NEA-->>NC: Register NFA
end
|
||
const mintAmount = 800_000n; | ||
|
||
// TODO export CctpTxEvidence type |
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.
yikes!
This is a good test of the package, isn't it?
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.
+1. I put exporting types as a req for: #10677
287e5be
to
475e720
Compare
ec38514
to
6dd673e
Compare
Base branch is changed to master. Please re-run the integration tests by adding 'force:integration' label. |
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.
So cool to see this working!
Arbitrum: { | ||
cctpTokenMessengerAddress: '0x19330d10D9Cc8751218eaf51E8885D058642E08A', | ||
chainId: 42161, | ||
confirmations: 2, | ||
nobleContractAddress: '0x19330d10D9Cc8751218eaf51E8885D058642E08A', |
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.
For context: https://developers.circle.com/stablecoins/evm-smart-contracts
That's for cctpTokenMessengerAddress
, but nobleContractAddress
could be the same or different. From codecider:
nobleContractAddress: Hex;
- The address of Noble's wrapper contract that users interact with via NobleExpress
- msg.sender of DepositAndBurn must be this address to prevent users from calling replaceDepositForBurn
I'm not sure where exactly we'd find the noble wrapper contract addresses (if they exist). Might need to ask those folks directly.
() => vstorageClient.queryData(`published.${contractName}.poolMetrics`), | ||
({ shareWorth }) => | ||
!isGTE(currShareWorth.numerator, shareWorth.numerator), | ||
'share worth numerator increases from deposit', |
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 suppose this is reasonable for testing it worked. It would also be good to verify that the pool shares were received, but I think we can do that implicitly in the todo withdrawal test below.
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.
doOffer
checks that numWantsSatisfied
is 1, so we can have confidence the pool shares were received.
No harm in explicitly checking in the test though, so I fixed up to include that. Also closed out the test.todo('lp withdraws')
6dd673e
to
6a891c3
Compare
ba19ac0
to
4ed677f
Compare
f081d9f
to
b9c275c
Compare
4ed677f
to
d99ae45
Compare
ba4fce5
to
d369f08
Compare
26486cf
to
e860814
Compare
d369f08
to
6091992
Compare
- include `chainInfo` and `assetInfo` as common builder options for orchestration contracts
- in the testing environment, we might see multiple USDC entries in `vbankAsset`. This change ensures the `byName` record contains the values needed for the test, reliant on the consistent ordering currently present in `vbankAsset` entries
- get rid of dangling promise and await something we actually rely on
e860814
to
a56f407
Compare
closes: #10597
Description
Adds
multichain-testing
test for FUSDC happy path. Includes:mockCctpTxEvidence
submissionsEnsures advance appears in EUD account, Liquidity Pool is repaid, and corresponding TxStatus updates are recorded in vstorage.
Security Considerations
None, test code.
Scaling Considerations
None really. For CI load, the test takes about 32 seconds after setup.
Documentation Considerations
None
Testing Considerations
PR only includes tests and test support.
Upgrade Considerations
None