diff --git a/contracts/gateway/BridgeEscrow.sol b/contracts/gateway/BridgeEscrow.sol index 1c1d85f54..4d9c11e0d 100644 --- a/contracts/gateway/BridgeEscrow.sol +++ b/contracts/gateway/BridgeEscrow.sol @@ -36,7 +36,6 @@ contract BridgeEscrow is Initializable, GraphUpgradeable, Managed { * @param _spender Address of the spender that will be revoked */ function revokeAll(address _spender) external onlyGovernor { - IGraphToken grt = graphToken(); - grt.decreaseAllowance(_spender, grt.allowance(address(this), _spender)); + graphToken().approve(_spender, 0); } } diff --git a/contracts/gateway/GraphTokenGateway.sol b/contracts/gateway/GraphTokenGateway.sol index b239af00a..ed59b149a 100644 --- a/contracts/gateway/GraphTokenGateway.sol +++ b/contracts/gateway/GraphTokenGateway.sol @@ -21,7 +21,7 @@ abstract contract GraphTokenGateway is GraphUpgradeable, Pausable, Managed, ITok modifier onlyGovernorOrGuardian() { require( msg.sender == controller.getGovernor() || msg.sender == pauseGuardian, - "Only Governor or Guardian can call" + "Only Governor or Guardian" ); _; } diff --git a/contracts/gateway/L1GraphTokenGateway.sol b/contracts/gateway/L1GraphTokenGateway.sol index d1cbd417a..7688a5e29 100644 --- a/contracts/gateway/L1GraphTokenGateway.sol +++ b/contracts/gateway/L1GraphTokenGateway.sol @@ -143,7 +143,8 @@ contract L1GraphTokenGateway is Initializable, GraphTokenGateway, L1ArbitrumMess * @param _escrow Address of the BridgeEscrow */ function setEscrowAddress(address _escrow) external onlyGovernor { - require(_escrow != address(0) && Address.isContract(_escrow), "INVALID_ESCROW"); + require(_escrow != address(0), "INVALID_ESCROW"); + require(Address.isContract(_escrow), "MUST_BE_CONTRACT"); escrow = _escrow; emit EscrowAddressSet(_escrow); } @@ -202,8 +203,8 @@ contract L1GraphTokenGateway is Initializable, GraphTokenGateway, L1ArbitrumMess bytes calldata _data ) external payable override notPaused returns (bytes memory) { IGraphToken token = graphToken(); + require(_amount != 0, "INVALID_ZERO_AMOUNT"); require(_l1Token == address(token), "TOKEN_NOT_GRT"); - require(_amount > 0, "INVALID_ZERO_AMOUNT"); require(_to != address(0), "INVALID_DESTINATION"); // nested scopes to avoid stack too deep errors @@ -284,7 +285,7 @@ contract L1GraphTokenGateway is Initializable, GraphTokenGateway, L1ArbitrumMess * @return Base ether value required to keep retryable ticket alive * @return Additional data sent to L2 */ - function parseOutboundData(bytes memory _data) + function parseOutboundData(bytes calldata _data) private view returns ( diff --git a/contracts/governance/Governed.sol b/contracts/governance/Governed.sol index 2a87389d9..697f2fa12 100644 --- a/contracts/governance/Governed.sol +++ b/contracts/governance/Governed.sol @@ -51,15 +51,16 @@ contract Governed { * This function must called by the pending governor. */ function acceptOwnership() external { + address oldPendingGovernor = pendingGovernor; + require( - pendingGovernor != address(0) && msg.sender == pendingGovernor, + oldPendingGovernor != address(0) && msg.sender == oldPendingGovernor, "Caller must be pending governor" ); address oldGovernor = governor; - address oldPendingGovernor = pendingGovernor; - governor = pendingGovernor; + governor = oldPendingGovernor; pendingGovernor = address(0); emit NewOwnership(oldGovernor, governor); diff --git a/contracts/governance/Managed.sol b/contracts/governance/Managed.sol index ce18fb009..562028c15 100644 --- a/contracts/governance/Managed.sol +++ b/contracts/governance/Managed.sol @@ -28,6 +28,14 @@ contract Managed { mapping(bytes32 => address) private addressCache; uint256[10] private __gap; + // Immutables + bytes32 private immutable CURATION = keccak256("Curation"); + bytes32 private immutable EPOCH_MANAGER = keccak256("EpochManager"); + bytes32 private immutable REWARDS_MANAGER = keccak256("RewardsManager"); + bytes32 private immutable STAKING = keccak256("Staking"); + bytes32 private immutable GRAPH_TOKEN = keccak256("GraphToken"); + bytes32 private immutable GRAPH_TOKEN_GATEWAY = keccak256("GraphTokenGateway"); + // -- Events -- event ParameterUpdated(string param); @@ -50,7 +58,7 @@ contract Managed { } function _onlyGovernor() internal view { - require(msg.sender == controller.getGovernor(), "Caller must be Controller governor"); + require(msg.sender == controller.getGovernor(), "Only Controller governor"); } function _onlyController() internal view { @@ -111,7 +119,7 @@ contract Managed { * @return Curation contract registered with Controller */ function curation() internal view returns (ICuration) { - return ICuration(_resolveContract(keccak256("Curation"))); + return ICuration(_resolveContract(CURATION)); } /** @@ -119,7 +127,7 @@ contract Managed { * @return Epoch manager contract registered with Controller */ function epochManager() internal view returns (IEpochManager) { - return IEpochManager(_resolveContract(keccak256("EpochManager"))); + return IEpochManager(_resolveContract(EPOCH_MANAGER)); } /** @@ -127,7 +135,7 @@ contract Managed { * @return Rewards manager contract registered with Controller */ function rewardsManager() internal view returns (IRewardsManager) { - return IRewardsManager(_resolveContract(keccak256("RewardsManager"))); + return IRewardsManager(_resolveContract(REWARDS_MANAGER)); } /** @@ -135,7 +143,7 @@ contract Managed { * @return Staking contract registered with Controller */ function staking() internal view returns (IStaking) { - return IStaking(_resolveContract(keccak256("Staking"))); + return IStaking(_resolveContract(STAKING)); } /** @@ -143,7 +151,7 @@ contract Managed { * @return Graph token contract registered with Controller */ function graphToken() internal view returns (IGraphToken) { - return IGraphToken(_resolveContract(keccak256("GraphToken"))); + return IGraphToken(_resolveContract(GRAPH_TOKEN)); } /** @@ -151,7 +159,7 @@ contract Managed { * @return Graph token gateway contract registered with Controller */ function graphTokenGateway() internal view returns (ITokenGateway) { - return ITokenGateway(_resolveContract(keccak256("GraphTokenGateway"))); + return ITokenGateway(_resolveContract(GRAPH_TOKEN_GATEWAY)); } /** diff --git a/contracts/l2/gateway/L2GraphTokenGateway.sol b/contracts/l2/gateway/L2GraphTokenGateway.sol index 251897f6f..371db711f 100644 --- a/contracts/l2/gateway/L2GraphTokenGateway.sol +++ b/contracts/l2/gateway/L2GraphTokenGateway.sol @@ -143,7 +143,7 @@ contract L2GraphTokenGateway is GraphTokenGateway, L2ArbitrumMessenger, Reentran bytes calldata _data ) public payable override notPaused nonReentrant returns (bytes memory) { require(_l1Token == l1GRT, "TOKEN_NOT_GRT"); - require(_amount > 0, "INVALID_ZERO_AMOUNT"); + require(_amount != 0, "INVALID_ZERO_AMOUNT"); require(msg.value == 0, "INVALID_NONZERO_VALUE"); require(_to != address(0), "INVALID_DESTINATION"); @@ -238,8 +238,7 @@ contract L2GraphTokenGateway is GraphTokenGateway, L2ArbitrumMessenger, Reentran if (_data.length > 0) { bytes memory callhookData; { - bytes memory gatewayData; - (gatewayData, callhookData) = abi.decode(_data, (bytes, bytes)); + (, callhookData) = abi.decode(_data, (bytes, bytes)); } ICallhookReceiver(_to).onTokenTransfer(_from, _amount, callhookData); } @@ -283,7 +282,7 @@ contract L2GraphTokenGateway is GraphTokenGateway, L2ArbitrumMessenger, Reentran * @return Sender of the tx * @return Any other data sent to L1 */ - function parseOutboundData(bytes memory _data) private view returns (address, bytes memory) { + function parseOutboundData(bytes calldata _data) private view returns (address, bytes memory) { address from; bytes memory extraData; if (msg.sender == l2Router) { diff --git a/contracts/l2/token/GraphTokenUpgradeable.sol b/contracts/l2/token/GraphTokenUpgradeable.sol index 4ecfb9ffa..ac6ce63f0 100644 --- a/contracts/l2/token/GraphTokenUpgradeable.sol +++ b/contracts/l2/token/GraphTokenUpgradeable.sol @@ -4,7 +4,6 @@ pragma solidity ^0.7.6; import "@openzeppelin/contracts-upgradeable/token/ERC20/ERC20BurnableUpgradeable.sol"; import "@openzeppelin/contracts/cryptography/ECDSA.sol"; -import "@openzeppelin/contracts/math/SafeMath.sol"; import "../../upgrades/GraphUpgradeable.sol"; import "../../governance/Governed.sol"; @@ -26,20 +25,18 @@ import "../../governance/Governed.sol"; * the original's constructor + non-upgradeable approach. */ contract GraphTokenUpgradeable is GraphUpgradeable, Governed, ERC20BurnableUpgradeable { - using SafeMath for uint256; - // -- EIP712 -- // https://github.com/ethereum/EIPs/blob/master/EIPS/eip-712.md#definition-of-domainseparator - bytes32 private constant DOMAIN_TYPE_HASH = + bytes32 private immutable DOMAIN_TYPE_HASH = keccak256( "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract,bytes32 salt)" ); - bytes32 private constant DOMAIN_NAME_HASH = keccak256("Graph Token"); - bytes32 private constant DOMAIN_VERSION_HASH = keccak256("0"); - bytes32 private constant DOMAIN_SALT = + bytes32 private immutable DOMAIN_NAME_HASH = keccak256("Graph Token"); + bytes32 private immutable DOMAIN_VERSION_HASH = keccak256("0"); + bytes32 private immutable DOMAIN_SALT = 0xe33842a7acd1d5a1d28f25a931703e5605152dc48d64dc4716efdae1f5659591; // Randomly generated salt - bytes32 private constant PERMIT_TYPEHASH = + bytes32 private immutable PERMIT_TYPEHASH = keccak256( "Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)" ); @@ -96,7 +93,7 @@ contract GraphTokenUpgradeable is GraphUpgradeable, Governed, ERC20BurnableUpgra require(_owner == recoveredAddress, "GRT: invalid permit"); require(_deadline == 0 || block.timestamp <= _deadline, "GRT: expired permit"); - nonces[_owner] = nonces[_owner].add(1); + nonces[_owner] = nonces[_owner] + 1; _approve(_owner, _spender, _value); } @@ -114,7 +111,7 @@ contract GraphTokenUpgradeable is GraphUpgradeable, Governed, ERC20BurnableUpgra * @param _account Address of the minter */ function removeMinter(address _account) external onlyGovernor { - require(_minters[_account], "NOT_A_MINTER"); + require(isMinter(_account), "NOT_A_MINTER"); _removeMinter(_account); } @@ -122,7 +119,7 @@ contract GraphTokenUpgradeable is GraphUpgradeable, Governed, ERC20BurnableUpgra * @dev Renounce to be a minter. */ function renounceMinter() external { - require(_minters[msg.sender], "NOT_A_MINTER"); + require(isMinter(msg.sender), "NOT_A_MINTER"); _removeMinter(msg.sender); } diff --git a/contracts/l2/token/L2GraphToken.sol b/contracts/l2/token/L2GraphToken.sol index 0e1d942c9..7a5abf78c 100644 --- a/contracts/l2/token/L2GraphToken.sol +++ b/contracts/l2/token/L2GraphToken.sol @@ -59,7 +59,7 @@ contract L2GraphToken is GraphTokenUpgradeable, IArbToken { function setGateway(address _gw) external onlyGovernor { require(_gw != address(0), "INVALID_GATEWAY"); gateway = _gw; - emit GatewaySet(gateway); + emit GatewaySet(_gw); } /** diff --git a/contracts/upgrades/GraphProxy.sol b/contracts/upgrades/GraphProxy.sol index 69c88fd28..cf7ad7812 100644 --- a/contracts/upgrades/GraphProxy.sol +++ b/contracts/upgrades/GraphProxy.sol @@ -102,7 +102,7 @@ contract GraphProxy is GraphProxyStorage { * NOTE: Only the admin can call this function. */ function setAdmin(address _newAdmin) external ifAdmin { - require(_newAdmin != address(0), "Cannot change the admin of a proxy to the zero address"); + require(_newAdmin != address(0), "Admin cant be the zero address"); _setAdmin(_newAdmin); } @@ -138,11 +138,9 @@ contract GraphProxy is GraphProxyStorage { */ function _acceptUpgrade() internal { address _pendingImplementation = _pendingImplementation(); - require(Address.isContract(_pendingImplementation), "Implementation must be a contract"); - require( - _pendingImplementation != address(0) && msg.sender == _pendingImplementation, - "Caller must be the pending implementation" - ); + require(Address.isContract(_pendingImplementation), "Impl must be a contract"); + require(_pendingImplementation != address(0), "Impl cannot be zero address"); + require(msg.sender == _pendingImplementation, "Only pending implementation"); _setImplementation(_pendingImplementation); _setPendingImplementation(address(0)); diff --git a/contracts/upgrades/GraphUpgradeable.sol b/contracts/upgrades/GraphUpgradeable.sol index 2331cae27..3f3b505ba 100644 --- a/contracts/upgrades/GraphUpgradeable.sol +++ b/contracts/upgrades/GraphUpgradeable.sol @@ -29,7 +29,7 @@ contract GraphUpgradeable { * @dev Check if the caller is the implementation. */ modifier onlyImpl() { - require(msg.sender == _implementation(), "Caller must be the implementation"); + require(msg.sender == _implementation(), "Only implementation"); _; } diff --git a/e2e/deployment/config/l1/l1GraphTokenGateway.test.ts b/e2e/deployment/config/l1/l1GraphTokenGateway.test.ts index 1f96bd946..cce20c735 100644 --- a/e2e/deployment/config/l1/l1GraphTokenGateway.test.ts +++ b/e2e/deployment/config/l1/l1GraphTokenGateway.test.ts @@ -26,7 +26,7 @@ describe('[L1] L1GraphTokenGateway configuration', function () { describe('calls with unauthorized user', () => { it('initialize should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).initialize(unauthorized.address) - await expect(tx).revertedWith('Caller must be the implementation') + await expect(tx).revertedWith('Only implementation') }) it('setArbitrumAddresses should revert', async function () { @@ -34,38 +34,38 @@ describe('[L1] L1GraphTokenGateway configuration', function () { unauthorized.address, unauthorized.address, ) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('setL2TokenAddress should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).setL2TokenAddress(unauthorized.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('setL2CounterpartAddress should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).setL2CounterpartAddress( unauthorized.address, ) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('setEscrowAddress should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).setEscrowAddress(unauthorized.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('addToCallhookWhitelist should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).addToCallhookWhitelist( unauthorized.address, ) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('removeFromCallhookWhitelist should revert', async function () { const tx = L1GraphTokenGateway.connect(unauthorized).removeFromCallhookWhitelist( unauthorized.address, ) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('finalizeInboundTransfer should revert', async function () { diff --git a/e2e/deployment/config/l2/l2GraphTokenGateway.test.ts b/e2e/deployment/config/l2/l2GraphTokenGateway.test.ts index f572a37be..c8944927c 100644 --- a/e2e/deployment/config/l2/l2GraphTokenGateway.test.ts +++ b/e2e/deployment/config/l2/l2GraphTokenGateway.test.ts @@ -26,24 +26,24 @@ describe('[L2] L2GraphTokenGateway configuration', function () { describe('calls with unauthorized user', () => { it('initialize should revert', async function () { const tx = L2GraphTokenGateway.connect(unauthorized).initialize(unauthorized.address) - await expect(tx).revertedWith('Caller must be the implementation') + await expect(tx).revertedWith('Only implementation') }) it('setL2Router should revert', async function () { const tx = L2GraphTokenGateway.connect(unauthorized).setL2Router(unauthorized.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('setL1TokenAddress should revert', async function () { const tx = L2GraphTokenGateway.connect(unauthorized).setL1TokenAddress(unauthorized.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('setL1CounterpartAddress should revert', async function () { const tx = L2GraphTokenGateway.connect(unauthorized).setL1CounterpartAddress( unauthorized.address, ) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('finalizeInboundTransfer should revert', async function () { diff --git a/test/curation/configuration.test.ts b/test/curation/configuration.test.ts index b2424c784..f475d8f30 100644 --- a/test/curation/configuration.test.ts +++ b/test/curation/configuration.test.ts @@ -55,7 +55,7 @@ describe('Curation:Config', () => { it('reject set `defaultReserveRatio` if not allowed', async function () { const tx = curation.connect(me.signer).setDefaultReserveRatio(defaults.curation.reserveRatio) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -79,7 +79,7 @@ describe('Curation:Config', () => { const tx = curation .connect(me.signer) .setMinimumCurationDeposit(defaults.curation.minimumCurationDeposit) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -99,7 +99,7 @@ describe('Curation:Config', () => { it('reject set `curationTaxPercentage` if not allowed', async function () { const tx = curation.connect(me.signer).setCurationTaxPercentage(0) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -124,7 +124,7 @@ describe('Curation:Config', () => { it('reject set `curationTokenMaster` if not allowed', async function () { const newCurationTokenMaster = curation.address const tx = curation.connect(me.signer).setCurationTokenMaster(newCurationTokenMaster) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) }) diff --git a/test/disputes/configuration.test.ts b/test/disputes/configuration.test.ts index 28bc92ed5..c663c31d7 100644 --- a/test/disputes/configuration.test.ts +++ b/test/disputes/configuration.test.ts @@ -49,7 +49,7 @@ describe('DisputeManager:Config', () => { it('reject set `arbitrator` if not allowed', async function () { const tx = disputeManager.connect(me.signer).setArbitrator(arbitrator.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `arbitrator` to address zero', async function () { @@ -74,7 +74,7 @@ describe('DisputeManager:Config', () => { it('reject set `minimumDeposit` if not allowed', async function () { const newValue = toBN('1') const tx = disputeManager.connect(me.signer).setMinimumDeposit(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -97,7 +97,7 @@ describe('DisputeManager:Config', () => { it('reject set `fishermanRewardPercentage` if not allowed', async function () { const tx = disputeManager.connect(me.signer).setFishermanRewardPercentage(50) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -127,7 +127,7 @@ describe('DisputeManager:Config', () => { it('reject set `slashingPercentage` if not allowed', async function () { const tx = disputeManager.connect(me.signer).setSlashingPercentage(50, 50) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) }) diff --git a/test/gateway/bridgeEscrow.test.ts b/test/gateway/bridgeEscrow.test.ts index ec3eedb73..fabe9de27 100644 --- a/test/gateway/bridgeEscrow.test.ts +++ b/test/gateway/bridgeEscrow.test.ts @@ -41,7 +41,7 @@ describe('BridgeEscrow', () => { describe('approveAll', function () { it('cannot be called by someone other than the governor', async function () { const tx = bridgeEscrow.connect(tokenReceiver.signer).approveAll(spender.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('allows a spender to transfer GRT held by the contract', async function () { expect(await grt.allowance(bridgeEscrow.address, spender.address)).eq(0) @@ -62,7 +62,7 @@ describe('BridgeEscrow', () => { describe('revokeAll', function () { it('cannot be called by someone other than the governor', async function () { const tx = bridgeEscrow.connect(tokenReceiver.signer).revokeAll(spender.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it("revokes a spender's permission to transfer GRT held by the contract", async function () { await bridgeEscrow.connect(governor.signer).approveAll(spender.address) diff --git a/test/gateway/l1GraphTokenGateway.test.ts b/test/gateway/l1GraphTokenGateway.test.ts index 70984717a..7c2d3db5e 100644 --- a/test/gateway/l1GraphTokenGateway.test.ts +++ b/test/gateway/l1GraphTokenGateway.test.ts @@ -133,7 +133,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .setArbitrumAddresses(inboxMock.address, mockRouter.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('rejects setting an EOA as router or inbox', async function () { let tx = l1GraphTokenGateway @@ -162,7 +162,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .setL2TokenAddress(mockL2GRT.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets l2GRT', async function () { const tx = l1GraphTokenGateway.connect(governor.signer).setL2TokenAddress(mockL2GRT.address) @@ -176,7 +176,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .setL2CounterpartAddress(mockL2Gateway.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets L2Counterpart', async function () { const tx = l1GraphTokenGateway @@ -193,7 +193,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .setEscrowAddress(bridgeEscrow.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets escrow', async function () { const tx = l1GraphTokenGateway @@ -210,7 +210,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .addToCallhookWhitelist(fixtureContracts.rewardsManager.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') expect( await l1GraphTokenGateway.callhookWhitelist(fixtureContracts.rewardsManager.address), ).eq(false) @@ -241,7 +241,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .removeFromCallhookWhitelist(fixtureContracts.rewardsManager.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') expect( await l1GraphTokenGateway.callhookWhitelist(fixtureContracts.rewardsManager.address), ).eq(true) @@ -264,9 +264,9 @@ describe('L1GraphTokenGateway', () => { describe('Pausable behavior', () => { it('cannot be paused or unpaused by someone other than governor or pauseGuardian', async () => { let tx = l1GraphTokenGateway.connect(tokenSender.signer).setPaused(false) - await expect(tx).revertedWith('Only Governor or Guardian can call') + await expect(tx).revertedWith('Only Governor or Guardian') tx = l1GraphTokenGateway.connect(tokenSender.signer).setPaused(true) - await expect(tx).revertedWith('Only Governor or Guardian can call') + await expect(tx).revertedWith('Only Governor or Guardian') }) it('cannot be unpaused if some state variables are not set', async function () { let tx = l1GraphTokenGateway.connect(governor.signer).setPaused(false) @@ -303,7 +303,7 @@ describe('L1GraphTokenGateway', () => { const tx = l1GraphTokenGateway .connect(tokenSender.signer) .setPauseGuardian(pauseGuardian.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets a new pause guardian', async function () { const tx = l1GraphTokenGateway diff --git a/test/gns.test.ts b/test/gns.test.ts index 298d95ab0..1ee46002a 100644 --- a/test/gns.test.ts +++ b/test/gns.test.ts @@ -546,7 +546,7 @@ describe('GNS', () => { it('reject set `ownerTaxPercentage` if not allowed', async function () { const tx = gns.connect(me.signer).setOwnerTaxPercentage(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -1034,7 +1034,7 @@ describe('GNS', () => { // Batch send transaction const tx = gns.connect(me.signer).multicall([tx1.data, tx2.data]) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('should revert if batching a call to initialize', async function () { @@ -1050,7 +1050,7 @@ describe('GNS', () => { // Batch send transaction const tx = gns.connect(me.signer).multicall([tx1.data, tx2.data]) - await expect(tx).revertedWith('Caller must be the implementation') + await expect(tx).revertedWith('Only implementation') }) it('should revert if trying to call a private function', async function () { diff --git a/test/l2/l2GraphTokenGateway.test.ts b/test/l2/l2GraphTokenGateway.test.ts index c987fc281..7c222b73d 100644 --- a/test/l2/l2GraphTokenGateway.test.ts +++ b/test/l2/l2GraphTokenGateway.test.ts @@ -126,7 +126,7 @@ describe('L2GraphTokenGateway', () => { describe('setL2Router', function () { it('is not callable by addreses that are not the governor', async function () { const tx = l2GraphTokenGateway.connect(tokenSender.signer).setL2Router(mockRouter.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets router address', async function () { const tx = l2GraphTokenGateway.connect(governor.signer).setL2Router(mockRouter.address) @@ -140,7 +140,7 @@ describe('L2GraphTokenGateway', () => { const tx = l2GraphTokenGateway .connect(tokenSender.signer) .setL1TokenAddress(mockL1GRT.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets l2GRT', async function () { const tx = l2GraphTokenGateway.connect(governor.signer).setL1TokenAddress(mockL1GRT.address) @@ -154,7 +154,7 @@ describe('L2GraphTokenGateway', () => { const tx = l2GraphTokenGateway .connect(tokenSender.signer) .setL1CounterpartAddress(mockL1Gateway.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets L1Counterpart', async function () { const tx = l2GraphTokenGateway @@ -169,9 +169,9 @@ describe('L2GraphTokenGateway', () => { describe('Pausable behavior', () => { it('cannot be paused or unpaused by someone other than governor or pauseGuardian', async () => { let tx = l2GraphTokenGateway.connect(tokenSender.signer).setPaused(false) - await expect(tx).revertedWith('Only Governor or Guardian can call') + await expect(tx).revertedWith('Only Governor or Guardian') tx = l2GraphTokenGateway.connect(tokenSender.signer).setPaused(true) - await expect(tx).revertedWith('Only Governor or Guardian can call') + await expect(tx).revertedWith('Only Governor or Guardian') }) it('cannot be paused if some state variables are not set', async function () { let tx = l2GraphTokenGateway.connect(governor.signer).setPaused(false) @@ -205,7 +205,7 @@ describe('L2GraphTokenGateway', () => { const tx = l2GraphTokenGateway .connect(tokenSender.signer) .setPauseGuardian(pauseGuardian.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('sets a new pause guardian', async function () { const tx = l2GraphTokenGateway diff --git a/test/rewards/rewards.test.ts b/test/rewards/rewards.test.ts index 23aee0dfa..beed73a73 100644 --- a/test/rewards/rewards.test.ts +++ b/test/rewards/rewards.test.ts @@ -171,7 +171,7 @@ describe('Rewards', () => { describe('issuance rate update', function () { it('reject set issuance rate if unauthorized', async function () { const tx = rewardsManager.connect(indexer1.signer).setIssuanceRate(toGRT('1.025')) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set issuance rate to less than minimum allowed', async function () { @@ -199,7 +199,7 @@ describe('Rewards', () => { const tx = rewardsManager .connect(indexer1.signer) .setSubgraphAvailabilityOracle(oracle.address) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('should set subgraph oracle if governor', async function () { diff --git a/test/staking/configuration.test.ts b/test/staking/configuration.test.ts index 39ed30502..52aeaa843 100644 --- a/test/staking/configuration.test.ts +++ b/test/staking/configuration.test.ts @@ -52,7 +52,7 @@ describe('Staking:Config', () => { it('reject set `minimumIndexerStake` if not allowed', async function () { const newValue = toGRT('100') const tx = staking.connect(me.signer).setMinimumIndexerStake(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `minimumIndexerStake` to zero', async function () { @@ -74,7 +74,7 @@ describe('Staking:Config', () => { it('reject set `slasher` if not allowed', async function () { const tx = staking.connect(other.signer).setSlasher(me.address, true) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `slasher` for zero', async function () { @@ -103,7 +103,7 @@ describe('Staking:Config', () => { it('reject set `assetHolder` if not allowed', async function () { const tx = staking.connect(other.signer).setAssetHolder(me.address, true) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `assetHolder` to address zero', async function () { @@ -122,7 +122,7 @@ describe('Staking:Config', () => { it('reject set `channelDisputeEpochs` if not allowed', async function () { const newValue = toBN('5') const tx = staking.connect(other.signer).setChannelDisputeEpochs(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `channelDisputeEpochs` to zero', async function () { @@ -146,7 +146,7 @@ describe('Staking:Config', () => { it('reject set `curationPercentage` if not allowed', async function () { const tx = staking.connect(other.signer).setCurationPercentage(50) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -166,7 +166,7 @@ describe('Staking:Config', () => { it('reject set `protocolPercentage` if not allowed', async function () { const tx = staking.connect(other.signer).setProtocolPercentage(50) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -180,7 +180,7 @@ describe('Staking:Config', () => { it('reject set `maxAllocationEpochs` if not allowed', async function () { const newValue = toBN('5') const tx = staking.connect(other.signer).setMaxAllocationEpochs(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -194,7 +194,7 @@ describe('Staking:Config', () => { it('reject set `thawingPeriod` if not allowed', async function () { const newValue = toBN('5') const tx = staking.connect(other.signer).setThawingPeriod(newValue) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) it('reject set `thawingPeriod` to zero', async function () { @@ -225,7 +225,7 @@ describe('Staking:Config', () => { it('reject set `rebateRatio` if not allowed', async function () { const tx = staking.connect(other.signer).setRebateRatio(1, 1) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) }) diff --git a/test/staking/delegation.test.ts b/test/staking/delegation.test.ts index cad46a063..e097dfd9f 100644 --- a/test/staking/delegation.test.ts +++ b/test/staking/delegation.test.ts @@ -217,7 +217,7 @@ describe('Staking::Delegation', () => { it('reject set `delegationRatio` if not allowed', async function () { const tx = staking.connect(me.signer).setDelegationRatio(delegationRatio) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -231,7 +231,7 @@ describe('Staking::Delegation', () => { it('reject set `delegationParametersCooldown` if not allowed', async function () { const tx = staking.connect(me.signer).setDelegationParametersCooldown(cooldown) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) }) @@ -251,7 +251,7 @@ describe('Staking::Delegation', () => { it('reject set `delegationTaxPercentage` if not allowed', async function () { const tx = staking.connect(me.signer).setDelegationTaxPercentage(50) - await expect(tx).revertedWith('Caller must be Controller governor') + await expect(tx).revertedWith('Only Controller governor') }) })