From 32b2f938c392ec166abaa0ce3e5277ea8f08f654 Mon Sep 17 00:00:00 2001 From: soloseng <102702451+soloseng@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:55:56 -0500 Subject: [PATCH] ++ L2 setup; renamed local registry contract; passing L1 test --- .../test-sol/unit/common/Registry.t.sol | 56 +++++++++++-------- 1 file changed, 34 insertions(+), 22 deletions(-) diff --git a/packages/protocol/test-sol/unit/common/Registry.t.sol b/packages/protocol/test-sol/unit/common/Registry.t.sol index 404101316d6..277d4832536 100644 --- a/packages/protocol/test-sol/unit/common/Registry.t.sol +++ b/packages/protocol/test-sol/unit/common/Registry.t.sol @@ -1,7 +1,7 @@ // SPDX-License-Identifier: UNLICENSED pragma solidity ^0.5.13; -import "celo-foundry/Test.sol"; +import "@test-sol/utils/WhenL2.sol"; import "@celo-contracts/common/Registry.sol"; @@ -14,89 +14,101 @@ contract RegistryTest is Test { // hash is harcoded to avoid test and implementation changing at the same time bytes32 constant ID_HASH = 0x05445421d7b4d4c2e571c5a4ccf9317ec68601449f752c75ddbcc61a16061004; - Registry registry; + Registry _registry; address owner; function setUp() public { owner = address(this); vm.prank(owner); - registry = new Registry(true); - registry.initialize(); + _registry = new Registry(true); + _registry.initialize(); } +} + +contract RegistryTest_L2 is WhenL2, RegistryTest { + function setUp() public { + super.setUp(); + registry = IRegistry(address(_registry)); + setupEpochManager(); + } +} +contract RegistryTest_initialize is RegistryTest { function test_SetsTheOwner() public { - assertEq(registry.owner(), owner); + assertEq(_registry.owner(), owner); } function test_Reverts_WhenCalledAgain() public { vm.expectRevert("contract already initialized"); - registry.initialize(); + _registry.initialize(); } } contract RegistryTest_setAddressFor is RegistryTest { function test_SetsAddress() public { vm.prank(owner); - registry.setAddressFor(SOME_ID, SOME_ADDRESS); - assertEq(registry.registry(ID_HASH), SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); + assertEq(_registry.registry(ID_HASH), SOME_ADDRESS); } function test_Reverts_WhenCalledByNonOwner() public { vm.expectRevert("Ownable: caller is not the owner"); vm.prank(msg.sender); - registry.setAddressFor(SOME_ID, SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); } function test_Emits_RegistryUpdated() public { vm.expectEmit(true, true, false, true); emit RegistryUpdated(SOME_ID, ID_HASH, SOME_ADDRESS); - registry.setAddressFor(SOME_ID, SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); } } +contract RegistryTest_setAddressFor_L2 is RegistryTest_L2, RegistryTest_setAddressFor {} + contract RegistryTest_getAddressFor is RegistryTest { function test_GetsRightAddress() public { - registry.setAddressFor(SOME_ID, SOME_ADDRESS); - assertEq(registry.getAddressFor(ID_HASH), SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); + assertEq(_registry.getAddressFor(ID_HASH), SOME_ADDRESS); } function test_ReturnsZero_WhenNotFound() public { - assertEq(registry.getAddressFor(ID_HASH), address(0)); + assertEq(_registry.getAddressFor(ID_HASH), address(0)); } } contract RegistryTest_getAddressForString is RegistryTest { function test_GetsRightAddress() public { - registry.setAddressFor(SOME_ID, SOME_ADDRESS); - assertEq(registry.getAddressForString(SOME_ID), SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); + assertEq(_registry.getAddressForString(SOME_ID), SOME_ADDRESS); } function test_DoesNotRevers_WhenGettingAddress() public view { - registry.getAddressForString(SOME_ID); + _registry.getAddressForString(SOME_ID); } } contract RegistryTest_getAddressForOrDie is RegistryTest { function test_GetsRightAddress() public { - registry.setAddressFor(SOME_ID, SOME_ADDRESS); - assertEq(registry.getAddressForOrDie(ID_HASH), SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); + assertEq(_registry.getAddressForOrDie(ID_HASH), SOME_ADDRESS); } function test_Reverts_WhenAddressNotFound() public { vm.expectRevert("identifier has no registry entry"); - registry.getAddressForOrDie(ID_HASH); + _registry.getAddressForOrDie(ID_HASH); } } contract RegistryTest_getAddressForStringOrDie is RegistryTest { function test_GetAddressForStringOrDie_gets_address() public { - registry.setAddressFor(SOME_ID, SOME_ADDRESS); - assertEq(registry.getAddressForStringOrDie(SOME_ID), SOME_ADDRESS); + _registry.setAddressFor(SOME_ID, SOME_ADDRESS); + assertEq(_registry.getAddressForStringOrDie(SOME_ID), SOME_ADDRESS); } function test_Reverts_WhenAddressNotFound() public { vm.expectRevert("identifier has no registry entry"); - registry.getAddressForStringOrDie(SOME_ID); + _registry.getAddressForStringOrDie(SOME_ID); } }