包详细信息

@defi-wonderland/smock

defi-wonderland56.4kMIT不推荐使用2.4.1

Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.

The Solidity mocking library

ethereum, smart-contracts, test, solidity

自述文件

image

image



⚠️ DEPRECATED – DO NOT USE

This repository is no longer maintained and is deprecated.

It may contain outdated, insecure, or vulnerable code and should not be used in production or as a dependency in any project.

The repository is retained solely for historical reference. No support, updates, or security patches will be provided.

Soft-deprecation notice

Smock has had a fruitful life, and its legacy lives on smock-foundry, a re-implementation for foundry which we now use exclusively as a side-effect of using foundry for all new projects.

We won't migrate the project to newer versions of peer dependencies, as specified in #201

Overview

Smock is the Solidity mocking 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:

npm install @defi-wonderland/smock

Note: Starting from v2.4.0, Smock is only compatible with Hardhat v2.21.0 or later. If you are using an older version of Hardhat, please install Smock v2.3.5.

Basic Usage

Smock is dead simple to use. Here's a basic example of how you might use it to streamline your tests.

...
import { FakeContract, smock } from '@defi-wonderland/smock';

chai.should(); // if you like should syntax
chai.use(smock.matchers);

describe('MyContract', () => {
    let myContractFake: FakeContract<MyContract>;

    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.

更新日志

Changelog

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

2.3.4 (2022-11-07)

Bug Fixes

2.3.3 (2022-10-21)

2.3.1 (2022-09-28)

Features

Bug Fixes

2.3.0 (2022-09-08)

Features

Bug Fixes

2.2.0 (2022-07-12)

Features

  • add getVariable function (ce79653)
  • add getVariable function (ebdd00a)
  • return hardhat errors on factory failures (#125) (3b626a3)

Bug Fixes

2.1.1 (2022-07-07)

Features

  • return hardhat errors on factory failures (#125) (3b626a3)

Bug Fixes

2.1.0 (2022-06-24)

Features

Bug Fixes

2.0.7 (2021-09-30)

Features

Bug Fixes

  • add call signature to programmable functions (#82) (277378d)
  • allow mocks to override reverting functions (#84) (7b6894b)
  • correctly export assertion types (#66) (3de6f3d)
  • have connect function return mock factory (#67) (a8814fd)
  • make sure connect returns the correct factory instance (#75) (43dbc00)
  • move ethereumjs-vm into deps (#74) (5d8d664)

2.0.5 (2021-09-21)

Features

Bug Fixes

  • correctly export assertion types (#66) (3de6f3d)
  • have connect function return mock factory (#67) (a8814fd)
  • make sure connect returns the correct factory instance (#75) (43dbc00)
  • move ethereumjs-vm into deps (#74) (5d8d664)

2.0.4 (2021-09-15)

Features

Bug Fixes

  • correctly export assertion types (#66) (3de6f3d)

2.0.3 (2021-09-07)

Features

Bug Fixes

2.0.1 (2021-08-10)

Features

Bug Fixes

2.0.0 (2021-08-09)

Features

2.0.0-rc.1 (2021-08-09)

Features

  • setVariable for ints supported (37259d6)

2.0.0-rc.0 (2021-08-09)

⚠ BREAKING CHANGES

  • making this in order to make a rc of 2.0.0

Features

  • refactor storage editing logic (f95f236)

Bug Fixes

1.0.0 (2021-07-25)

1.0.0-rc.0 (2021-07-25)

Features

  • mocks can now edit internal variables (#7) (c4bfac6)

0.0.4-rc.0 (2021-07-25)

0.0.3 (2021-07-23)

Features

0.0.2 (2021-07-22)

0.0.1 (2021-07-22)

Features

0.0.1-rc.3 (2021-07-22)

0.0.1-rc.2 (2021-07-22)

Features

  • added getCall to watchable fns (5ff6598)

0.0.1-rc.1 (2021-07-22)

Features

0.0.1-rc.0 (2021-07-22)

Features