Speed up development and boost team productivity with Virtual TestNets. Get started!

Exploring a way to support Move VM-based chains.
Back to Internship Program

Aptos / Move VM Integration

Objective

Tenderly infrastructure is centred around EVM, and as such we only support chains that are based around EVM. Goal of this project is to explore and research a way into supporting chains that are not EVM-based, on the example of the Aptos chain and the Move VM on which it runs.


Scope of Work

Goals:

* Understanding the internal workings of EVM and MVM-based chains.

* Implementing and validating a PoC implementation that can execute on-chain or simulated Aptos transactions, and produce the state changes.

* Stretch goal: Defining and implementing key-value based storage layout for MVM state.

Non-goals:

* Extracting any source-level information (contract verification, debugger, …)

* Integrating anything into `tenderly-core` proper


Tasks

1. Understanding EVM and MVM execution and their differences

Expected outcome: analysis of how EVM works and interacts with the environment, and how that differs to MVM (block format, transaction format, system transactions, gas, state layout, instructions, stack, RPC, …)

Estimated time: 1-2 weeks

2. Implementing an execution environment for executing MVM transactions

Expected outcome: A PoC that can execute on-chain or simulated transactions, given a node API.

Estimated time: 3-4 weeks

3. Implementing block state and validating execution correctness

Expected outcome: proving the execution is correct, by executing the Aptos chain and validating produced state diffs. If some parts of the execution are impossible to replicate, identify if we can implement it differently (e.g. read it from node directly).

Estimated time: 2-3 weeks

4. Implementing an opcode-level logger

Expected outcome: adding the ability to externally observe the internal workings of the MVM by providing opcode hooks (and optionally call entry/exit hooks), with the information required to replicate the tracing functionality of `EVMLogger` from Geth.

Estimated time: 1 week

5. (Optional) Implementing a key-value based storage for MVM state

Expected outcome: defining how to store and retrieve MVM state in a manner compatible to an ordered key-value storage we use for storing EVM state, and implementing a PoC storage implementation.

Estimated time: 2 weeks


Prerequisites

* Rust language (or similar)

* Knowledge of low-level system design (e.g. computer architecture, OS, virtual machines, …)


Ready to Push Boundaries?

Join us in extending Tenderly's infrastructure to support non-EVM blockchains.

Apply Now