- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.2k
chore(deps): bump revm 30+, alloy-evm, revm-inspectors #12094
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
Conversation
d636673    to
    ebcd477      
    Compare
  
    | call.input.bytes(ecx).get(..4).and_then(|selector| mocks.get(selector)) | ||
| }) { | ||
| call.bytecode_address = *target; | ||
| call.known_bytecode = None; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If not reset to None old bytecode is loaded by hash rather than from the set target the line above
known_bytecode is a new field introduced in revm 30
| let is_out_of_gas = matches!( | ||
| ctx.step.status, | ||
| Some( | ||
| InstructionResult::OutOfGas | ||
| | InstructionResult::MemoryOOG | ||
| | InstructionResult::MemoryLimitOOG | ||
| | InstructionResult::PrecompileOOG | ||
| | InstructionResult::InvalidOperandOOG | ||
| ) | ||
| ); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
small optimization to avoid branching
| let depth = node.trace.depth as u64 + 1; | ||
| let contract_addr = node.execution_address(); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Per paradigmxyz/revm-inspectors#354 the depth and contract fields are no longer included and expected to be collected in the context of the steps' CallTrace.
The +1 fixes an index mismatch causing the a test failure on testDebugTraceCanRecordDepth.
I believe this fix and implementation is correct but please double check this @DaniPopes
The +1 was inspired by a follow-up fix added here: paradigmxyz/revm-inspectors#369 by @klkvr
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
you should store ref to the node and the step, and retrieve depth and such later
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
addressed in 74d36ad
The +1 still appears to be necessary, not exactly clear to me why.
| 
 After discussion we decided that no change is required on our side in regards to  Looking into panic in external test suite. | 
…k is done at setup, we need to ensure when the test is ran the "from" account remains in scope
| // Ensure new caller is loaded and touched | ||
| let _ = journaled_account(ecx, prank.new_caller); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This fixes a regression introduced in revm 30 where it now assumes the "from" account in a transfer is always loaded. We were experiencing a panic if startPrank was applied in the setup and then a value transfer happened in a test.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can you pls check startBroadcast too, see #11650 and if possible add a unit test?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added in cb2aae6, is think this is what you are looking for
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
just a note that we touch account now twice, when calling cheatcode and here when we apply prank
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
good catch, looking at the code this should effectively be a noop but still good to be aware
| Pending final reviews @DaniPopes & @grandizzy | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm! left a comment, not sure if we should take any cleanup action. pending @DaniPopes review
| // Ensure new caller is loaded and touched | ||
| let _ = journaled_account(ecx, prank.new_caller); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
just a note that we touch account now twice, when calling cheatcode and here when we apply prank
Motivation
Closes: #12075
Solution
Bumps to latest
revm,alloy-evm&revm-inspectorsincluding requested API changesSee inline callouts for additional context
Breaking changes
TraceArenano longer includes thedepthandcontractAddrin the step trace, ref: chore: Remove depth and contract fields from CallTraceStep paradigmxyz/revm-inspectors#355. In turn theDebugStepstruct no longer includes these fields when callingvm.stopAndReturnDebugTraceRecordingas these values are constant throughout a single call depth. At the top-level thedepthis now included.PR Checklist