1 个稳定版本
1.6.16 | 2021年8月7日 |
---|
#22 在 #通知器
9KB
164 行
构建
1. 安装 rustc, cargo 和 rustfmt。
$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt
在构建 master 分支时,请确保您正在使用最新的稳定 Rust 版本,可以通过运行
$ rustup update
在构建特定发布分支时,您应该在 ci/rust-version.sh
中检查 Rust 版本,并在必要时通过运行安装该版本
$ rustup install VERSION
请注意,如果这不是您机器上的最新 Rust 版本,则 cargo 命令可能需要一个 覆盖 才能使用正确版本。
在 Linux 系统上,您可能需要安装 libssl-dev, pkg-config, zlib1g-dev, protobuf 等。
在 Ubuntu 上
$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang cmake make libprotobuf-dev protobuf-compiler
在 Fedora 上
$ sudo dnf install openssl-devel systemd-devel pkg-config zlib-devel llvm clang cmake make protobuf-devel protobuf-compiler perl-core
2. 下载源代码。
$ git clone https://github.com/solana-labs/solana.git
$ cd solana
3. 构建。
$ ./cargo build
测试
运行测试套件
$ ./cargo test
启动本地测试网
在本地启动自己的测试网,说明请参考在线文档。
访问远程开发集群
devnet
- 稳定的公共集群,可通过 devnet.solana.com 访问。24/7 运行。了解更多关于 公共集群 的信息。
基准测试
首先安装 rustc 的夜间构建版。 cargo bench
需要 nightly build 版本中仅有的不稳定特性。
$ rustup install nightly
运行基准测试
$ cargo +nightly bench
发布流程
该项目的发布流程描述如下:此处。
代码覆盖率
要生成代码覆盖率统计信息
$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html
为什么需要覆盖率?虽然大多数人将覆盖率视为代码质量指标,但我们主要将其视为开发者生产力的指标。当开发者对代码库进行修改时,这通常被认为是对某些问题的解决方案。我们的单元测试套件是我们编码代码库解决的问题集合。运行测试套件应表明您的更改没有侵犯他人的解决方案。添加测试可以保护您的解决方案免受未来的更改。如果您不理解为什么存在某一行代码,可以尝试删除它并运行单元测试。最近的测试失败应该会告诉您该代码解决了什么问题。如果没有测试失败,您可以提交一个包含“这段代码解决了什么问题?”的Pull Request。另一方面,如果测试失败并且您认为有更好的解决方案,您的解决方案PullRequest将非常受欢迎!同样,如果重写测试可以更好地传达所保护的代码,请发送这个补丁!
免责声明
本项目中描述的所有声明、内容、设计、算法、估算、路线图、规范和性能测量均基于Solana Labs,Inc.(“SL”)的良好诚意。读者有责任检查和验证其准确性和真实性。此外,本项目中没有任何内容构成投资邀请。
SL或SL提供的开发者资源产生的任何内容仅用于教育和启发目的。SL不鼓励、诱导或支持违反适用法律或法规部署、集成或使用任何此类应用程序(包括构成Solana区块链协议的代码),并禁止任何此类部署、集成或使用。这包括读者使用此类应用程序的情况:(a)违反美国或任何其他适用司法管辖区的出口管制或制裁法律,(b)如果读者位于或通常居住在美国海外资产控制办公室(OFAC)管理的全面制裁的任何国家或地区,(c)如果读者是或代表特别指定的国家(SDN)或受到类似封锁或拒绝方禁止的人员。
读者应了解,美国出口管制和制裁法律禁止美国公民(以及受此类法律约束的其他人员)与某些国家或地区或SDN名单上的个人进行交易。因此,使用此存储库中包含的任何代码或其派生代码的个人可能受到制裁,与这些人员的交易可能违反美国出口管制和制裁法律。
依赖关系
~3–14MB
~206K SLoC