Skip to content
This repository has been archived by the owner on Jan 9, 2025. It is now read-only.

Commit

Permalink
fuzz test values
Browse files Browse the repository at this point in the history
  • Loading branch information
enitrat committed Nov 25, 2024
1 parent 0ec3e89 commit 1a628f6
Showing 1 changed file with 7 additions and 10 deletions.
17 changes: 7 additions & 10 deletions cairo_zero/tests/src/kakarot/accounts/test_account_contract.py
Original file line number Diff line number Diff line change
Expand Up @@ -307,25 +307,22 @@ def test_should_raise_with_wrong_signature(self, cairo_run):
chain_id=CHAIN_ID,
)

def test_should_raise_with_malleable_signature_eip_2(self, cairo_run):
# EIP-2: one can take any transaction, flip the s value from s to secp256k1n -
# s, flip the v value (27 -> 28, 28 -> 27), and the resulting signature would still be
# valid.
@given(s_value=integers(min_value=SECP256K1N // 2 + 1, max_value=SECP256K1N))
def test_should_raise_with_high_s_values(self, cairo_run, s_value):
"""Test that signatures with s values > secp256k1n/2 are rejected (EIP-2)."""
transaction = TRANSACTIONS[0]
private_key = generate_random_private_key()
address = int(private_key.public_key.to_checksum_address(), 16)
signed = Account.sign_transaction(transaction, private_key)

# Modify s and flip v to generate a malleable signature
s_modified = SECP256K1N - signed.s
y_parity = signed.v - 2 * CHAIN_ID - 35
v_modified = signed.v + 1 if y_parity == 0 else signed.v - 1
# Override the s value with our test value while keeping r and v
signature = [
*int_to_uint256(signed.r),
*int_to_uint256(s_modified),
v_modified,
*int_to_uint256(s_value),
signed.v,
]
tx_data = list(rlp_encode_signed_data(transaction))

with (
cairo_error(message="Invalid s value"),
SyscallHandler.patch("Account_evm_address", address),
Expand Down

0 comments on commit 1a628f6

Please sign in to comment.