#solana #labs #faucet #blockchain #maintained #process #waffle

bin+lib waffles-solana-faucet

由 Waffle Labs 维护的 Solana Faucet

6 个版本

1.16.0-alpha.102023年3月24日
1.16.0-alpha.92023年3月23日
1.16.0-alpha.52023年2月27日

#9 in #faucet

Download history 16/week @ 2024-03-24 36/week @ 2024-03-31 12/week @ 2024-04-07 3/week @ 2024-04-14 121/week @ 2024-04-21 16/week @ 2024-04-28 14/week @ 2024-05-05 19/week @ 2024-05-12 13/week @ 2024-05-19 22/week @ 2024-05-26 14/week @ 2024-06-02 13/week @ 2024-06-09 17/week @ 2024-06-16 25/week @ 2024-06-23 4/week @ 2024-06-30 4/week @ 2024-07-07

51 每月下载量
8 个 crate 中使用 (2 直接)

Apache-2.0

720KB
15K SLoC

Rust 13K SLoC // 0.0% comments Bitbake 1K SLoC // 0.1% comments Shell 651 SLoC // 0.1% comments Python 155 SLoC // 0.0% comments INI 9 SLoC

Solana

Solana crate Solana documentation Build status codecov

构建

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小时运行。了解更多关于 公共集群 的信息

基准测试

首先,安装 rustc 的夜间构建版本。 cargo bench 需要 unstable 功能,这些功能仅在夜间构建版本中可用。

$ rustup install nightly

运行基准测试

$ cargo +nightly bench

发布流程

此项目的发布流程描述见 此处

代码覆盖率

要生成代码覆盖率统计信息

$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html

为什么是覆盖率?虽然大多数人将覆盖率视为代码质量指标,但我们将其视为开发者生产力的主要指标。当开发者对代码库进行修改时,这通常被视为对某个问题的解决方案。我们的单元测试套件是记录代码库解决的一组问题的方式。运行测试套件应该表明您的更改没有侵犯其他人的解决方案。添加测试保护您的解决方案免受未来更改的影响。比如说您不明白为什么存在一行代码,尝试删除它并运行单元测试。最近的测试失败应该会告诉您那行代码解决了什么问题。如果没有测试失败,您可以提交一个Pull Request,询问“这段代码解决了什么问题?”另一方面,如果测试失败并且您能想到更好的解决方案,您的解决方案Pull Request将非常受欢迎!同样,如果重写测试可以更好地传达它所保护的代码,请将补丁发送给我们!

免责声明

本项目中描述的所有声明、内容、设计、算法、估计、路线图、规范和性能测量都是Solana Labs, Inc.(“SL”)本着诚信努力完成的。读者有责任检查和验证其准确性和真实性。此外,本项目中的任何内容均不构成投资邀请。

SL或开发者资源产生的任何内容仅供教育和启发目的使用。SL不鼓励、诱导或允许违反适用的法律或法规部署、集成或使用任何此类应用(包括构成Solana区块链协议的代码),并在此禁止任何此类部署、集成或使用。这包括读者(a)违反美国或任何其他适用司法管辖区的出口控制或制裁法律,(b) 如果读者位于或通常居住在美国商务部外国资产控制办公室(OFAC)管理的全面制裁的国家或地区,或(c) 如果读者是或代表特别指定国家(SDN)或受到类似禁止的个人。

读者应意识到,美国的出口控制和制裁法律禁止美国人士(以及受此类法律约束的其他人士)与某些国家或地区的人员进行交易或列入SDN名单。因此,其他人士使用本项目包含的任何代码或其衍生代码可能会受到制裁,与这些人进行的交易可能违反美国的出口控制和制裁法律。

依赖项

~32–49MB
~862K SLoC