From a40c1a21fecdb40b1fe4a07b3538e9151096e846 Mon Sep 17 00:00:00 2001 From: Andrei Maiboroda Date: Wed, 27 Nov 2024 11:34:58 +0100 Subject: [PATCH] Add unit test for EXTCODECOPY of delegated account --- .../state_transition_eip7702_test.cpp | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/test/unittests/state_transition_eip7702_test.cpp b/test/unittests/state_transition_eip7702_test.cpp index ccacdddb1..c98b81d77 100644 --- a/test/unittests/state_transition_eip7702_test.cpp +++ b/test/unittests/state_transition_eip7702_test.cpp @@ -92,6 +92,24 @@ TEST_F(state_transition, eip7702_extcodehash_delegation_to_empty) expect.post[To].storage[0x01_bytes32] = 0x01_bytes32; } +TEST_F(state_transition, eip7702_extcodecopy) +{ + rev = EVMC_PRAGUE; + + constexpr auto callee = 0xca11ee_address; + constexpr auto delegate = 0xde1e_address; + pre[callee] = {.nonce = 1, .code = bytes{0xef, 0x01, 0x00} + hex(delegate)}; + tx.to = To; + pre[To] = {.code = push(10) + push0() + push0() + push(callee) + OP_EXTCODECOPY + + sstore(0, mload(0)) + sstore(1, 1)}; + + expect.post[callee].exists = true; + expect.post[delegate].exists = false; + expect.post[To].storage[0x00_bytes32] = + 0xef01000000000000000000000000000000000000000000000000000000000000_bytes32; + expect.post[To].storage[0x01_bytes32] = 0x01_bytes32; +} + TEST_F(state_transition, eip7702_call) { rev = EVMC_PRAGUE;