-
Notifications
You must be signed in to change notification settings - Fork 36
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore: migrate E2E upgradeAuthenticator test to Foundry (#217)
## Description Migrate the upgradeAuthenticator e2e test to foundry. Depends on #215. ## Test Plan CI ## Related Issues Closes #142
- Loading branch information
1 parent
9225dff
commit 75bf332
Showing
3 changed files
with
101 additions
and
155 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
// SPDX-License-Identifier: LGPL-3.0-or-later | ||
pragma solidity ^0.8; | ||
|
||
import {GPv2AllowListAuthentication} from "src/contracts/GPv2AllowListAuthentication.sol"; | ||
|
||
import {Helper} from "./Helper.sol"; | ||
|
||
interface IEIP173Proxy { | ||
function upgradeTo(address) external; | ||
function transferOwnership(address) external; | ||
function owner() external view returns (address); | ||
} | ||
|
||
contract GPv2AllowListAuthenticationV2 is GPv2AllowListAuthentication { | ||
function newMethod() external pure returns (uint256) { | ||
return 1337; | ||
} | ||
} | ||
|
||
contract UpgradeAuthenticatorTest is Helper(false) { | ||
GPv2AllowListAuthenticationV2 v2Impl; | ||
|
||
function setUp() public override { | ||
super.setUp(); | ||
v2Impl = new GPv2AllowListAuthenticationV2(); | ||
} | ||
|
||
function test_should_upgrade_authenticator() external { | ||
vm.expectRevert(); | ||
GPv2AllowListAuthenticationV2(address(authenticator)).newMethod(); | ||
|
||
vm.prank(owner); | ||
IEIP173Proxy(address(authenticator)).upgradeTo(address(v2Impl)); | ||
|
||
assertEq( | ||
GPv2AllowListAuthenticationV2(address(authenticator)).newMethod(), 1337, "proxy didnt update as expected" | ||
); | ||
} | ||
|
||
function test_should_preserve_storage() external { | ||
address newSolver = makeAddr("newSolver"); | ||
address newManager = makeAddr("newManager"); | ||
|
||
vm.startPrank(owner); | ||
GPv2AllowListAuthentication(address(authenticator)).addSolver(newSolver); | ||
GPv2AllowListAuthentication(address(authenticator)).setManager(newManager); | ||
|
||
IEIP173Proxy(address(authenticator)).upgradeTo(address(v2Impl)); | ||
vm.stopPrank(); | ||
|
||
assertEq(authenticator.isSolver(newSolver), true, "solver not retained in storage after proxy upgrade"); | ||
assertEq( | ||
GPv2AllowListAuthentication(address(authenticator)).manager(), | ||
newManager, | ||
"manager not retained in storage after proxy upgrade" | ||
); | ||
} | ||
|
||
function test_should_allow_proxy_owner_to_change_manager() external { | ||
// transfer ownership to a new address and then assert the behavior | ||
// to have a proxy owner that is different address than manager | ||
address newOwner = makeAddr("newOwner"); | ||
vm.prank(owner); | ||
IEIP173Proxy(address(authenticator)).transferOwnership(newOwner); | ||
|
||
address newManager = makeAddr("newManager"); | ||
vm.prank(newOwner); | ||
GPv2AllowListAuthentication(address(authenticator)).setManager(newManager); | ||
|
||
assertEq( | ||
GPv2AllowListAuthentication(address(authenticator)).manager(), | ||
newManager, | ||
"proxy owner couldnt update manager" | ||
); | ||
} | ||
|
||
function test_should_be_able_to_transfer_proxy_ownership() external { | ||
address newOwner = makeAddr("newOwner"); | ||
vm.prank(owner); | ||
IEIP173Proxy(address(authenticator)).transferOwnership(newOwner); | ||
|
||
assertEq(IEIP173Proxy(address(authenticator)).owner(), newOwner, "ownership didnt transfer as expected"); | ||
} | ||
|
||
function test_should_revert_when_upgrading_with_the_authentication_manager() external { | ||
address newManager = makeAddr("newManager"); | ||
vm.prank(owner); | ||
GPv2AllowListAuthentication(address(authenticator)).setManager(newManager); | ||
|
||
vm.prank(newManager); | ||
vm.expectRevert("NOT_AUTHORIZED"); | ||
IEIP173Proxy(address(authenticator)).upgradeTo(address(v2Impl)); | ||
} | ||
|
||
function test_should_revert_when_not_upgrading_with_the_proxy_owner() external { | ||
address nobody = makeAddr("nobody"); | ||
vm.prank(nobody); | ||
vm.expectRevert("NOT_AUTHORIZED"); | ||
IEIP173Proxy(address(authenticator)).upgradeTo(address(v2Impl)); | ||
} | ||
} |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.