.. image:: https://img.shields.io/npm/v/@defi-wonderland/smock.svg?style=flat-square
:target: https://www.npmjs.org/package/@defi-wonderland/smock
.. image:: https://badgen.net/badge/icon/discord?icon=discord&label
:target: https://discord.com/invite/22RQcJjau9
.. raw:: html
**Smock** is the **S**\ olidity **mock**\ ing library.
It's a plugin for `hardhat `_ that can be used to create mock Solidity contracts entirely in JavaScript (or TypeScript!).
With Smock, it's easier than ever to test your smart contracts.
You'll never have to write another mock contract in Solidity again.
Smock is inspired by `sinon `_, `sinon-chai `_, and Python's `unittest.mock `_.
Although Smock is currently only compatible with `hardhat `_, we plan to extend support to other testing frameworks like `Truffle `_.
If you wanna chat about the future of Solidity Mocking, join our `Discord `_!
Features
--------
* Get rid of your folder of "mock" contracts and **just use JavaScript**.
* Keep your tests **simple** with a sweet set of chai matchers.
* Fully compatible with TypeScript and TypeChain.
* Manipulate the behavior of functions on the fly with **fakes**.
* Modify functions and internal variables of a real contract with **mocks**.
* Make **assertions** about calls, call arguments, and call counts.
* We've got extensive documentation and a complete test suite.
Documentation
-------------
Detailed documentation can be found `here `_.
Quick Start
-----------
Installation
************
You can install Smock via npm or yarn:
.. code-block:: console
npm install @defi-wonderland/smock
Basic Usage
***********
Smock is dead simple to use.
Here's a basic example of how you might use it to streamline your tests.
.. code-block:: typescript
...
import { FakeContract, smock } from '@defi-wonderland/smock';
chai.should(); // if you like should syntax
chai.use(smock.matchers);
describe('MyContract', () => {
let myContractFake: FakeContract;
beforeEach(async () => {
...
myContractFake = await smock.fake('MyContract');
});
it('some test', () => {
myContractFake.bark.returns('woof');
...
myContractFake.bark.atCall(0).should.be.calledWith('Hello World');
});
});
License
-------
Smock is released under the MIT license.
Feel free to use, modify, and/or redistribute this software as you see fit.
See the `LICENSE `_ file for more information.
Contributors
------------
Maintained with love by `Optimism PBC `_ and `DeFi Wonderland `_.
Made possible by viewers like you.