Skip to content

Latest commit

 

History

History
90 lines (59 loc) · 2.62 KB

README.md

File metadata and controls

90 lines (59 loc) · 2.62 KB

Injective Cosmwasm Contracts

This repository contains the full source code for the core smart contracts deployed on Injective.

Contracts

These contracts hold the core logic of the system.

Contract Description
dummy A simply template for starting a new contract
atomic-order-example Example contract on how to do atomic market orders on Injective incl handling the response

Development

Environment Setup

  • Rust v1.67.0
  • wasm32-unknown-unknown target
  • Docker
  1. Install rustup
  2. Run the following
rustup default 1.67.0
rustup target add wasm32-unknown-unknown
  1. Make sure Docker is installed on your machine

Unit / Integration Test

Each contract contains Rust unit tests embedded within the contract source directories. You can run

cargo unit-test

Compiling

Go to the contract directory and run

After making sure tests pass, you can compile each contract with the following

RUSTFLAGS='-C link-arg=-s' cargo wasm
sha256sum target/wasm32-unknown-unknown/release/<CONTRACT_NAME>.wasm

Production

For production builds, run the following:

docker run --rm -v "$(pwd)":/code \
  --mount type=volume,source="$(basename "$(pwd)")_cache",target=/code/target \
  --mount type=volume,source=registry_cache,target=/usr/local/cargo/registry \
  cosmwasm/workspace-optimizer-arm64:0.12.11

This performs several optimizations which can significantly reduce the final size of the contract binaries, which will be available inside the artifacts/ directory.

Formatting

Make sure you run rustfmt before creating a PR to the repo.

To run rustfmt,

cargo fmt

Linting

You should run clippy also. This is a lint tool for Rust. It suggests more efficient/readable code. You can see the clippy document for more information.

Run

cargo clippy -- -D warnings

Testing

Developers are strongly encouraged to write unit tests for new code, and to submit new unit tests for old code. Unit tests can be compiled and run with: cargo test --all. For more details, please reference Unit Tests.