Each test function is ran as if it were the entry point for a
script . Tests "pass" if they return
successfully, and "fail" if they revert or vice versa while testing failure .
If the project has failing tests forc test will exit with exit status 101.
To test the test_function(), a unit test like the following can be written.
#[test]fntest_success() {let caller =abi(MyContract, CONTRACT_ID);let result = caller.test_function {}();assert(result ==true)}
It is also possible to test failure with contract calls as well.
#[test(should_revert)]fntest_fail() {let caller =abi(MyContract, CONTRACT_ID);let result = caller.test_function {}();assert(result ==false)}
Icon InfoCircle
Note: When running forc test, your contract will be built twice: first without unit tests in order to determine the contract's ID, then a second time with unit tests with the CONTRACT_ID provided to their namespace. This CONTRACT_ID can be used with the abi cast to enable contract calls within unit tests.
Unit tests can call methods of external contracts if those contracts are added as contract dependencies, i.e. in the contract-dependencies section of the manifest file. An example of such calls is shown below:
By default, all unit tests in your project are run in parallel. Note that this does not lead to any data races in storage because each unit test has its own storage space that is not shared by any other unit test.
By default, forc test will use all the available threads in your system. To request that a specific number of threads be used, the flag --test-threads <val> can be provided to forc test.