From 1d5cb990533dd737923e17c9537fe3963b06d5c5 Mon Sep 17 00:00:00 2001 From: Chris Hibbert Date: Wed, 27 Nov 2024 10:46:57 -0800 Subject: [PATCH] chore: upgrade v8, the priceAuthorityRegistry (#10418) closes: #10401 ## Description Upgrade the priceAuthorityRegistry ### Security Considerations N/A ### Scaling Considerations N/A ### Documentation Considerations Does need to be mentioned in the upgrade description. ### Testing Considerations As issue #10401 directs, we verify that `quoteWanted()` continues to work. Existing tests in `z:acceptance` verify that prices continue to be received by vaults. ### Upgrade Considerations This should be included in upgrade 19. --- .../proposals/n:upgrade-next/registry.test.js | 20 +++++++ golang/cosmos/app/upgrade.go | 3 + .../scripts/vats/upgrade-paRegistry.js | 21 +++++++ .../proposals/upgrade-paRegistry-proposal.js | 57 +++++++++++++++++++ 4 files changed, 101 insertions(+) create mode 100644 a3p-integration/proposals/n:upgrade-next/registry.test.js create mode 100644 packages/builders/scripts/vats/upgrade-paRegistry.js create mode 100644 packages/vats/src/proposals/upgrade-paRegistry-proposal.js diff --git a/a3p-integration/proposals/n:upgrade-next/registry.test.js b/a3p-integration/proposals/n:upgrade-next/registry.test.js new file mode 100644 index 00000000000..a0d4adb84ed --- /dev/null +++ b/a3p-integration/proposals/n:upgrade-next/registry.test.js @@ -0,0 +1,20 @@ +// @ts-check +import test from 'ava'; +import '@endo/init/debug.js'; + +import { + getDetailsMatchingVats, + getIncarnation, +} from '@agoric/synthetic-chain'; + +/** + * @file + * A test of upgrading vat-priceAuthority, which is planned to ship in Upgrade 9 + */ + +test('priceAuthorityRegistry upgrade', async t => { + t.is(await getIncarnation('priceAuthority'), 1); + + const priceAuthorityVats = await getDetailsMatchingVats('priceAuthority'); + t.is(priceAuthorityVats.length, 1); +}); diff --git a/golang/cosmos/app/upgrade.go b/golang/cosmos/app/upgrade.go index 818c1fd63ce..1396a18879b 100644 --- a/golang/cosmos/app/upgrade.go +++ b/golang/cosmos/app/upgrade.go @@ -219,6 +219,9 @@ func unreleasedUpgradeHandler(app *GaiaApp, targetUpgrade string) func(sdk.Conte vm.CoreProposalStepForModules( "@agoric/builders/scripts/inter-protocol/replace-feeDistributor.js", ), + vm.CoreProposalStepForModules( + "@agoric/builders/scripts/vats/upgrade-paRegistry.js", + ), ) } diff --git a/packages/builders/scripts/vats/upgrade-paRegistry.js b/packages/builders/scripts/vats/upgrade-paRegistry.js new file mode 100644 index 00000000000..9f353134a77 --- /dev/null +++ b/packages/builders/scripts/vats/upgrade-paRegistry.js @@ -0,0 +1,21 @@ +import { makeHelpers } from '@agoric/deploy-script-support'; + +/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */ +export const defaultProposalBuilder = async ({ publishRef, install }) => + harden({ + sourceSpec: '@agoric/vats/src/proposals/upgrade-paRegistry-proposal.js', + getManifestCall: [ + 'getManifestForUpgradingRegistry', + { + registryRef: publishRef( + install('@agoric/vats/src/vat-priceAuthority.js'), + ), + }, + ], + }); + +/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */ +export default async (homeP, endowments) => { + const { writeCoreEval } = await makeHelpers(homeP, endowments); + await writeCoreEval('upgrade-paRegistry', defaultProposalBuilder); +}; diff --git a/packages/vats/src/proposals/upgrade-paRegistry-proposal.js b/packages/vats/src/proposals/upgrade-paRegistry-proposal.js new file mode 100644 index 00000000000..81387d7193b --- /dev/null +++ b/packages/vats/src/proposals/upgrade-paRegistry-proposal.js @@ -0,0 +1,57 @@ +// @ts-check +import { E } from '@endo/far'; +import { AmountMath } from '@agoric/ertp'; +import { Stable } from '@agoric/internal/src/tokens.js'; + +/** + * @param {BootstrapPowers} powers + * @param {object} options + * @param {{ registryRef: VatSourceRef }} options.options + */ +export const upgradePriceAuthorityRegistry = async ( + { + consume: { vatAdminSvc, vatStore, priceAuthority, agoricNames }, + brand: { + consume: { [Stable.symbol]: stableBrandP }, + }, + }, + options, +) => { + const { registryRef } = options.options; + + assert(registryRef.bundleID); + console.log(`PriceAuthorityRegistry BUNDLE ID: `, registryRef.bundleID); + + const [{ adminNode }, stableBrand, atomBrand, bundleCap] = await Promise.all([ + E(vatStore).get('priceAuthority'), + stableBrandP, + E(agoricNames).lookup('brand', 'ATOM'), + E(vatAdminSvc).getBundleCap(registryRef.bundleID), + ]); + + await E(adminNode).upgrade(bundleCap, {}); + + const oneATOM = AmountMath.make(atomBrand, 1_000_000n); + const quoteAtom = await E(priceAuthority).quoteGiven(oneATOM, stableBrand); + console.log('paRegistry quote', quoteAtom); + + assert(quoteAtom.quoteAmount.value, 'insist on getting a quote'); +}; + +const par = 'paRegistry'; +export const getManifestForUpgradingRegistry = (_powers, { registryRef }) => ({ + manifest: { + [upgradePriceAuthorityRegistry.name]: { + consume: { + agoricNames: par, + vatAdminSvc: par, + vatStore: par, + priceAuthority: par, + }, + brand: { consume: { [Stable.symbol]: par } }, + }, + }, + options: { + registryRef, + }, +});