Skip to content
This repository has been archived by the owner on Jul 5, 2024. It is now read-only.

Commit

Permalink
fix type checking
Browse files Browse the repository at this point in the history
  • Loading branch information
KimiWu123 committed Nov 26, 2023
1 parent ff68c72 commit 3e0320e
Show file tree
Hide file tree
Showing 11 changed files with 32 additions and 33 deletions.
4 changes: 2 additions & 2 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -30,9 +30,9 @@ where = src

[options.extras_require]
test =
pytest == 7.0.0
pytest == 7.4.3
lint =
black == 23.10
black == 23.10.1
mypy == 1.6.1
flake8 == 6.1.0

Expand Down
1 change: 0 additions & 1 deletion src/zkevm_specs/evm_circuit/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,3 @@
from .table import *
from .typing import *
from .util import *
from .precompile import *
2 changes: 1 addition & 1 deletion src/zkevm_specs/evm_circuit/instruction.py
Original file line number Diff line number Diff line change
Expand Up @@ -255,7 +255,7 @@ def constrain_step_state_transition(self, **kwargs: Transition):
)
elif transition.kind == TransitionKind.ToWord:
curr, next = cast(Word, curr), cast(Word, next)
# mypy gets confused here and thinkgs value must be FQ.
# mypy gets confused here and thinks value must be FQ.
value = cast(Word, transition.value) # type: ignore
assert next.lo.expr() == value.lo.expr() and next.hi.expr() == value.hi.expr(), ConstraintUnsatFailure( # type: ignore
f"State {key} should transit to {transition.value}, but got {next}"
Expand Down
5 changes: 3 additions & 2 deletions src/zkevm_specs/evm_circuit/typing.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
U256,
FQ,
IntOrFQ,
IntOrFQOrWord,
RLC,
WordOrValue,
Word,
Expand Down Expand Up @@ -1010,9 +1011,9 @@ def copy(
self,
r: FQ,
rw_dict: RWDictionary,
src_id: IntOrFQ,
src_id: IntOrFQOrWord,
src_tag: CopyDataTypeTag,
dst_id: IntOrFQ,
dst_id: IntOrFQOrWord,
dst_tag: CopyDataTypeTag,
src_addr: IntOrFQ,
src_addr_end: IntOrFQ,
Expand Down
3 changes: 3 additions & 0 deletions src/zkevm_specs/util/arithmetic.py
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,9 @@ def __repr__(self) -> str:
return f"Value({hex(self.lo.expr().n)})"


IntOrFQOrWord = Union[int, FQ, Word]


@runtime_checkable
class Expression(Protocol):
def expr(self) -> FQ:
Expand Down
8 changes: 4 additions & 4 deletions tests/evm/test_create.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@
GAS_COST_CREATE,
GAS_COST_INITCODE_WORD,
)
from zkevm_specs.util import Word
from zkevm_specs.util.typing import U256
from zkevm_specs.util import Word, U160, U256


CreateContext = namedtuple(
"CreateContext",
Expand All @@ -47,7 +47,7 @@
)


CALLER = Account(address=0xFE, balance=int(1e20), nonce=10)
CALLER = Account(address=U160(0xFE), balance=U256(int(1e20)), nonce=U256(10))


def gen_bytecode(is_return: bool, offset: int, has_init_code: bool) -> Bytecode:
Expand Down Expand Up @@ -340,7 +340,7 @@ def test_create_create2(
stack.offset + stack.size,
0,
stack.size,
src_data,
src_data, # type: ignore[arg-type]
)

# caller's call context
Expand Down
11 changes: 5 additions & 6 deletions tests/evm/test_memory.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,10 @@
Opcode,
verify_steps,
Tables,
Block,
Bytecode,
RWDictionary,
)
from zkevm_specs.util import Word
from zkevm_specs.util import Word, U64
from common import memory_expansion

TESTING_DATA = (
Expand Down Expand Up @@ -58,7 +57,7 @@ def test_memory(opcode: Opcode, offset: int, value: int, memory: bytes):
offset_word = Word(offset)
value_word = Word(value)
call_id = 1
curr_memory_word_size = 0
curr_memory_word_size = U64(0)
length = offset

is_mload = opcode == Opcode.MLOAD
Expand Down Expand Up @@ -95,15 +94,15 @@ def test_memory(opcode: Opcode, offset: int, value: int, memory: bytes):
rw_dictionary.memory_write(call_id, offset + idx, memory[idx])

tables = Tables(
block_table=set(Block().table_assignments()),
block_table=set(),
tx_table=set(),
withdrawal_table=set(),
bytecode_table=set(bytecode.table_assignments()),
rw_table=rw_dictionary.rws,
rw_table=set(rw_dictionary.rws),
)

address = offset + 1 + (is_not_mstore8 * 31)
next_mem_size, memory_gas_cost = memory_expansion(curr_memory_word_size, address)
next_mem_size, memory_gas_cost = memory_expansion(curr_memory_word_size, U64(address))
gas = Opcode.MLOAD.constant_gas_cost() + memory_gas_cost

rw_counter = 35 - (is_mstore8 * 31)
Expand Down
8 changes: 3 additions & 5 deletions tests/evm/test_not.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
StepState,
verify_steps,
Tables,
Block,
Bytecode,
RWDictionary,
)
Expand All @@ -26,17 +25,16 @@
@pytest.mark.parametrize("a", NOT_TESTING_DATA)
def test_not(a: int):
b = Word(a ^ ((1 << 256) - 1))
a = Word(a)

bytecode = Bytecode().not_(a).stop()
bytecode = Bytecode().not_(Word(a)).stop()
bytecode_hash = Word(bytecode.hash())

tables = Tables(
block_table=set(Block().table_assignments()),
block_table=set(),
tx_table=set(),
withdrawal_table=set(),
bytecode_table=set(bytecode.table_assignments()),
rw_table=set(RWDictionary(9).stack_read(1, 1023, a).stack_write(1, 1023, b).rws),
rw_table=set(RWDictionary(9).stack_read(1, 1023, Word(a)).stack_write(1, 1023, b).rws),
)

verify_steps(
Expand Down
12 changes: 4 additions & 8 deletions tests/evm/test_sar.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,11 +72,7 @@
def test_sar(shift: int, a: int):
b = get_int_neg(-(-get_int_abs(a) >> shift)) if int_is_neg(a) else a >> shift

shift = Word(shift)
a = Word(a)
b = Word(b)

bytecode = Bytecode().sar(shift, a)
bytecode = Bytecode().sar(shift, Word(a))
bytecode_hash = Word(bytecode.hash())

tables = Tables(
Expand All @@ -86,9 +82,9 @@ def test_sar(shift: int, a: int):
bytecode_table=set(bytecode.table_assignments()),
rw_table=set(
RWDictionary(9)
.stack_read(1, 1022, shift)
.stack_read(1, 1023, a)
.stack_write(1, 1023, b)
.stack_read(1, 1022, Word(shift))
.stack_read(1, 1023, Word(a))
.stack_write(1, 1023, Word(b))
.rws
),
)
Expand Down
2 changes: 1 addition & 1 deletion tests/evm/test_sha3.py
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ def test_sha3(offset: U64, length: U64):
offset + length,
FQ.zero(),
length,
src_data,
src_data, # type: ignore[arg-type]
)
assert rw_dictionary.rw_counter - rw_counter_interim == length

Expand Down
9 changes: 6 additions & 3 deletions tests/evm/test_sstore.py
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,9 @@ def test_sstore(
else:
gas_refund = gas_refund + SSTORE_RESET_GAS - SLOAD_GAS

# workaround for mypy, it yells incompatible type
# bcs the type of callee_address is Optional[U160]
callee_addr = tx.callee_address or 0
tables = Tables(
block_table=set(Block().table_assignments()),
tx_table=set(tx.table_assignments()),
Expand All @@ -140,11 +143,11 @@ def test_sstore(
.call_context_read(1, CallContextFieldTag.IsStatic, 0)
.call_context_read(1, CallContextFieldTag.RwCounterEndOfReversion, 0 if is_success else 14)
.call_context_read(1, CallContextFieldTag.IsPersistent, is_success)
.call_context_read(1, CallContextFieldTag.CalleeAddress, Word(tx.callee_address))
.call_context_read(1, CallContextFieldTag.CalleeAddress, Word(callee_addr))
.stack_read(1, 1022, Word(storage_key))
.stack_read(1, 1023, Word(value))
.account_storage_write(tx.callee_address, Word(storage_key), Word(value), Word(value_prev), tx.id, Word(value_committed), rw_counter_of_reversion=None if is_success else 14)
.tx_access_list_account_storage_write(tx.id, tx.callee_address, Word(storage_key), True, True if warm else False, rw_counter_of_reversion=None if is_success else 13)
.account_storage_write(callee_addr, Word(storage_key), Word(value), Word(value_prev), tx.id, Word(value_committed), rw_counter_of_reversion=None if is_success else 14)
.tx_access_list_account_storage_write(tx.id, callee_addr, Word(storage_key), True, True if warm else False, rw_counter_of_reversion=None if is_success else 13)
.tx_refund_write(tx.id, gas_refund, gas_refund_prev, rw_counter_of_reversion=None if is_success else 12)
.rws
# fmt: on
Expand Down

0 comments on commit 3e0320e

Please sign in to comment.