首页
/ Ruby Spec Suite 技术文档

Ruby Spec Suite 技术文档

2024-12-12 13:59:27作者:范靓好Udolf

1. 安装指南

1.1 克隆项目

首先,克隆 ruby/spec 项目到本地:

$ git clone https://github.com/ruby/spec.git

1.2 进入项目目录

进入克隆下来的项目目录:

$ cd spec

1.3 克隆 MSpec 项目

克隆 MSpec 项目到本地:

$ git clone https://github.com/ruby/mspec.git ../mspec

2. 项目的使用说明

2.1 运行所有测试

在项目目录下,运行以下命令来执行所有的测试:

$ ../mspec/bin/mspec

2.2 运行特定测试

你可以通过指定文件或目录来运行特定的测试。例如,运行单个测试文件:

$ ../mspec/bin/mspec core/kernel/kind_of_spec.rb

或者运行某个目录下的所有测试:

$ ../mspec/bin/mspec core/kernel

2.3 按组运行测试

你还可以按组运行测试,例如运行所有语言相关的测试:

$ ../mspec/bin/mspec :language

其他组的测试可以通过以下命令运行:

$ ../mspec/bin/mspec :core
$ ../mspec/bin/mspec :library
$ ../mspec/bin/mspec :capi

3. 项目API使用文档

3.1 运行特定Ruby实现的测试

使用 -t 选项来指定要运行的Ruby实现。你可以传递Ruby二进制文件的完整路径或 $PATH 中的可执行文件:

$ ../mspec/bin/mspec -t /path/to/some/bin/ruby

3.2 启用内存泄漏检查

你可以通过设置 CHECK_LEAKS=true 来启用内存泄漏检查:

$ CHECK_LEAKS=true ../mspec/bin/mspec

3.3 在S390x架构上运行测试

如果在S390x架构上运行测试时遇到与zlib库相关的失败,可以通过设置 DFLTCC=0 来解决:

$ DFLTCC=0 ../mspec/bin/mspec

4. 项目安装方式

4.1 依赖项

运行测试需要以下命令行工具:

  • echo
  • stat(用于 core/file/*time_spec.rb
  • find(用于 core/file/fixtures/file_types.rb,在Windows上不需要)

此外,/etc/services 文件是套接字测试所必需的(在Debian上需要 netbase 包,在Windows上不需要)。

4.2 历史版本

如果你需要运行旧版本的Ruby测试,可以参考项目中的历史提交记录,选择相应的提交版本进行测试。

5. 贡献与编写测试

5.1 贡献指南

有关贡献和编写测试的详细信息,请参阅 CONTRIBUTING.md 文件。

5.2 编写测试

编写测试时,可以使用 guardsmatchers 等工具来帮助编写和运行测试。

热门项目推荐

项目优选

收起
mybatis-plusmybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.com
Java
35
1
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
82
55
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
185
42
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
52
40
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
31
20
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用。 官网地址:https://matechat.gitcode.com
72
5
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
260
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
897
0
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
168
39
Git4TomeGit4Tome
以开源协作的方式翻译开源领域的经典著作,推动开源知识的中文传播。
8
1