mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-10 21:04:40 +00:00
7d0d1dc382
svm-rs is already in tree as a library, so we may as well include it as a bin instead of also pulling in solc-select.
1.8 KiB
1.8 KiB
Getting Started
Dependencies
Ubuntu
sudo apt-get install -y build-essential cmake clang-11 git curl python3-pip protobuf-compiler libssl-dev pkg-config
Install rustup
Linux
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
macOS
brew install rustup
Install Rust
rustup update
rustup toolchain install stable
rustup target add wasm32-unknown-unknown
rustup toolchain install nightly
rustup target add wasm32-unknown-unknown --toolchain nightly
Install Solidity
cargo install svm-rs
svm install 0.8.16
svm use 0.8.16
Install Solidity Compiler Version Manager
cargo install svm-rs
svm install 0.8.16
svm use 0.8.16
Install foundry and anvil (for tests)
cargo install --git https://github.com/foundry-rs/foundry --profile local --locked foundry-cli anvil
Clone and Build Serai
git clone https://github.com/serai-dex/serai
cd serai
cargo build --release --all-features
Run Tests
Running tests requires:
- A rootless Docker setup
- A properly configured Bitcoin regtest node (available via Docker)
- A properly configured Monero regtest node (available via Docker)
- A properly configured monero-wallet-rpc instance
- A debug Serai node (
cd substrate/node && cargo build
)
cargo test --all-features
Run Serai in Development Mode
./target/release/serai-node --dev
Run Serai with Orchestration
Under /orchestration
, you can find our orchestration components for running
the entire infrastructure of Serai in a local environment using Docker Compose
or Kubernetes.