Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ndev 2981 trace call overrides params #327

Open
wants to merge 43 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
e941a0e
add case to check stateOverrides nonce
romanova-natasha May 6, 2024
1ddb225
add dbg prints and run only one test
romanova-natasha May 6, 2024
d65c8e0
Merge branch 'develop' into NDEV-2981-traceCall-overrides-param
romanova-natasha May 7, 2024
fa8edd6
mv tests to new file, add cases for stateOverride check
romanova-natasha May 8, 2024
0ba594b
add cases for stateOverride check
romanova-natasha May 8, 2024
77f12c9
rm dbg
romanova-natasha May 8, 2024
ff3e9e1
link bugs to tests and skip these cases
romanova-natasha May 8, 2024
ade1a82
add blockOverride case using debug_traceCall request
romanova-natasha May 9, 2024
df78a65
Merge branch 'run-specific-test' into NDEV-2981-traceCall-overrides-p…
romanova-natasha May 10, 2024
00b1140
Merge branch 'run-specific-test' into NDEV-2981-traceCall-overrides-p…
romanova-natasha May 10, 2024
defad66
add case with blockOverrides for debug_traceCall method
romanova-natasha May 10, 2024
e24d8eb
add comment to test_stateOverrides_eth_call_override_code case
romanova-natasha May 10, 2024
796d273
minor refactoring
romanova-natasha May 10, 2024
787e74c
add negative cases to override params suite, minor refactoring, add c…
romanova-natasha May 10, 2024
e5df8b6
add cases for blockOverrides with time parameter
romanova-natasha May 10, 2024
bf757c4
add negative cases for stateDiff param
romanova-natasha May 10, 2024
9721b9e
add cases for stateOverride nonce, balance
romanova-natasha May 10, 2024
5d887bb
add cases for stateOverride code parameter
romanova-natasha May 10, 2024
17321d9
enable stateDiff cases which were fixed
romanova-natasha May 10, 2024
23f2e86
fix stateOverride balance tests, add a negative case: insufficient ba…
romanova-natasha May 11, 2024
8212775
add blockOverrides time and number case, minor refactoring, add case …
romanova-natasha May 13, 2024
e6be41d
add case: stateOverrides and blockOverrides in one requests, add case…
romanova-natasha May 13, 2024
403113e
refactoring of debug_methods suite according to the recent changes
romanova-natasha May 13, 2024
6ffeb7e
add stateOverride cases for state param
romanova-natasha May 14, 2024
e3c30a4
fix tests stateOverrides with code param: add check of trace with ove…
romanova-natasha May 14, 2024
a9c1620
add contract function with retrieving sender balance, check balance i…
romanova-natasha May 14, 2024
0172479
fix: add make_raw_tx where it is nedeed
romanova-natasha May 14, 2024
355a9f5
add function: fill params for prestateTracer call
romanova-natasha May 14, 2024
8d8ba5a
mv storage contract to separate class
romanova-natasha May 14, 2024
8958546
fix review
romanova-natasha May 14, 2024
18f5763
fix review: do not wait transaction
romanova-natasha May 14, 2024
73a41c8
add case for stateDiff: check storage with 2 indixes
romanova-natasha May 15, 2024
26f4869
rm code field from state and stateDiff requests
romanova-natasha May 15, 2024
2db27a7
fix state/stateDiff param format: should be hex string 32 bytes
romanova-natasha May 15, 2024
2cd746a
fix state/stateDiff param format: should be hex string 32 bytes
romanova-natasha May 15, 2024
6fba2c5
fix blockOverrides: add is_tx_block flag to control block number in r…
romanova-natasha May 15, 2024
37aca39
fix stateDiff cases
romanova-natasha May 17, 2024
ecc79a1
rm dbg info
romanova-natasha May 17, 2024
25b3ca6
fix state cases
romanova-natasha May 17, 2024
edf0c62
Merge remote-tracking branch 'origin/develop' into NDEV-2981-traceCal…
romanova-natasha May 17, 2024
bcd368c
rm wait for get transaction method
romanova-natasha May 22, 2024
3380e11
Merge remote-tracking branch 'origin/develop' into NDEV-2981-traceCal…
romanova-natasha May 23, 2024
6a2e627
rm wait transaction method
romanova-natasha May 23, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
60 changes: 45 additions & 15 deletions contracts/common/StorageSoliditySource.sol
Original file line number Diff line number Diff line change
Expand Up @@ -6,38 +6,68 @@ pragma solidity >=0.4.0;
*/
contract Storage {
uint256 number;
uint256 numberTwo;
uint256 time;
uint256[] public values;

/**
* @dev Stores value in variable
* @param num value to store
*/
function store(uint256 num) public {
number = num;
values = [number];
}

/**
* @dev Returns value
* @return value of 'number'
*/
function retrieve() public view returns (uint256) {
return number;
}

/**
* @dev Returns code for given address
* @return value of '_addr.code'
*/
function retrieveSenderBalance() public view returns (uint256) {
return msg.sender.balance;
}

function storeSumOfNumbers(uint256 num1, uint256 num2) public view returns (uint256) {
if (number == 101) {
num1 = 0;
}
if (numberTwo == 103) {
num2 = 5;
}
return num1 + num2;
}

function at(address _addr) public view returns (bytes memory) {
return _addr.code;
}

function storeBlock() public {
number = block.number;
values = [number];
}

function storeBlockTimestamp() public returns (uint256) {
number = block.timestamp;
values = [number];
return block.timestamp;
}

function storeBlockInfo() public {
number = block.number;
time = block.timestamp;
values = [number, time];
}

function returnDoubledNumber(uint256 num) public view returns (uint256) {
if (number == 102) {
num = 10;
}
return num * 2;
}
}

contract StorageMultipleVars {
string public data = "test";
uint256 constant public number = 1;
uint256 public constant number = 1;
uint256 public notSet;

function setData(string memory _data) public {
function setData(string memory _data) public {
data = _data;
}
}
}
6 changes: 6 additions & 0 deletions integration/tests/tracer/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
from _pytest.config import Config

from utils.tracer_client import TracerClient
from utils.storage_contract import StorageContract


@pytest.fixture(scope="session")
Expand All @@ -16,3 +17,8 @@ def tracer_api(tracer_json_rpc_client_session, request):
if inspect.isclass(request.cls):
request.cls.tracer_api = tracer_json_rpc_client_session
yield tracer_json_rpc_client_session


@pytest.fixture(scope="class")
def storage_object(web3_client, storage_contract):
return StorageContract(web3_client, storage_contract)
926 changes: 926 additions & 0 deletions integration/tests/tracer/test_override_params.py

Large diffs are not rendered by default.

35 changes: 19 additions & 16 deletions integration/tests/tracer/test_tracer_debug_methods.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,13 @@
from utils.web3client import NeonChainWeb3Client
from utils.accounts import EthAccounts
from utils.tracer_client import TracerClient
from integration.tests.tracer.test_tracer_historical_methods import call_storage
from utils.helpers import padhex


SCHEMAS = "./integration/tests/tracer/schemas/"
GOOD_CALLDATA = ["0x60fe60005360016000f3"]


@allure.feature("Tracer API")
@allure.story("Tracer API RPC calls debug methods check")
@pytest.mark.usefixtures("accounts", "web3_client", "tracer_api")
Expand All @@ -37,13 +39,14 @@ def validate_response_result(self, response):
validator = Draft4Validator(schema)
assert validator.is_valid(response["result"])

# NDEV-3009
def test_debug_trace_call_invalid_params(self):
response = self.tracer_api.send_rpc(method="debug_traceCall", params=[{}, "0x0"])
assert "error" in response, "No errors in response"
assert response["error"]["code"] == -32603, "Invalid error code"
assert response["error"]["message"] == "neon_api::trace failed"

def test_debug_trace_call_empty_params_valid_block(self):
def test_debug_trace_call_empty_params_valid_block(self, storage_object):
sender_account = self.accounts[0]
recipient_account = self.accounts[1]
receipt = self.web3_client.send_neon(sender_account, recipient_account, 0.1)
Expand All @@ -63,9 +66,8 @@ def test_debug_trace_call_zero_eth_call(self):
recipient_account = self.accounts[1]
receipt = self.web3_client.send_neon(sender_account, recipient_account, 0.1)
assert receipt["status"] == 1
tx_hash = receipt["transactionHash"].hex()

tx_info = self.web3_client.get_transaction_by_hash(tx_hash)
tx_info = self.web3_client.get_transaction_by_hash(receipt["transactionHash"].hex())

params = [
{
Expand All @@ -85,13 +87,12 @@ def test_debug_trace_call_zero_eth_call(self):
assert response["result"]["returnValue"] == ""
self.validate_response_result(response)

def test_debug_trace_call_non_zero_eth_call(self, storage_contract, web3_client):
def test_debug_trace_call_non_zero_eth_call(self, storage_object):
sender_account = self.accounts[0]
store_value = random.randint(1, 100)
_, _, receipt = call_storage(sender_account, storage_contract, store_value, "blockNumber", web3_client)
tx_hash = receipt["transactionHash"].hex()

tx_info = self.web3_client.get_transaction_by_hash(tx_hash)
_, _, receipt = storage_object.call_storage(sender_account, store_value, "blockNumber")

tx_info = self.web3_client.get_transaction_by_hash(receipt["transactionHash"].hex())

params = [
{
Expand All @@ -107,7 +108,7 @@ def test_debug_trace_call_non_zero_eth_call(self, storage_contract, web3_client)
response = self.tracer_api.send_rpc_and_wait_response("debug_traceCall", params)

assert "error" not in response, "Error in response"
assert 1 <= int(response["result"]["returnValue"], 16) <= 100
assert response["result"]["returnValue"] == padhex(hex(store_value), 64)[2:]
self.validate_response_result(response)

def test_debug_trace_transaction(self):
Expand All @@ -120,24 +121,26 @@ def test_debug_trace_transaction(self):
assert "error" not in response, "Error in response"
self.validate_response_result(response)

def test_debug_trace_transaction_non_zero_trace(self, web3_client, storage_contract):
def test_debug_trace_transaction_non_zero_trace(self, storage_object):
sender_account = self.accounts[0]
store_value = random.randint(1, 100)
_, _, receipt = call_storage(sender_account, storage_contract, store_value, "blockNumber", web3_client)
_, _, receipt = storage_object.call_storage(sender_account, store_value, "blockNumber")

response = self.tracer_api.send_rpc_and_wait_response("debug_traceTransaction", [receipt["transactionHash"].hex()])

assert "error" not in response, "Error in response"
assert 1 <= int(response["result"]["returnValue"], 16) <= 100
assert response["result"]["returnValue"] == padhex(hex(store_value), 64)[2:]
self.validate_response_result(response)

def test_debug_trace_transaction_hash_without_prefix(self, storage_contract, web3_client):
def test_debug_trace_transaction_hash_without_prefix(self, storage_object):
sender_account = self.accounts[0]
store_value = random.randint(1, 100)
_, _, receipt = call_storage(sender_account, storage_contract, store_value, "blockNumber", web3_client)
_, _, receipt = storage_object.call_storage(sender_account, store_value, "blockNumber")

response = self.tracer_api.send_rpc_and_wait_response("debug_traceTransaction", [receipt["transactionHash"].hex()[2:]])

assert "error" not in response, "Error in response"
assert 1 <= int(response["result"]["returnValue"], 16) <= 100
assert response["result"]["returnValue"] == padhex(hex(store_value), 64)[2:]
self.validate_response_result(response)

@pytest.mark.parametrize("hash", [6, "0x0", "", "f23e554"])
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,13 @@
import random

import allure
import pytest
import json

from deepdiff import DeepDiff
from integration.tests.basic.helpers.basic import AccountData
from utils.web3client import NeonChainWeb3Client
from utils.accounts import EthAccounts
from utils.tracer_client import TracerClient
from integration.tests.tracer.test_tracer_historical_methods import call_storage


@allure.feature("Tracer API")
@allure.story("Tracer API RPC calls debug method trace_transaction callTracer check")
Expand Down Expand Up @@ -123,11 +121,11 @@ def test_callTracer_type_create2(self, tracer_caller_contract):
expected_response = self.fill_expected_response(instruction_tx, receipt, calls_value="0x0", calls_type="CREATE2")
self.assert_response_contains_expected(expected_response, response)

def test_callTracer_type_call(self, storage_contract):
def test_callTracer_type_call(self, storage_object):
sender_account = self.accounts[0]
store_value = random.randint(1, 100)

tx_obj, _, receipt = call_storage(sender_account, storage_contract, store_value, "blockNumber", self.web3_client)
tx_obj, _, receipt = storage_object.call_storage(sender_account, store_value, "blockNumber")

tracer_params = { "tracer": "callTracer", "tracerConfig": { "onlyTopCall": True } }
params = [receipt["transactionHash"].hex(), tracer_params]
Expand Down Expand Up @@ -389,11 +387,11 @@ def test_callTracer_call_to_precompiled_contract(self, eip1052_checker):
self.assert_response_contains_expected(expected_response, response)

@pytest.mark.skip(reason="NDEV-2934")
def test_callTracer_without_tracerConfig(self, storage_contract):
def test_callTracer_without_tracerConfig(self, storage_object):
sender_account = self.accounts[0]
store_value = random.randint(1, 100)

tx_obj, _, receipt = call_storage(sender_account, storage_contract, store_value, "blockNumber", self.web3_client)
tx_obj, _, receipt = storage_object.call_storage(sender_account, store_value, "blockNumber")

tracer_params = { "tracer": "callTracer" }
params = [receipt["transactionHash"].hex(), tracer_params]
Expand Down
Loading