Test and benchmark Plutus Smart Contracts. This project enables you to construct entire smart contract transactions against a mock environment, and measure the correctness (i.e. unit test) and performance of your smart contracts.
Plutus Bench creates a mock ledger with an arbitrary UTxO set specified by the user. It then hosts a mock blockfrost API to interact with the ledger, supporting popular off-chain tooling like translucent and pycardano.
Note: Plutus Bench is currently a Work In Progress, and is not yet ready for production use.
- Compatability: Plutus Bench is written in Python, and is compatible with popular off-chain tooling relying on BlockFrost APIs. Ogmios mocking is also planned.
- Holistic Testing: Plutus Bench allows you to test the entire lifecycle of a smart contract, from minting to consuming, in a single test.
- Simple: Plutus Bench is designed to be simple to use, and easy to integrate with your existing infrastructure.
# install the plutus-bench package
git clone https://github.com/OpShin/plutus-bench.git
cd plutus-bench
# install the package
pip install .
# run the mock server
uvicorn plutus_bench.mockfrost.server:app
After running these commands, a mock blockfrost server will be running on http://localhost:8000
.
Head to http://localhost:8000/docs
to see the API documentation.
Generally the workflow is as follows:
- Create a new session with the
/session/create
endpoint. You receive a session ID. - Initialize a BlockFrost client in your off-chain code, and point it to the mock server. The base url is
http://localhost:8000/<session-id>/api/v1
. Project id is not required.
That's it! You can now interact with the mock ledger using the BlockFrost client.
You may further manipulate the ledger using the /<session-id>/ledger
endpoints.
- lucid transaction emulator - Allows emulation of transactions on the Cardano blockchain. Only supports JavaScript and TypeScript.
- helios transaction emulator - Allows emulation of transactions on the Cardano blockchain. Only supports JavaScript and TypeScript.
- plutus simple model - Allows evaluating Plutus smart contracts. Only supports Haskell.
The language comparison has been moved to contest. It is planned to expand to cover different implementations of the same contract in different languages and the same language, tailored for performance optimizations.