From 7f551a332f28b9b2260b337dc306179da742f6c0 Mon Sep 17 00:00:00 2001 From: Chris Maree Date: Tue, 20 Dec 2022 18:27:52 +0200 Subject: [PATCH] feat: Add mainnet forking test case (#4306) Signed-off-by: Reinis Martinsons --- .../implementation/Staker.sol | 2 +- packages/core/package.json | 1 + ...ommonDataVerificationMechanismForkTest.sol | 53 ++++++++++++++ .../fork-tests/FakeLifeCycle.ft.sol | 70 +++++++++++++++++++ .../fixtures/common/CommonTestBase.sol | 7 ++ ...n.sol => CommonOptimisticAsserterTest.sol} | 5 +- .../OptimisticAsserter.Callbacks.t.sol | 4 +- .../OptimisticAsserter.EdgeCases.t.sol | 4 +- .../OptimisticAsserter.Events.t.sol | 4 +- .../OptimisticAsserter.Lifecycle.t.sol | 4 +- .../OptimisticAsserter.Maintenance.t.sol | 4 +- .../OptimisticAsserter.SsPolicy.t.sol | 4 +- .../BaseEscalationManager.t.sol | 4 +- .../DisputeLimitingEscalationManager.t.sol | 4 +- .../FullPolicyEscalationManager.t.sol | 4 +- .../OwnerDiscardOracleEscalationManager.t.sol | 4 +- .../OwnerSelectOracleEscalationManager.t.sol | 4 +- .../SuperbondEscalationManager.t.sol | 4 +- .../WhitelistAsserterEscalationManager.t.sol | 4 +- .../WhitelistCallerEscalationManager.t.sol | 4 +- .../WhitelistDisputerEscalationManager.t.sol | 4 +- .../examples/DataAsserter.t.sol | 4 +- .../examples/Insurance.t.sol | 4 +- .../examples/PredictionMarket.Common.sol | 4 +- .../BaseEscalationManager.t.sol | 4 +- 25 files changed, 172 insertions(+), 42 deletions(-) create mode 100644 packages/core/test/foundry/data-verification-mechanism/fork-tests/CommonDataVerificationMechanismForkTest.sol create mode 100644 packages/core/test/foundry/data-verification-mechanism/fork-tests/FakeLifeCycle.ft.sol create mode 100644 packages/core/test/foundry/fixtures/common/CommonTestBase.sol rename packages/core/test/foundry/optimistic-asserter/{Common.sol => CommonOptimisticAsserterTest.sol} (99%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/BaseEscalationManager.t.sol (92%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/DisputeLimitingEscalationManager.t.sol (98%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/FullPolicyEscalationManager.t.sol (98%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/OwnerDiscardOracleEscalationManager.t.sol (90%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/OwnerSelectOracleEscalationManager.t.sol (94%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/SuperbondEscalationManager.t.sol (95%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/WhitelistAsserterEscalationManager.t.sol (96%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/WhitelistCallerEscalationManager.t.sol (92%) rename packages/core/test/foundry/optimistic-asserter/{EscalationManager => escalation-manager}/WhitelistDisputerEscalationManager.t.sol (90%) diff --git a/packages/core/contracts/data-verification-mechanism/implementation/Staker.sol b/packages/core/contracts/data-verification-mechanism/implementation/Staker.sol index af34505a7b..3696610c1c 100644 --- a/packages/core/contracts/data-verification-mechanism/implementation/Staker.sol +++ b/packages/core/contracts/data-verification-mechanism/implementation/Staker.sol @@ -38,7 +38,7 @@ abstract contract Staker is StakerInterface, Ownable, Lockable, MultiCaller { // Mapping of delegates to their delegators (staker). Reverse mapping from voterStakes.delegate. mapping(address => address) public delegateToStaker; - // Number of UMA emitted per second top incentivize stakers. + // Number of UMA emitted per second to incentivize stakers. uint256 public emissionRate; // Total number of UMA staked within the system. diff --git a/packages/core/package.json b/packages/core/package.json index 94790e8f6a..a2679b72d4 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -78,6 +78,7 @@ "scripts": { "test": "yarn hardhat-test && yarn forge-test", "forge-test": "./scripts/SetUpFoundryWithHardhat.sh && forge test", + "forge-fork-test": "forge test --match-path *fork-test* -vvv --fork-url $CUSTOM_NODE_URL", "hardhat-test": "hardhat test --network hardhat", "mocha-test": "mocha ./mocha-test --recursive", "load-addresses": "yarn hardhat load-addresses", diff --git a/packages/core/test/foundry/data-verification-mechanism/fork-tests/CommonDataVerificationMechanismForkTest.sol b/packages/core/test/foundry/data-verification-mechanism/fork-tests/CommonDataVerificationMechanismForkTest.sol new file mode 100644 index 0000000000..0259a6720b --- /dev/null +++ b/packages/core/test/foundry/data-verification-mechanism/fork-tests/CommonDataVerificationMechanismForkTest.sol @@ -0,0 +1,53 @@ +// SPDX-License-Identifier: AGPL-3.0-only +pragma solidity ^0.8.0; + +import "../../fixtures/common/CommonTestBase.sol"; + +import "../../../../contracts/data-verification-mechanism/implementation/VotingV2.sol"; +import "../../../../contracts/data-verification-mechanism/interfaces/VotingAncillaryInterface.sol"; +import "../../../../contracts/common/interfaces/ExpandedIERC20.sol"; + +contract CommonDataVerificationMechanismForkTest is CommonTestBase { + VotingV2 voting; + ExpandedIERC20 votingToken; + + bool shouldRunForkedTest; + + address registeredRequester; + address governor; + + bytes32 identifier = bytes32("YES_OR_NO_QUERY"); + bytes ancillaryData = bytes("Some data"); + uint256 gatMeetingNumOfTokens = 6e24; + uint256 requestTime = 420; + + function _commonSetup() public { + uint256 chainId = block.chainid; + shouldRunForkedTest = (chainId == 1 || chainId == 5); + if (!shouldRunForkedTest) return; // Exit early if we are not executing forked tests. + + // TODO: look into a way to not have to hard code these addresses. Ok for now as we wont be changing them. + address votingAddress = chainId == 1 ? address(0) : 0xF71cdF8A34c56933A8871354A2570a301364e95F; + + voting = VotingV2(votingAddress); + + registeredRequester = chainId == 1 + ? 0xA0Ae6609447e57a42c51B50EAe921D701823FFAe + : 0xA5B9d8a0B0Fa04Ba71BDD68069661ED5C0848884; + + governor = chainId == 1 + ? 0x592349F7DeDB2b75f9d4F194d4b7C16D82E507Dc + : 0xFf0E348389400d7D7510a230361Fc00904429e48; + + votingToken = voting.votingToken(); + } + + function moveToNextPhase() public { + (uint256 phaseLength, ) = voting.voteTiming(); + vm.warp(voting.getRoundEndTime(voting.getCurrentRoundId()) - phaseLength); + } + + function moveToNextRound() public { + vm.warp(voting.getRoundEndTime(voting.getCurrentRoundId())); + } +} diff --git a/packages/core/test/foundry/data-verification-mechanism/fork-tests/FakeLifeCycle.ft.sol b/packages/core/test/foundry/data-verification-mechanism/fork-tests/FakeLifeCycle.ft.sol new file mode 100644 index 0000000000..18e9c0e674 --- /dev/null +++ b/packages/core/test/foundry/data-verification-mechanism/fork-tests/FakeLifeCycle.ft.sol @@ -0,0 +1,70 @@ +// SPDX-License-Identifier: UNLICENSED +pragma solidity ^0.8.0; + +import "./CommonDataVerificationMechanismForkTest.sol"; + +contract FakeLifeCycle is CommonDataVerificationMechanismForkTest { + function setUp() public { + _commonSetup(); + } + + function test_CanEnqueueRequestAndVoteWithNewlyStakedTokens() public { + if (!shouldRunForkedTest) return; // Exit early if we are not executing forked tests. + + // Submit a new request and show it increments. + // Ensure we are at the start of a voting round so we can stake and vote without the stake being disabled. + if (voting.getVotePhase() == VotingV2Interface.Phase.Reveal) moveToNextRound(); + + uint256 numberRequestsPreRequest = voting.getNumberOfPriceRequests(); + vm.prank(registeredRequester); + voting.requestPrice(identifier, requestTime, ancillaryData); + assert(voting.getNumberOfPriceRequests() == numberRequestsPreRequest + 1); + + // Mint fresh UMA and stake them. + vm.prank(address(voting)); + uint256 stakedNumOfTokens = gatMeetingNumOfTokens; + votingToken.mint(TestAddress.account1, stakedNumOfTokens); + vm.startPrank(TestAddress.account1); + votingToken.approve(address(voting), stakedNumOfTokens); + uint256 stakeTime = voting.getCurrentTime(); + voting.stake(stakedNumOfTokens); + assert(voting.getVoterStakePostUpdate(TestAddress.account1) == stakedNumOfTokens); + + // Advance some time to ensure reward accrual works as expected. + moveToNextRound(); + voting.withdrawRewards(); // Check if the Staker claims rewards now they get the expected amount. + uint256 stakerBalanceAfterRewardWithdrawal = votingToken.balanceOf(TestAddress.account1); + assert(voting.getVoterStakePostUpdate(TestAddress.account1) == stakedNumOfTokens); + + uint256 rewardsPerToken = + ((voting.getCurrentTime() - stakeTime) * voting.emissionRate() * 1e18) / voting.cumulativeStake(); + uint256 expectedRewards = (rewardsPerToken * voting.getVoterStakePostUpdate(TestAddress.account1)) / 1e18; + assertEq(stakerBalanceAfterRewardWithdrawal, expectedRewards); + + // Move to next round, request a price and vote on it from the newly staked account. + moveToNextRound(); + int256 price = 1e18; + int256 salt = 42069; + uint256 roundId = voting.getCurrentRoundId(); + address account = TestAddress.account1; + bytes32 hash = + keccak256(abi.encodePacked(price, salt, account, requestTime, ancillaryData, roundId, identifier)); + voting.commitVote(identifier, requestTime, ancillaryData, hash); + moveToNextPhase(); + voting.revealVote(identifier, requestTime, price, ancillaryData, salt); + + // Check the price has resolved correctly. + moveToNextRound(); + vm.stopPrank(); + vm.prank(registeredRequester); + assertEq(voting.getPrice(identifier, requestTime, ancillaryData), price); + + // Finally, considering we were the only voter, we should be able to work out the slashing amount precisely. + uint256 totalStakedAtVote = voting.cumulativeStake(); // Has not changed from when we staked. + uint256 slashPerTokenPerNoVote = + voting.slashingLibrary().calcNoVoteSlashPerToken(totalStakedAtVote, stakedNumOfTokens, stakedNumOfTokens); + uint256 totalSlashedTokens = ((totalStakedAtVote - stakedNumOfTokens) * slashPerTokenPerNoVote) / 1e18; + uint256 expectedStakerBalanceAfterSlashing = stakedNumOfTokens + totalSlashedTokens; + assertEq(voting.getVoterStakePostUpdate(TestAddress.account1), expectedStakerBalanceAfterSlashing); + } +} diff --git a/packages/core/test/foundry/fixtures/common/CommonTestBase.sol b/packages/core/test/foundry/fixtures/common/CommonTestBase.sol new file mode 100644 index 0000000000..20962de9c7 --- /dev/null +++ b/packages/core/test/foundry/fixtures/common/CommonTestBase.sol @@ -0,0 +1,7 @@ +// SPDX-License-Identifier: UNLICENSED +pragma solidity ^0.8.0; + +import "forge-std/Test.sol"; +import "./TestAddress.sol"; + +contract CommonTestBase is Test {} diff --git a/packages/core/test/foundry/optimistic-asserter/Common.sol b/packages/core/test/foundry/optimistic-asserter/CommonOptimisticAsserterTest.sol similarity index 99% rename from packages/core/test/foundry/optimistic-asserter/Common.sol rename to packages/core/test/foundry/optimistic-asserter/CommonOptimisticAsserterTest.sol index a6abc23bb9..0a7580b232 100644 --- a/packages/core/test/foundry/optimistic-asserter/Common.sol +++ b/packages/core/test/foundry/optimistic-asserter/CommonOptimisticAsserterTest.sol @@ -1,13 +1,12 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "forge-std/Test.sol"; +import "../fixtures/common/CommonTestBase.sol"; import "../fixtures/optimistic-asserter/OptimisticAsserterFixture.sol"; -import "../fixtures/common/TestAddress.sol"; import "../../../contracts/data-verification-mechanism/test/MockOracleAncillary.sol"; import "../../../contracts/optimistic-asserter/implementation/test/AssertingCallerTest.sol"; -contract Common is Test { +contract CommonOptimisticAsserterTest is CommonTestBase { // Data structures, that might be used in tests. struct OracleRequest { bytes32 identifier; diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Callbacks.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Callbacks.t.sol index 8bceeb7a6e..9334a6b503 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Callbacks.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Callbacks.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; -contract OptimisticAsserterCallbacks is Common { +contract OptimisticAsserterCallbacks is CommonOptimisticAsserterTest { function setUp() public { _commonSetup(); diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.EdgeCases.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.EdgeCases.t.sol index 46fdd18bc3..70aa997142 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.EdgeCases.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.EdgeCases.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; -contract InvalidParameters is Common { +contract InvalidParameters is CommonOptimisticAsserterTest { function setUp() public { _commonSetup(); } diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Events.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Events.t.sol index 238cd1a5fd..6b97b928ba 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Events.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Events.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; -contract OptimisticAsserterEvents is Common { +contract OptimisticAsserterEvents is CommonOptimisticAsserterTest { event AdminPropertiesSet(IERC20 defaultCurrency, uint64 defaultLiveness, uint256 burnedBondPercentage); function setUp() public { diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Lifecycle.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Lifecycle.t.sol index c377c95aa2..ef42c6a9bd 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Lifecycle.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Lifecycle.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; -contract SimpleAssertionsWithClaimOnly is Common { +contract SimpleAssertionsWithClaimOnly is CommonOptimisticAsserterTest { function setUp() public { _commonSetup(); } diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Maintenance.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Maintenance.t.sol index 8d61dd60c3..5dcf9d4b28 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Maintenance.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.Maintenance.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; import "../../../contracts/data-verification-mechanism/implementation/Store.sol"; -contract MaintenanceTest is Common { +contract MaintenanceTest is CommonOptimisticAsserterTest { function setUp() public { _commonSetup(); } diff --git a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.SsPolicy.t.sol b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.SsPolicy.t.sol index da6da2a1b1..64d5d8cb87 100644 --- a/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.SsPolicy.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/OptimisticAsserter.SsPolicy.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "./Common.sol"; +import "./CommonOptimisticAsserterTest.sol"; -contract EscalationManagerPolicyEnforced is Common { +contract EscalationManagerPolicyEnforced is CommonOptimisticAsserterTest { function setUp() public { _commonSetup(); diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/BaseEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/BaseEscalationManager.t.sol similarity index 92% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/BaseEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/BaseEscalationManager.t.sol index 54a1e0ef5d..3da79c928b 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/BaseEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/BaseEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/BaseEscalationManager.sol"; -contract BaseEscalationManagerTest is Common { +contract BaseEscalationManagerTest is CommonOptimisticAsserterTest { BaseEscalationManager escalationManager; bytes32 identifier = "test"; diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/DisputeLimitingEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/DisputeLimitingEscalationManager.t.sol similarity index 98% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/DisputeLimitingEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/DisputeLimitingEscalationManager.t.sol index 3c94b10da4..fde8084f1e 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/DisputeLimitingEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/DisputeLimitingEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/DisputeLimitingEscalationManager.sol"; -contract DisputeLimitingEscalationManagerTest is Common { +contract DisputeLimitingEscalationManagerTest is CommonOptimisticAsserterTest { DisputeLimitingEscalationManager escalationManager; bytes32 assertionId = "test"; diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/FullPolicyEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/FullPolicyEscalationManager.t.sol similarity index 98% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/FullPolicyEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/FullPolicyEscalationManager.t.sol index ad437eddbd..43d22a81af 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/FullPolicyEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/FullPolicyEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/FullPolicyEscalationManager.sol"; -contract FullPolicyEscalationManagerTest is Common { +contract FullPolicyEscalationManagerTest is CommonOptimisticAsserterTest { FullPolicyEscalationManager escalationManager; bytes32 assertionId = bytes32(0); diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerDiscardOracleEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerDiscardOracleEscalationManager.t.sol similarity index 90% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerDiscardOracleEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerDiscardOracleEscalationManager.t.sol index 2d0cd1835f..54f693d03f 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerDiscardOracleEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerDiscardOracleEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/OwnerDiscardOracleEscalationManager.sol"; -contract OwnerDiscardOracleEscalationManagerTest is Common { +contract OwnerDiscardOracleEscalationManagerTest is CommonOptimisticAsserterTest { OwnerDiscardOracleEscalationManager escalationManager; function setUp() public { diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerSelectOracleEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerSelectOracleEscalationManager.t.sol similarity index 94% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerSelectOracleEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerSelectOracleEscalationManager.t.sol index 2e72e4096f..95e1e7e8ac 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/OwnerSelectOracleEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/OwnerSelectOracleEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/OwnerSelectOracleEscalationManager.sol"; -contract OwnerSelectOracleEscalationManagerTest is Common { +contract OwnerSelectOracleEscalationManagerTest is CommonOptimisticAsserterTest { OwnerSelectOracleEscalationManager escalationManager; function setUp() public { diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/SuperbondEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/SuperbondEscalationManager.t.sol similarity index 95% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/SuperbondEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/SuperbondEscalationManager.t.sol index d7eed288ab..1bee1929ed 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/SuperbondEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/SuperbondEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/SuperbondEscalationManager.sol"; -contract SuperbondEscalationManagerTest is Common { +contract SuperbondEscalationManagerTest is CommonOptimisticAsserterTest { SuperbondEscalationManager escalationManager; uint256 superbond = 100e18; uint256 bond = 50e18; diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistAsserterEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistAsserterEscalationManager.t.sol similarity index 96% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistAsserterEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistAsserterEscalationManager.t.sol index d7e650facc..d40684d746 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistAsserterEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistAsserterEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/WhitelistAsserterEscalationManager.sol"; -contract WhitelistAsserterEscalationManagerTest is Common { +contract WhitelistAsserterEscalationManagerTest is CommonOptimisticAsserterTest { WhitelistAsserterEscalationManager escalationManager; bytes32 assertionId = "test"; diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistCallerEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistCallerEscalationManager.t.sol similarity index 92% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistCallerEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistCallerEscalationManager.t.sol index 7e3e0b18a9..e15f18716d 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistCallerEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistCallerEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/WhitelistCallerEscalationManager.sol"; -contract WhitelistCallerEscalationManagerTest is Common { +contract WhitelistCallerEscalationManagerTest is CommonOptimisticAsserterTest { WhitelistCallerEscalationManager escalationManager; function setUp() public { diff --git a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistDisputerEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistDisputerEscalationManager.t.sol similarity index 90% rename from packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistDisputerEscalationManager.t.sol rename to packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistDisputerEscalationManager.t.sol index ad5f552761..584816d194 100644 --- a/packages/core/test/foundry/optimistic-asserter/EscalationManager/WhitelistDisputerEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/escalation-manager/WhitelistDisputerEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/WhitelistDisputerEscalationManager.sol"; -contract WhitelistDisputerEscalationManagerTest is Common { +contract WhitelistDisputerEscalationManagerTest is CommonOptimisticAsserterTest { WhitelistDisputerEscalationManager escalationManager; function setUp() public { diff --git a/packages/core/test/foundry/optimistic-asserter/examples/DataAsserter.t.sol b/packages/core/test/foundry/optimistic-asserter/examples/DataAsserter.t.sol index 03b1ddf852..ea79caf7a7 100644 --- a/packages/core/test/foundry/optimistic-asserter/examples/DataAsserter.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/examples/DataAsserter.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/examples/DataAsserter.sol"; -contract DataAsserterTest is Common { +contract DataAsserterTest is CommonOptimisticAsserterTest { DataAsserter public dataAsserter; bytes32 dataId = bytes32("dataId"); bytes32 correctData = bytes32("correctData"); diff --git a/packages/core/test/foundry/optimistic-asserter/examples/Insurance.t.sol b/packages/core/test/foundry/optimistic-asserter/examples/Insurance.t.sol index b248df8c0d..1d0d0042c5 100644 --- a/packages/core/test/foundry/optimistic-asserter/examples/Insurance.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/examples/Insurance.t.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/examples/Insurance.sol"; -contract InsuranceTest is Common { +contract InsuranceTest is CommonOptimisticAsserterTest { Insurance public insurance; bytes insuredEvent = bytes("insuredEvent"); uint256 insuranceAmount = 100; diff --git a/packages/core/test/foundry/optimistic-asserter/examples/PredictionMarket.Common.sol b/packages/core/test/foundry/optimistic-asserter/examples/PredictionMarket.Common.sol index b9e5460cdf..d2a9a8897f 100644 --- a/packages/core/test/foundry/optimistic-asserter/examples/PredictionMarket.Common.sol +++ b/packages/core/test/foundry/optimistic-asserter/examples/PredictionMarket.Common.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/examples/PredictionMarket.sol"; -contract PredictionMarketTestCommon is Common { +contract PredictionMarketTestCommon is CommonOptimisticAsserterTest { PredictionMarket public predictionMarket; string outcome1 = "Red"; string outcome2 = "Blue"; diff --git a/packages/core/test/foundry/optimistic-asserter/integration-tests/BaseEscalationManager.t.sol b/packages/core/test/foundry/optimistic-asserter/integration-tests/BaseEscalationManager.t.sol index 9c89fcc5ac..2b6dc93257 100644 --- a/packages/core/test/foundry/optimistic-asserter/integration-tests/BaseEscalationManager.t.sol +++ b/packages/core/test/foundry/optimistic-asserter/integration-tests/BaseEscalationManager.t.sol @@ -1,10 +1,10 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.0; -import "../Common.sol"; +import "../CommonOptimisticAsserterTest.sol"; import "../../../../contracts/optimistic-asserter/implementation/escalation-manager/BaseEscalationManager.sol"; -contract BaseEscalationManagerTest is Common { +contract BaseEscalationManagerTest is CommonOptimisticAsserterTest { address escalationManager; function setUp() public virtual {