solana-with-rpc-optimizations/README.md

116 lines
3.7 KiB
Markdown
Raw Normal View History

2020-04-09 10:51:16 -07:00
<p align="center">
<a href="https://solana.com">
<img alt="Solana" src="https://i.imgur.com/0vfIMHo.png" width="250" />
2020-04-09 10:51:16 -07:00
</a>
</p>
2018-06-24 10:10:55 -07:00
2020-04-09 10:55:00 -07:00
[![Solana crate](https://img.shields.io/crates/v/solana-core.svg)](https://crates.io/crates/solana-core)
[![Solana documentation](https://docs.rs/solana-core/badge.svg)](https://docs.rs/solana-core)
[![Build status](https://badge.buildkite.com/8cc350de251d61483db98bdfc895b9ea0ac8ffa4a32ee850ed.svg?branch=master)](https://buildkite.com/solana-labs/solana/builds?branch=master)
[![codecov](https://codecov.io/gh/solana-labs/solana/branch/master/graph/badge.svg)](https://codecov.io/gh/solana-labs/solana)
2020-04-09 11:06:09 -07:00
# Building
2020-04-09 11:06:09 -07:00
## **1. Install rustc, cargo and rustfmt.**
```bash
$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt
```
When building the master branch, please make sure you are using the latest stable rust version by running:
```bash
$ rustup update
```
When building a specific release branch, you should check the rust version in `ci/rust-version.sh` and if necessary, install that version by running:
```bash
$ rustup install VERSION
```
Note that if this is not the latest rust version on your machine, cargo commands may require an [override](https://rust-lang.github.io/rustup/overrides.html) in order to use the correct version.
On Linux systems you may need to install libssl-dev, pkg-config, zlib1g-dev, protobuf etc.
On Ubuntu:
2018-07-02 10:22:37 -07:00
```bash
$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang cmake make libprotobuf-dev protobuf-compiler
2018-07-02 10:22:37 -07:00
```
On Fedora:
```bash
$ sudo dnf install openssl-devel systemd-devel pkg-config zlib-devel llvm clang cmake make protobuf-devel protobuf-compiler perl-core
```
2020-04-09 11:06:09 -07:00
## **2. Download the source code.**
```bash
2018-03-27 15:16:27 -07:00
$ git clone https://github.com/solana-labs/solana.git
$ cd solana
```
2020-04-09 11:06:09 -07:00
## **3. Build.**
2018-12-14 15:55:58 -08:00
```bash
2022-11-14 12:08:56 -08:00
$ ./cargo build
2018-12-14 15:55:58 -08:00
```
2020-04-09 11:06:09 -07:00
# Testing
2020-04-09 10:58:42 -07:00
**Run the test suite:**
```bash
2022-11-14 12:08:56 -08:00
$ ./cargo test
```
2020-04-09 11:06:09 -07:00
### Starting a local testnet
Start your own testnet locally, instructions are in the [online docs](https://docs.solanalabs.com/clusters/benchmark).
### Accessing the remote development cluster
* `devnet` - stable public cluster for development accessible via
devnet.solana.com. Runs 24/7. Learn more about the [public clusters](https://docs.solanalabs.com/clusters)
2020-02-06 12:19:30 -08:00
2020-04-09 11:06:09 -07:00
# Benchmarking
2021-12-20 22:50:36 -08:00
First, install the nightly build of rustc. `cargo bench` requires the use of the
2019-03-04 09:00:52 -08:00
unstable features only available in the nightly build.
```bash
$ rustup install nightly
```
Run the benchmarks:
```bash
2019-03-04 09:00:52 -08:00
$ cargo +nightly bench
```
2020-04-09 11:06:09 -07:00
# Release Process
2018-11-28 16:48:27 -08:00
The release process for this project is described [here](RELEASE.md).
2018-08-16 20:48:11 -07:00
2020-04-09 11:06:09 -07:00
# Code coverage
2018-12-17 10:11:02 -08:00
To generate code coverage statistics:
```bash
2018-12-17 10:11:02 -08:00
$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html
```
Why coverage? While most see coverage as a code quality metric, we see it primarily as a developer
productivity metric. When a developer makes a change to the codebase, presumably it's a *solution* to
some problem. Our unit-test suite is how we encode the set of *problems* the codebase solves. Running
the test suite should indicate that your change didn't *infringe* on anyone else's solutions. Adding a
test *protects* your solution from future changes. Say you don't understand why a line of code exists,
try deleting it and running the unit-tests. The nearest test failure should tell you what problem
was solved by that code. If no test fails, go ahead and submit a Pull Request that asks, "what
problem is solved by this code?" On the other hand, if a test does fail and you can think of a
better way to solve the same problem, a Pull Request with your solution would most certainly be
welcome! Likewise, if rewriting a test can better communicate what code it's protecting, please
send us that patch!