Unit tests allow you to test the contract methods individually. They are suitable to check the storage is updated correctly, and that methods return their expected values. They are written in the contract’s language and execute locally. If you used one of our examples as template, then you simply need to navigate to the contract’s folder, and useDocumentation Index
Fetch the complete documentation index at: https://docs.near.org/llms.txt
Use this file to discover all available pages before exploring further.
yarn test. In case you didn’t, then we recommend you copy the necessary node files (e.g. package.json) from one of our templates.
Snippet I: Testing a Counter
The tests in the Counter Example rely on basic functions to check that theincrement, decrement, and reset methods work properly.
Snippet II: Modifying the Context
While doing unit testing you can modify the Environment variables through theVMContextBuilder. This will enable you to, for example, simulate calls from different users, with specific attached deposit and GAS. Here we present a snippet on how we test the donate method from our Donation Example by manipulating the predecessor and attached_deposit.
⚠️ Limitations
Unit tests are useful to check for code integrity, and detect basic errors on isolated methods. However, since unit tests do not run on a blockchain, there are many things which they cannot detect. Unit tests are not suitable for:- Testing gas and storage usage
- Testing transfers
- Testing cross-contract calls
- Testing complex interactions, i.e. multiple users depositing money on the contract