Integration tests enable you to deploy a contract in the NEARDocumentation Index
Fetch the complete documentation index at: https://docs.near.org/llms.txt
Use this file to discover all available pages before exploring further.
testnet or a local sandbox and create test users to interact with it. This way, you can thoroughly test your contract in a realistic environment.
Moreover, when using the local sandbox you gain complete control of the network:
- Create test
Accountsand manipulate theirStateandBalance. - Simulate errors on callbacks.
- Control the time-flow and fast-forward into the future (Rust ready, TS coming soon).
near-go CLI:
MockSystem environment to simulate the NEAR blockchain locally — no sandbox required. For full integration tests that deploy to a sandbox, Go contracts use the Rust workspaces-rs framework. See the Go Integration Testing section below.
Sandbox TestingNEAR Sandbox allows you to write tests once, and run them either on
testnet or a local Sandbox. By default, Sandbox will start a sandbox and run your tests locally. Lets dive into the features of our framework and see how they can help you.Create Accounts
Account
- 🦀 Rust
Dev Account
- 🌐 JavaScript
Subaccount
- 🌐 JavaScript
Using Secret Key
- 🦀 Rust
- 🌐 JavaScript
Using Credentials From File
- 🦀 Rust
- 🌐 JavaScript
WASM Files
Compile Contract Code
- 🦀 Rust
- 🌐 JavaScript
Loading From File
- 🦀 Rust
- 🌐 JavaScript
Deploy Contracts
Dev Deploy
- 🌐 JavaScript
Deploy To Account
- 🦀 Rust
- 🌐 JavaScript
Logs
Show contract’s logs.- 🦀 Rust
- 🌐 JavaScript
You can use
println or dbg! when you want to see information from your code.In Rust, the output from your code is captured by default and not displayed in the terminal. In order to see the output, you have to use the --nocapture flageg. cargo test -- --nocaptureIf you want to access the contracts logs, you can find them in the tx_outcome.logs() Vec.Account Balance
- 🦀 Rust
- 🌐 JavaScript
Transactions
Call
- 🦀 Rust
- 🌐 JavaScript
View
- 🦀 Rust
- 🌐 JavaScript
Patch State on the Fly
In Sandbox-mode, you can add or modify any contract state, contract code, account or access key withpatchState.
You can alter contract code, accounts, and access keys using normal transactions via the DeployContract, CreateAccount, and AddKey actions. But this limits you to altering your own account or sub-account. patchState allows you to perform these operations on any account.
- 🦀 Rust
- 🌐 JavaScript
As an alternative to
patchState, you can stop the node, dump state at genesis, edit the genesis, and restart the node.
This approach is more complex to do and also cannot be performed without restarting the node.Time Traveling
sandbox offers support for forwarding the state of the blockchain to the future. This means contracts which require time sensitive data do not need to sit and wait the same amount of time for blocks on the sandbox to be produced. We can simply just call sandbox.fast_forward to get us further in time:
- 🦀 Rust
- 🌐 JavaScript
Using Testnet
NEAR Sandbox is set up so that you can write tests once and run them against a local Sandbox node (the default behavior) or against NEAR TestNet. Some reasons this might be helpful:- Gives higher confidence that your contracts work as expected
- You can test against deployed testnet contracts
- If something seems off in Sandbox mode, you can compare it to testnet
- 🦀 Rust
- 🌐 JavaScript
Spooning Contracts
Spooning a blockchain is copying the data from one network into a different network. NEAR Sandbox makes it easy to copy data from Mainnet or Testnet contracts into your local Sandbox environment:- 🦀 Rust
- 🌐 JavaScript
Specify the contract name from
testnet you want to be pulling, and a specific block ID referencing back to a specific time. (Just in case the contract you’re referencing has been changed or updated)Create a function called pull_contract which will pull the contract’s .wasm file from the chain and deploy it onto your local sandbox. You’ll have to re-initialize it with all the data to run tests. This is because the contract’s data is too big for the RPC service to pull down. (limits are set to 50Mb)Snippets
Snippet I: Testing Hello NEAR
Lets take a look at the test of our Quickstart Project 👋 Hello NEAR, where we deploy the contract on an account and test it correctly retrieves and sets the greeting.- 🦀 Rust
- 🌐 JavaScript
- 🐹 GO
Snippet II: Testing Donations
In most cases we will want to test complex methods involving multiple users and money transfers. A perfect example for this is our Donation Example, which enables users todonate money to a beneficiary. Lets see its integration tests
- 🦀 Rust
- 🌐 JavaScript
- 🐹 GO
Go Integration Testing
Go contracts use the Rustworkspaces-rs framework for integration tests. The workflow is:
- Build your contract to WASM with
near-go build - Write integration tests in a separate Rust project using
workspaces-rs - Run with
cargo test
Unit tests vs Integration tests
near-go test project runs unit tests using the MockSystem environment locally. For full integration tests that deploy to a sandbox, use the workspaces-rs Rust crate as described below.Project Structure
Running Tests
Writing Integration Tests
Integration tests follow theworkspaces-rs pattern. The compiled main.wasm sits one directory above integration-tests/, so tests load it with std::fs::read("../main.wasm").