Skip to content

Commit

Permalink
updated portal fee oracle set routine for updated FOV2 contracts
Browse files Browse the repository at this point in the history
  • Loading branch information
Zodomo committed Nov 29, 2024
1 parent 74befd5 commit 7197543
Show file tree
Hide file tree
Showing 7 changed files with 128 additions and 113 deletions.
28 changes: 14 additions & 14 deletions contracts/bindings/admin.go

Large diffs are not rendered by default.

10 changes: 5 additions & 5 deletions contracts/core/.gas-snapshot
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
Admin_Test:test_pause_unpause() (gas: 32315662)
Admin_Test:test_pause_unpause_bridge() (gas: 27345415)
Admin_Test:test_pause_unpause_xcall() (gas: 32269636)
Admin_Test:test_pause_unpause_xsubmit() (gas: 32269343)
Admin_Test:test_upgrade() (gas: 36350837)
Admin_Test:test_pause_unpause() (gas: 33933914)
Admin_Test:test_pause_unpause_bridge() (gas: 28963667)
Admin_Test:test_pause_unpause_xcall() (gas: 33887888)
Admin_Test:test_pause_unpause_xsubmit() (gas: 33887595)
Admin_Test:test_upgrade() (gas: 37969089)
AllocPredeploys_Test:test_num_allocs() (gas: 1181319043)
AllocPredeploys_Test:test_predeploys() (gas: 1181300853)
AllocPredeploys_Test:test_preinstalls() (gas: 1182017269)
Expand Down
6 changes: 3 additions & 3 deletions contracts/core/script/admin/Admin.s.sol
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import { Script } from "forge-std/Script.sol";
import { BridgeL1PostUpgradeTest } from "./BridgeL1PostUpgradeTest.sol";
import { BridgeNativePostUpgradeTest } from "./BridgeNativePostUpgradeTest.sol";
import { StakingPostUpgradeTest } from "./StakingPostUpgradeTest.sol";
// import { FeeOraclePostUpdateTest } from "./FeeOraclePostUpdateTest.sol";
import { FeeOracleV2PostUpdateTest } from "./FeeOracleV2PostUpdateTest.sol";

/**
* @title Admin
Expand Down Expand Up @@ -389,7 +389,7 @@ contract Admin is Script {
* @param portal The address of the OmniPortal contract.
* @param newFeeOracle The address of the new FeeOracleV2 contract.
*/
function setPortalFeeOracle(address admin, address portal, address newFeeOracle) public {
function setPortalFeeOracleV2(address admin, address portal, address newFeeOracle) public {
address oldFeeOracle = OmniPortal(portal).feeOracle();
require(oldFeeOracle != newFeeOracle, "new fee oracle required");

Expand All @@ -401,7 +401,7 @@ contract Admin is Script {
require(FeeOracleV2(newFeeOracle).manager() != address(0), "fee oracle not initialized");
require(FeeOracleV2(newFeeOracle).version() == 2, "fee oracle not FeeOracleV2");

// new FeeOraclePostUpdateTest().run(newFeeOracle);
new FeeOracleV2PostUpdateTest().run(newFeeOracle);
}

/**
Expand Down
80 changes: 0 additions & 80 deletions contracts/core/script/admin/FeeOraclePostUpdateTest.sol

This file was deleted.

95 changes: 95 additions & 0 deletions contracts/core/script/admin/FeeOracleV2PostUpdateTest.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
// SPDX-License-Identifier: GPL-3.0-only
pragma solidity 0.8.24;

import { FeeOracleV2 } from "src/xchain/FeeOracleV2.sol";
import { IFeeOracleV2 } from "src/interfaces/IFeeOracleV2.sol";
import { Test } from "forge-std/Test.sol";
import { VmSafe } from "forge-std/Vm.sol";
import { EnumerableSetLib } from "solady/src/utils/EnumerableSetLib.sol";

contract FeeOracleV2PostUpdateTest is Test {
using EnumerableSetLib for EnumerableSetLib.Uint256Set;

FeeOracleV2 feeOracle;

EnumerableSetLib.Uint256Set testnetChainIds;
EnumerableSetLib.Uint256Set mainnetChainIds;

// Make sure these match the gas token IDs in `lib/contracts/feeoraclev2/gastokens.go`
uint16 constant OMNI = 1;
uint16 constant ETH = 2;

enum Network {
Invalid,
Testnet,
Mainnet
}

function run(address oracle) public {
(VmSafe.CallerMode mode,,) = vm.readCallers();
require(mode == VmSafe.CallerMode.None, "no broadcast");

Network network = _setup(oracle);
_testFeeParams(network);
_testDataCostParams(network);
_testToNativeRateParams();
}

function _setup(address oracle) internal returns (Network) {
feeOracle = FeeOracleV2(oracle);

// Testnet chain ids
testnetChainIds.add(164); // Omni Omega
testnetChainIds.add(17_000); // Ethereum Holesky
testnetChainIds.add(84_532); // Base Sepolia
testnetChainIds.add(421_614); // Arbitrum Sepolia
testnetChainIds.add(11_155_420); // Optimism Sepolia

// Mainnet chain ids
mainnetChainIds.add(1); // Ethereum Mainnet
mainnetChainIds.add(10); // Optimism Mainnet
mainnetChainIds.add(166); // Omni Mainnet
mainnetChainIds.add(8453); // Base Mainnet
mainnetChainIds.add(42_161); // Arbitrum Mainnet

if (testnetChainIds.contains(block.chainid)) {
return Network.Testnet;
} else if (mainnetChainIds.contains(block.chainid)) {
return Network.Mainnet;
} else {
revert("invalid network");
}
}

function _testFeeParams(Network network) internal view {
uint256[] memory chainIds = network == Network.Testnet ? testnetChainIds.values() : mainnetChainIds.values();
for (uint256 i; i < chainIds.length; i++) {
uint64 chainId = uint64(chainIds[i]);
IFeeOracleV2.FeeParams memory feeParams = feeOracle.feeParams(chainId);
assertGt(feeParams.gasToken, 0, "gas token must be set");
assertGt(feeParams.chainId, 0, "chain id must be set");
assertGt(feeParams.gasPrice, 0, "gas price must be set");
assertGt(feeParams.dataCostId, 0, "data cost id must be set");
}
}

function _testDataCostParams(Network network) internal view {
uint256[] memory chainIds = network == Network.Testnet ? testnetChainIds.values() : mainnetChainIds.values();
for (uint256 i; i < chainIds.length; i++) {
uint64 chainId = uint64(chainIds[i]);
IFeeOracleV2.DataCostParams memory dataCostParams = feeOracle.dataCostParams(chainId);
assertGt(dataCostParams.gasToken, 0, "gas token must be set");
assertGt(dataCostParams.id, 0, "data cost id must be set");
assertGt(dataCostParams.gasPrice, 0, "gas price must be set");
assertGt(dataCostParams.gasPerByte, 0, "gas per byte must be set");
}
}

function _testToNativeRateParams() internal view {
uint256 omniNativeRate = feeOracle.tokenToNativeRate(uint16(OMNI));
uint256 ethNativeRate = feeOracle.tokenToNativeRate(uint16(ETH));

assertGt(omniNativeRate, 0, "omni native rate must be set");
assertGt(ethNativeRate, 0, "eth native rate must be set");
}
}
12 changes: 6 additions & 6 deletions e2e/app/admin/upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -105,9 +105,9 @@ func UpgradePortalRegistry(ctx context.Context, def app.Definition, cfg Config)
return upgradePortalRegistry(ctx, s, c)
}

// UpgradePortalFeeOracle upgrades the OmniPortal's FeeOracle to the FeeOracleV2 contract.
func UpgradePortalFeeOracle(ctx context.Context, def app.Definition, cfg Config) error {
return setup(def, cfg).run(ctx, upgradePortalFeeOracle)
// SetPortalFeeOracleV2 upgrades the OmniPortal's FeeOracle to the FeeOracleV2 contract.
func SetPortalFeeOracleV2(ctx context.Context, def app.Definition, cfg Config) error {
return setup(def, cfg).run(ctx, setPortalFeeOracleV2)
}

func upgradePortal(ctx context.Context, s shared, c chain) error {
Expand Down Expand Up @@ -319,13 +319,13 @@ func upgradePortalRegistry(ctx context.Context, s shared, c chain) error {
return nil
}

func upgradePortalFeeOracle(ctx context.Context, s shared, c chain) error {
func setPortalFeeOracleV2(ctx context.Context, s shared, c chain) error {
addrs, err := contracts.GetAddresses(ctx, s.testnet.Network)
if err != nil {
return errors.Wrap(err, "get addresses")
}

calldata, err := adminABI.Pack("upgradePortalFeeOracle", s.manager, addrs.Portal, addrs.FeeOracleV2)
calldata, err := adminABI.Pack("setPortalFeeOracleV2", s.manager, addrs.Portal, addrs.FeeOracleV2)
if err != nil {
return errors.Wrap(err, "pack calldata")
}
Expand All @@ -335,7 +335,7 @@ func upgradePortalFeeOracle(ctx context.Context, s shared, c chain) error {
return errors.Wrap(err, "run forge", "out", out)
}

log.Info(ctx, "OmniPortal's FeeOracle upgraded ✅", "chain", c.Name, "addr", addrs.FeeOracleV2, "out", out)
log.Info(ctx, "OmniPortal's FeeOracle upgraded to V2 ✅", "chain", c.Name, "addr", addrs.FeeOracleV2, "out", out)

return nil
}
10 changes: 5 additions & 5 deletions e2e/cmd/admin.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ func newAdminCmd(def *app.Definition) *cobra.Command {
newUpgradeBridgeNativeCmd(def, &cfg),
newUpgradeBridgeL1(def, &cfg),
newUpgradePortalRegistryCmd(def, &cfg),
newUpgradePortalFeeOracleCmd(def, &cfg),
newSetPortalFeeOracleV2Cmd(def, &cfg),
newAllowValidatorsCmd(def, &cfg),
newPlanUpgradeCmd(def, &cfg),
newAdminTestCmd(def),
Expand Down Expand Up @@ -195,12 +195,12 @@ func newUpgradePortalRegistryCmd(def *app.Definition, cfg *admin.Config) *cobra.
return cmd
}

func newUpgradePortalFeeOracleCmd(def *app.Definition, cfg *admin.Config) *cobra.Command {
func newSetPortalFeeOracleV2Cmd(def *app.Definition, cfg *admin.Config) *cobra.Command {
cmd := &cobra.Command{
Use: "upgrade-portal-fee-oracle",
Short: "Upgrade OmniPortal's FeeOracle to the FeeOracleV2 contract.",
Use: "set-portal-fee-oracle-v2",
Short: "Sets OmniPortal's FeeOracle to the FeeOracleV2 contract.",
RunE: func(cmd *cobra.Command, _ []string) error {
return admin.UpgradePortalFeeOracle(cmd.Context(), *def, *cfg)
return admin.SetPortalFeeOracleV2(cmd.Context(), *def, *cfg)
},
}

Expand Down

0 comments on commit 7197543

Please sign in to comment.