Skip to content

Commit

Permalink
test: Advancer contract test
Browse files Browse the repository at this point in the history
  • Loading branch information
0xpatrickdev committed Nov 20, 2024
1 parent 9c406ad commit 2e699e7
Show file tree
Hide file tree
Showing 3 changed files with 97 additions and 26 deletions.
4 changes: 2 additions & 2 deletions packages/fast-usdc/src/fast-usdc.contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ export const contract = async (zcf, privateArgs, zone, tools) => {
* @param {{ USDC: Amount<'nat'>}} amounts
*/
testBorrow(amounts) {
console.log('🚧🚧 UNTIL: borrow is integrated 🚧🚧', amounts);
console.log('🚧🚧 UNTIL: borrow is integrated (#10388) 🚧🚧', amounts);
const { zcfSeat: tmpAssetManagerSeat } = zcf.makeEmptySeatKit();
// eslint-disable-next-line no-use-before-define
poolKit.borrower.borrow(tmpAssetManagerSeat, amounts);
Expand All @@ -132,7 +132,7 @@ export const contract = async (zcf, privateArgs, zone, tools) => {
* @returns {Promise<AmountKeywordRecord>}
*/
async testRepay(amounts, payments) {
console.log('🚧🚧 UNTIL: repay is integrated 🚧🚧', amounts);
console.log('🚧🚧 UNTIL: repay is integrated (#10388) 🚧🚧', amounts);
const { zcfSeat: tmpAssetManagerSeat } = zcf.makeEmptySeatKit();
await depositToSeat(
zcf,
Expand Down
111 changes: 91 additions & 20 deletions packages/fast-usdc/test/fast-usdc.contract.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import { commonSetup } from './supports.js';
import type { FastUsdcTerms } from '../src/fast-usdc.contract.js';
import { makeFeeTools } from '../src/utils/fees.js';
import type { PoolMetrics } from '../src/types.js';
import { addressTools } from '../src/utils/address.js';

const dirname = path.dirname(new URL(import.meta.url).pathname);

Expand Down Expand Up @@ -52,6 +53,14 @@ const startContract = async (
const { zoe, bundleAndInstall } = await setUpZoeForTest({
setJig: jig => {
jig.chainHub.registerChain('osmosis', fetchedChainInfo.osmosis);
jig.chainHub.registerChain('agoric', fetchedChainInfo.agoric);
// TODO #10445 register noble<>agoric and noble<>osmosis instead
// for PFM routing. also will need to call `registerAsset`
jig.chainHub.registerConnection(
fetchedChainInfo.agoric.chainId,
fetchedChainInfo.osmosis.chainId,
fetchedChainInfo.agoric.connections['osmosis-1'],
);
},
});
const installation: Installation<StartFn> =
Expand All @@ -69,26 +78,6 @@ const startContract = async (
return { ...startKit, zoe };
};

// FIXME this makeTestPushInvitation forces evidence, which triggers advancing,
// which doesn't yet work
test.skip('advancing', async t => {
const common = await commonSetup(t);

const { publicFacet, zoe } = await startContract(common);

const e1 = await E(MockCctpTxEvidences.AGORIC_PLUS_DYDX)();

const inv = await E(publicFacet).makeTestPushInvitation(e1);
// the invitation maker itself pushes the evidence

// the offer is still safe to make
const seat = await E(zoe).offer(inv);
t.is(
await E(seat).getOfferResult(),
'inert; nothing should be expected from this offer',
);
});

test('oracle operators have closely-held rights to submit evidence of CCTP transactions', async t => {
const common = await commonSetup(t);
const { creatorFacet, zoe } = await startContract(common);
Expand Down Expand Up @@ -551,3 +540,85 @@ test('baggage', async t => {
const tree = inspectMapStore(contractBaggage);
t.snapshot(tree, 'contract baggage after start');
});

test('advancing happy path', async t => {
const common = await commonSetup(t);
const {
brands: { usdc },
commonPrivateArgs,
utils: { inspectLocalBridge, inspectBankBridge, transmitTransferAck },
} = common;

const { instance, publicFacet, zoe } = await startContract(common);
const terms = await E(zoe).getTerms(instance);
const { subscriber } = E.get(
E.get(E(publicFacet).getPublicTopics()).poolMetrics,
);
const feeTools = makeFeeTools(commonPrivateArgs.feeConfig);
const { makeLP, purseOf } = makeLpTools(t, common, {
publicFacet,
subscriber,
terms,
zoe,
});

const evidence = await E(MockCctpTxEvidences.AGORIC_PLUS_OSMO)();

// seed pool with funds
const alice = makeLP('Alice', purseOf(evidence.tx.amount));
await alice.deposit(evidence.tx.amount);

// the invitation maker itself pushes the evidence
const inv = await E(publicFacet).makeTestPushInvitation(evidence);
const seat = await E(zoe).offer(inv);
t.is(
await E(seat).getOfferResult(),
'inert; nothing should be expected from this offer',
);

// calculate advance net of fees
const expectedAdvance = feeTools.calculateAdvance(
usdc.make(evidence.tx.amount),
);
t.log('Expecting to observe advance of', expectedAdvance);

await eventLoopIteration(); // let Advancer do work

// advance sent from PoolSeat to PoolAccount
t.deepEqual(inspectBankBridge().at(-1), {
amount: String(expectedAdvance.value),
denom: 'ibc/usdconagoric',
recipient: 'agoric1fakeLCAAddress',
type: 'VBANK_GIVE',
});

// ibc transfer sent over localChain bridge
const localBridgeMsg = inspectLocalBridge().at(-1);
const ibcTransferMsg = localBridgeMsg.messages[0];
t.is(ibcTransferMsg['@type'], '/ibc.applications.transfer.v1.MsgTransfer');

const expectedReceiver = addressTools.getQueryParams(
evidence.aux.recipientAddress,
).EUD;
t.is(ibcTransferMsg.receiver, expectedReceiver, 'sent to correct address');
t.deepEqual(ibcTransferMsg.token, {
amount: String(expectedAdvance.value),
denom: 'ibc/usdconagoric',
});

// TODO #10445 expect PFM memo
t.is(ibcTransferMsg.memo, '', 'TODO expecting PFM memo');

// TODO #10445 expect routing through noble, not osmosis
t.is(
ibcTransferMsg.sourceChannel,
fetchedChainInfo.agoric.connections['osmosis-1'].transferChannel.channelId,
'TODO expecting routing through Noble',
);

await transmitTransferAck();
// 'Advance transfer fulfilled' observed in logs instead of ending on 'No
// match yet. Save the pattern for later.'
// Consider supplying a `log: LogFn` to Advancer we can access in testing to
// verify the message.
});
8 changes: 4 additions & 4 deletions packages/fast-usdc/test/supports.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ export const commonSetup = async (t: ExecutionContext<any>) => {
onToBridge: obj => bankBridgeMessages.push(obj),
});
await E(bankManager).addAsset(
'uusdc',
'ibc/usdconagoric',
'USDC',
'USD Circle Stablecoin',
usdc.issuerKit,
Expand All @@ -64,13 +64,13 @@ export const commonSetup = async (t: ExecutionContext<any>) => {
// TODO https://github.com/Agoric/agoric-sdk/issues/9966
await makeWellKnownSpaces(agoricNamesAdmin, t.log, ['vbankAsset']);
await E(E(agoricNamesAdmin).lookupAdmin('vbankAsset')).update(
'uusdc',
'ibc/usdconagoric',
/** @type {AssetInfo} */ harden({
brand: usdc.brand,
issuer: usdc.issuer,
issuerName: 'IST',
issuerName: 'USDC',
denom: 'uusdc',
proposedName: 'IST',
proposedName: 'USDC',
displayInfo: { IOU: true },
}),
);
Expand Down

0 comments on commit 2e699e7

Please sign in to comment.