Formally Verifying MetaMorpho with Certora
MetaMorpho is an open-source, immutable, heavily audited code base that has now also been formally verified using Certora .
Formal verification is a staple of Morpho's security framework . Not long ago, we shared the formal verification of Morpho Blue , and today, we are doing the same for MetaMorpho.
Used effectively, formal verification can help develop higher quality and, most importantly, more secure smart contracts. That is why Morpho Labs has invested significant time and resources into formally verifying Morpho Blue and now MetaMorpho.
This article recaps the benefits of formal verification and provides examples of MetaMorpho verification using CVL, Certora's Verification Language.
The full scope of MetaMorpho's formal verification is available here .
Why Formal Verification
Formal verification is the process of using mathematical methods to prove the correctness of a smart contract by verifying that it satisfies specific properties. These properties are expressed using formal language supported by the verification tool used to prove them.
Formal verification stands out due to its exhaustive approach to evaluating software correctness. Other methods, such as unit testing , can only verify correctness for specific scenarios or inputs, whereas formal verification enables checking every possible scenario or input.
Despite its capabilities, it is worth noting that formal verification is still only one part of Morpho’s comprehensive security framework .
Now, to look at formal verification in practice, using real examples from the repo .
Example 1: Roles
MetaMorpho defines different roles to be able to manage the vault, the distinction between roles helps in reducing trust assumptions.
Roles follow a hierarchy, and this hierarchy is verified to hold in [ Roles.spec ]. More precisely, a senior role is checked to be able to do the same operations as a lesser role. Additionally, it is verified in [Reverts.spec] that the roles are necessary to be able to do permissioned operations.
For example, the following rule makes sure that having the guardian role is necessary to be able to revoke a pending timelock:
The rule is verified using the Certora prover in seconds:
Example 2: Timelock
MetaMorpho features a timelock mechanism that applies to every operation that could potentially increase risk for users. The following function defined in [ PendingValues.spec ] is verified to always return true.
In the end, the verification is completed by the Certora prover within a few minutes:
Notice how increasing the timelock itself is not subject to a timelock, as it does not increase the risk for the user. A greater timelock means that the user would have more time to react to the vault's management operations that would not align with the user risk profile.
Example 3: Liveness
The liveness properties ensure that some crucial actions cannot be blocked. It is notably useful to show that in case of an emergency, it is still possible to make salvaging transactions. The canPauseSupply rule in [ Liveness.spec ] shows that it is always possible to prevent new deposits. This is done by first setting the supply queue as the empty queue and checking that it does not revert.
With this defined, the verification is successful:
These are only some examples of MetaMorpho’s verification. Find the full scope here .
Limitations
Despite the thoroughness of formal verification, it cannot guarantee absolute perfection or eliminate all potential risks associated with MetaMorpho.
Formal verification is effective within the defined scope of specifications and assumptions. Human input and interpretation, incomplete specifications, and bugs in the tools used can also impact the accuracy of results.
Disclaimer: The content of this article solely reflects the author's opinion and does not represent the platform in any capacity. This article is not intended to serve as a reference for making investment decisions.
You may also like
Bitcoin (BTC) Surges to New ATH Amidst Declining Sell-Side Pressure
Bitcoin reaches a new all-time high of $109k after months of consolidation. Analysis reveals diminishing sell-side pressure and signals of potential market volatility, according to Glassnode.
Ethereum Initiates $2 Million Academic Grants for 2025
Ethereum Foundation launches the 2025 Academic Grants Round, offering $2 million to support innovative research in Ethereum-related fields.
Chartist Spots Bullish Pattern for this Altcoin Priced at $0.07 Following the TRUMP Memecoin Debut
John Deaton Outlines Four Key Objectives For White House Crypto Council