Skip to content
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

feat: core deploy apply admin proxy ownership fixes #4767

Merged
merged 36 commits into from
Nov 8, 2024
Merged
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
c675dbb
feat(sdk): updated the RouterConfigSchema to have an optional proxyAd…
xeno097 Oct 21, 2024
b978591
refactor(sdk): defined the DeployedOwnableConfig and DeployedOwnableS…
xeno097 Oct 21, 2024
747b008
feat(sdk): updated the EvmWarpReader to add a fetchAdminProxyData met…
xeno097 Oct 21, 2024
85843da
feat(sdk): added the updateProxyAdminOwnershipTxs method to the EvmE…
xeno097 Oct 21, 2024
a55dc01
feat(cli): implemented the setExistingProxyAdmin to promt users to us…
xeno097 Oct 21, 2024
e8e9fc0
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 21, 2024
b192810
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 22, 2024
50d2047
docs(changeset): Add optional proxy admin reuse in warp route deploym…
xeno097 Oct 22, 2024
552bbb5
chore: paul pr review suggestion
xeno097 Oct 22, 2024
8082d17
fix(sdk): fixed methdo cann for fetchProxyAdminConfig
xeno097 Oct 22, 2024
cf5f0aa
feat(cli): added proxy admin and ica router ownership configurability…
xeno097 Oct 23, 2024
9440e50
feat(sdk): updated the EvmCoreModule.deploy method to check if the co…
xeno097 Oct 23, 2024
a8f4683
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 23, 2024
62c2067
chore: lee pr review changes + e2e test fix for warp route apply
xeno097 Oct 24, 2024
a03e1d0
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 24, 2024
c59ad8b
fix(sdk): fixed deriveTokenMetadata return value to exlcude fields no…
xeno097 Oct 24, 2024
7fc834d
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 24, 2024
7c5d84d
Merge branch 'xeno/warp-deploy-apply-ownership-fixes' of github.com:h…
xeno097 Oct 24, 2024
e396abc
feat(sdk): updated the EvmCoreReader to fetch the admin proxy data fo…
xeno097 Oct 24, 2024
cca3416
refactor(sdk): implemented the proxyAdminOwnershipUpdateTxs to dedup …
xeno097 Oct 25, 2024
1c8c682
test(cli): implemented testing utils for core commands testing
xeno097 Oct 25, 2024
3623d06
refactor(sdk,infra): remvoed duplicated impls of randomAddress
xeno097 Oct 25, 2024
86178c9
test(cli): updated the test e2e script to also run a anvil 1 chain on…
xeno097 Oct 25, 2024
cdadfe4
test(cli): added e2e tests for the hyperlane core commands
xeno097 Oct 25, 2024
16f9b46
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 25, 2024
7c48117
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Oct 25, 2024
300af54
Merge branch 'xeno/warp-deploy-apply-ownership-fixes' of github.com:h…
xeno097 Oct 25, 2024
46c1dfb
refactor(cli): removed ica router proxy admin setting from core init …
xeno097 Oct 25, 2024
d58f6a7
docs(changeset): Add support for updating the mailbox proxy admin owner
xeno097 Oct 25, 2024
4a7798d
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Nov 1, 2024
1e7c304
chore: fix main merge dup code
xeno097 Nov 1, 2024
872cb39
chore: lee pr changes
xeno097 Nov 1, 2024
f204163
test: maybe fix e2e test issues
xeno097 Nov 2, 2024
30cd02e
feat(sdk,cli): added logic to update proxy admin contract + test
xeno097 Nov 4, 2024
7798c00
fix: maybe fix e2e test part 3
xeno097 Nov 4, 2024
52936e1
Merge branch 'main' of github.com:hyperlane-xyz/hyperlane-monorepo in…
xeno097 Nov 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
test(cli): added e2e tests for the hyperlane core commands
  • Loading branch information
xeno097 committed Oct 25, 2024
commit cdadfe44a71410911b0758a0b3fa41070d557c95
156 changes: 156 additions & 0 deletions typescript/cli/src/tests/core.e2e-test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,156 @@
import { expect } from 'chai';
import { Signer, Wallet } from 'ethers';

import {
CoreConfig,
ProtocolFeeHookConfig,
randomAddress,
} from '@hyperlane-xyz/sdk';
import { Address } from '@hyperlane-xyz/utils';

import { readYamlOrJson, writeYamlOrJson } from '../utils/files.js';

import {
hyperlaneCoreApply,
hyperlaneCoreDeploy,
readCoreConfig,
} from './commands/core.js';
import { ANVIL_KEY } from './commands/helpers.js';

const CHAIN_NAME = 'anvil1';

const EXAMPLES_PATH = './examples';
const CORE_CONFIG_PATH = `${EXAMPLES_PATH}/core-config.yaml`;

const TEMP_PATH = '/tmp'; // /temp gets removed at the end of all-test.sh
const CORE_READ_CONFIG_PATH = `${TEMP_PATH}/anvil1/core-config-read.yaml`;

const TEST_TIMEOUT = 100_000; // Long timeout since these tests can take a while
describe('hyperlane core e2e tests', async function () {
this.timeout(TEST_TIMEOUT);

let initialOwnerAddress: Address;
before(async () => {
const signer: Signer = new Wallet(ANVIL_KEY);

initialOwnerAddress = await signer.getAddress();
});

describe('core.deploy', () => {
it('should create a core deployment with the signer as the mailbox owner', async () => {
await hyperlaneCoreDeploy(CHAIN_NAME, CORE_CONFIG_PATH);

const coreConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);

expect(coreConfig.owner).to.equal(initialOwnerAddress);
expect(coreConfig.proxyAdmin?.owner).to.equal(initialOwnerAddress);
// Assuming that the ProtocolFeeHook is used for deployment
expect((coreConfig.requiredHook as ProtocolFeeHookConfig).owner).to.equal(
initialOwnerAddress,
);
});

it('should create a core deployment with the mailbox owner set to the address in the config', async () => {
const coreConfig: CoreConfig = await readYamlOrJson(CORE_CONFIG_PATH);

const newOwner = randomAddress().toLowerCase();

coreConfig.owner = newOwner;
writeYamlOrJson(CORE_READ_CONFIG_PATH, coreConfig);

// Deploy the core contracts with the updated mailbox owner
await hyperlaneCoreDeploy(CHAIN_NAME, CORE_READ_CONFIG_PATH);

// Verify that the owner has been set correctly without modifying any other owner values
const updatedConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);

expect(updatedConfig.owner.toLowerCase()).to.equal(newOwner);
expect(updatedConfig.proxyAdmin?.owner).to.equal(initialOwnerAddress);
// Assuming that the ProtocolFeeHook is used for deployment
expect(
(updatedConfig.requiredHook as ProtocolFeeHookConfig).owner,
).to.equal(initialOwnerAddress);
});

it('should create a core deployment with ProxyAdmin owner of the mailbox set to the address in the config', async () => {
const coreConfig: CoreConfig = await readYamlOrJson(CORE_CONFIG_PATH);

const newOwner = randomAddress().toLowerCase();

coreConfig.proxyAdmin = { owner: newOwner };
writeYamlOrJson(CORE_READ_CONFIG_PATH, coreConfig);

// Deploy the core contracts with the updated mailbox owner
await hyperlaneCoreDeploy(CHAIN_NAME, CORE_READ_CONFIG_PATH);

// Verify that the owner has been set correctly without modifying any other owner values
const updatedConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);

expect(updatedConfig.owner).to.equal(initialOwnerAddress);
expect(updatedConfig.proxyAdmin?.owner.toLowerCase()).to.equal(newOwner);
// Assuming that the ProtocolFeeHook is used for deployment
expect(
(updatedConfig.requiredHook as ProtocolFeeHookConfig).owner,
).to.equal(initialOwnerAddress);
});
});

describe('core.apply', () => {
it('should update the mailbox owner', async () => {
await hyperlaneCoreDeploy(CHAIN_NAME, CORE_CONFIG_PATH);
const coreConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);
expect(coreConfig.owner).to.equal(initialOwnerAddress);
const newOwner = randomAddress().toLowerCase();
coreConfig.owner = newOwner;
writeYamlOrJson(CORE_READ_CONFIG_PATH, coreConfig);
await hyperlaneCoreApply(CHAIN_NAME, CORE_READ_CONFIG_PATH);
// Verify that the owner has been set correctly without modifying any other owner values
const updatedConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);
expect(updatedConfig.owner.toLowerCase()).to.equal(newOwner);
expect(updatedConfig.proxyAdmin?.owner).to.equal(initialOwnerAddress);
// Assuming that the ProtocolFeeHook is used for deployment
expect(
(updatedConfig.requiredHook as ProtocolFeeHookConfig).owner,
).to.equal(initialOwnerAddress);
});

it('should update the ProxyAdmin owner for the mailbox', async () => {
await hyperlaneCoreDeploy(CHAIN_NAME, CORE_CONFIG_PATH);
const coreConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);
expect(coreConfig.owner).to.equal(initialOwnerAddress);
const newOwner = randomAddress().toLowerCase();
coreConfig.proxyAdmin!.owner = newOwner;
writeYamlOrJson(CORE_READ_CONFIG_PATH, coreConfig);
await hyperlaneCoreApply(CHAIN_NAME, CORE_READ_CONFIG_PATH);
// Verify that the owner has been set correctly without modifying any other owner values
const updatedConfig: CoreConfig = await readCoreConfig(
CHAIN_NAME,
CORE_READ_CONFIG_PATH,
);
expect(updatedConfig.owner).to.equal(initialOwnerAddress);
expect(updatedConfig.proxyAdmin?.owner.toLowerCase()).to.equal(newOwner);
// Assuming that the ProtocolFeeHook is used for deployment
expect(
(updatedConfig.requiredHook as ProtocolFeeHookConfig).owner,
).to.equal(initialOwnerAddress);
});
});
});