1 个稳定版本
1.15.0 | 2023年1月22日 |
---|
#13 在 #rebuilt
在 2 个crate中使用(通过 cbe-program-runtime)
515KB
11K SLoC
构建
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/Cartallum/cbe.git
$ cd cbe
3. 构建。
$ ./cargo build
测试
运行测试套件
$ ./cargo test
启动本地测试网
在本地启动您自己的测试网,说明在在线文档中。
访问远程开发集群
devnet
- 稳定的公共集群,可通过devnet.cartallum.com访问,24/7运行。了解更多关于公共集群的信息
基准测试
首先,安装rustc的夜间构建版本。 cargo bench
需要使用仅在夜间构建中可用的不稳定功能。
$ rustup install nightly
运行基准测试
$ cargo +nightly bench
发布流程
此项目的发布流程描述在这里。
代码覆盖率
要生成代码覆盖率统计信息
$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html
为什么需要覆盖率?虽然大多数人认为覆盖率是代码质量指标,但我们主要将其视为开发者生产力指标。当开发者对代码库进行更改时,这通常被认为是某些问题的解决方案。我们的单元测试套件是我们编码代码库解决的问题集。运行测试套件应该表明您的更改没有侵犯其他人的解决方案。添加测试保护您的解决方案免受未来的更改。比如说您不明白一行代码为何存在,试着删除它并运行单元测试。最近的测试失败应该告诉您这行代码解决了什么问题。如果没有测试失败,您可以提交一个Pull Request,询问“这段代码解决了什么问题?”另一方面,如果测试失败并且您有更好的解决方案,您的Pull Request将会非常受欢迎!同样,如果重写测试可以更好地传达它所保护的代码,请发送该补丁!
免责声明
本项目描述的所有主张、内容、设计、算法、估算、路线图、规范和性能测量均基于Cartallum基金会(“CF”)的诚信努力。读者有责任检查和验证其准确性和真实性。此外,本项目中的任何内容均不构成投资邀请。
由SF或开发者资源产生的任何内容仅用于教育和启发目的。SF不鼓励、诱导或批准任何此类应用(包括构成Cartallum CBE区块链协议的代码)的部署、集成或使用,如果违反了适用的法律或法规,并且禁止任何此类部署、集成或使用。这包括读者(a)违反美国或任何其他适用管辖区的出口控制或制裁法律、(b)如果读者位于或通常居住在美国外国资产控制办公室(OFAC)管理的全面制裁的国家或地区,或者(c)如果读者是或代表特别指定国民(SDN)或受到类似封锁或禁止方限制的人。这包括读者(a)违反美国或任何其他适用管辖区的出口控制或制裁法律、(b)如果读者位于或通常居住在美国外国资产控制办公室(OFAC)管理的全面制裁的国家或地区,或者(c)如果读者是或代表特别指定国民(SDN)或受到类似封锁或禁止方限制的人。
读者应了解,美国的出口控制法和制裁法禁止美国公民(以及受此类法律约束的其他个人)与某些国家或地区的个人进行交易,或这些个人在SDN名单上。作为一个主要基于开源软件的项目,可能存在此类受制裁的个人绕过禁令,获取构成Cartallum CBE区块链协议(或其他项目代码或应用程序)的代码,并部署、集成或以其他方式使用它的情况。因此,存在其他使用Cartallum CBE区块链协议的个人可能被制裁,与这些人进行交易可能违反美国出口控制法和制裁法。这种风险适用于直接部署、集成或使用Cartallum CBE区块链协议代码的个人、组织和其他生态系统参与者,以及通过轻客户端、第三方接口和/或钱包软件在Cartallum CBE区块链上进行交易的个人。
依赖项
约14-22MB
约356K SLoC