构建
1. 安装 rustc、cargo 和 rustfmt。
$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt
构建主分支时,请确保使用最新的稳定版 Rust,运行以下命令:
$ rustup update
构建特定发布分支时,应检查 ci/rust-version.sh
中的 Rust 版本,如有必要,通过运行以下命令安装该版本:
$ rustup install 版本号
请注意,如果这不是您机器上最新的 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 可访问的稳定公共开发集群。全天候运行。了解更多关于公共集群的信息
基准测试
首先,安装 rustc 的每日构建版本。cargo bench
需要使用仅在每日构建版本中可用的不稳定功能。
$ rustup install nightly
运行基准测试:
$ cargo +nightly bench
发布流程
本项目的发布流程在此处描述。
代码覆盖率
生成代码覆盖率统计:
$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html
为什么要关注覆盖率?虽然大多数人将覆盖率视为代码质量指标,但我们主要将其视为开发人员生产力指标。当开发人员对代码库进行更改时,假定这是某个问题的解决方案。我们的单元测试套件是我们编码代码库所解决的问题集的方式。运行测试套件应该表明您的更改没有侵犯其他人的解决方案。添加测试可以保护您的解决方案免受未来更改的影响。假设您不理解为什么存在某行代码,试着删除它并运行单元测试。最接近的测试失败应该告诉您该代码解决了什么问题。如果没有测试失败,请提交一个询问"这段代码解决了什么问题?"的拉取请求。另一方面,如果测试确实失败了,而您能想到更好的方法来解决同样的问题,那么包含您解决方案的拉取请求一定会受到欢迎!同样,如果重写测试可以更好地传达它所保护的代码,请向我们发送该补丁!
免责声明
本项目中描述的所有声明、内容、设计、算法、估计、路线图、规格和性能测量均由 Solana Labs, Inc.("SL")以诚信努力完成。读者有责任检查和验证其准确性和真实性。此外,本项目中的任何内容均不构成投资邀约。
SL 生产的任何内容或 SL 提供的开发者资源仅用于教育和启发目的。SL 不鼓励、诱导或批准以违反适用法律或法规的方式部署、集成或使用任何此类应用程序(包括构成 Solana 区块链协议的代码),并特此禁止任何此类部署、集成或使用。这包括读者(a)违反美国或任何其他适用司法管辖区的出口管制或制裁法律,(b)如果读者位于或通常居住在受美国财政部海外资产控制办公室(OFAC)全面制裁的国家或地区,或(c)如果读者是或代表特别指定国民(SDN)或受类似阻止或拒绝方禁令限制的人行事。
读者应该意识到,美国出口管制和制裁法律禁止美国人(以及受此类法律约束的其他人)与某些国家和地区的人或 SDN 名单上的人进行交易。因此,个人存在风险,即使用本仓库中包含的任何代码或其衍生物的其他人可能是受制裁人员,与此类人员的交易可能违反美国出口管制和制裁法律。