Setup Helpers
These contracts were created with the intention of speeding up the setup process for an invariant testing suite.
For an example implementation of these contracts in use see the create-chimera-app repo.
ActorManager
The ActorManager
contract serves as the source of truth for actors that are being used in the fuzzing suite setup.
The primary functions of interest when setting up a suite are:
_addActor
- allows adding a new address as an actor that can be tracked_switchActor
- this should be exposed in a target function that can be called by the fuzzer to randomly switch between actors
To use the actors stored in the ActorManager, add the asActor
modifier on all of your target function handlers which pranks as the currently set actor.
For privileged functions you can use the asAdmin
modifier which calls the target functions as the tester contract (address(this)
). The tester contract is typically set as the default admin address by convention.
AssetManager
The AssetManager
allows tracking all assets being used in the fuzz suite setup.
Similar to the ActorManager
this serves as the source of truth for all assets used in the test suite and therefore no target function should be called that may transfer an asset not tracked in the AssetManager
.
The primary functions of interest when setting up a suite are:
_newAsset
- deploys an instance of theMockERC20
contract and adds it to tracking so it can be accessed as needed_getAsset
- used to clamp values used for tokens in calls to target functions_finalizeAssetDeployment
- a utility for minting tokens added via_newAsset
to all actors that have been setup and approving it to all contracts in the the system that may need to calltransferFrom
on it
Utils
Provides utilities for invariant testing
checkError
- allows checking if a revert reason from a function call is equivalent to the reason passed in as theexpected
argument
Panic
A library that provides named variables corresponding to compiler panic messages. Used to more easily access these messages when using the checkError
utility.
library Panic {
// compiler panics
string constant assertionPanic = "Panic(1)";
string constant arithmeticPanic = "Panic(17)";
string constant divisionPanic = "Panic(18)";
string constant enumPanic = "Panic(33)";
string constant arrayPanic = "Panic(34)";
string constant emptyArrayPanic = "Panic(49)";
string constant outOfBoundsPanic = "Panic(50)";
string constant memoryPanic = "Panic(65)";
string constant functionPanic = "Panic(81)";
}
MockERC20
A minimal MockERC20
contract that lets you mock any standard ERC20 tokens that will be interacting with the system without requiring external dependencies.