4 个版本

0.1.3 2024年6月17日
0.1.2 2024年6月6日
0.1.1 2024年6月6日
0.1.0 2024年6月6日

#114测试

Download history 335/week @ 2024-06-03 33/week @ 2024-06-10 254/week @ 2024-06-17 23/week @ 2024-06-24

每月 193 次下载
gba_clock 中使用

MIT/Apache 许可

73KB
1.5K SLoC

gba_test

GitHub Workflow Status crates.io docs.rs License

Game Boy Advance 测试框架。

Example .gif

入门

使用 gba_test 需要安装 nightly 版本的 Rust。

先决条件

  • ARM Binutils:至少需要 ARM GNU 链接器 (arm-none-eabi-ld) 才能正确构建使用 gba_test 的项目。您可以从 ARM 网站 获取。
  • rust-src - GBA 开发需要 build-std 才能工作。运行 rustup component add rust-src 以启用它。
  • cargo 配置 - 应在项目中的 cargo/config.toml 文件中提供 cargo 的配置。以下是一个示例配置:
[build]
target = "thumbv4t-none-eabi"

[target.thumbv4t-none-eabi]
runner = "mgba"
rustflags = ["-Clinker=arm-none-eabi-ld", "-Clink-arg=-Tgba.ld", "-Ztrap-unreachable=no"]

[unstable]
build-std = ["core"]

gba_test 添加到依赖列表

在您的 Cargo.toml 清单中,将 gba_test 添加到 dev-dependencies 列表

[package]
name = "your_project"
version = "0.1.0"
edition = "2021"

[dev-dependencies]
gba_test = "0.1.0"

运行测试运行器

gba_test 提供了自己的测试运行器。要运行测试,您需要在您的 main() 函数中调用运行器。

以下代码可以在运行 cargo test 时调用测试运行器:

#![no_std]
#![cfg_attr(test, no_main)]
#![cfg_attr(test, feature(custom_test_frameworks))]
#![cfg_attr(test, test_runner(gba_test::runner))]
#![cfg_attr(test, reexport_test_harness_main = "test_harness")]

#[cfg(test)]
#[no_mangle]
pub fn main() {
    test_harness()
}

调用 test_harness() 将运行项目中定义的所有测试。

定义测试

gba_test 提供了自己的自定义 #[test] 属性来定义测试。它的工作方式与默认的 #[test] 属性类似。

// A very simple function to test.
pub fn add(left: usize, right: usize) -> usize {
    left + right
}

#[cfg(test)]
mod tests {
    use super::add;
    use gba_test::test;

    #[test]
    fn it_works() {
        let result = add(2, 2);
        assert_eq!(result, 4);
    }
}

其他常见的测试属性也受到支持,包括 #[ignore]#[should_panic]

运行测试

gba_test 可以在任何可以运行 .gba 文件的地方运行,从原始的 Game Boy Advance 硬件到仿真器。

使用 cargo test 配置在 mGBA 上运行

对于开发工作流程,建议在仿真器上运行测试。在“先决条件”部分提供的示例 cargo/config.toml 将允许您在运行 cargo test 时在 mGBA(假设 mgba 在您的 PATH 中)上运行测试。

在真实硬件上运行

要在真实 Game Boy Advance 硬件上运行,您可以将生成的测试二进制文件闪存到卡带中。

准备 .gba 文件

当运行 cargo test 时,会生成一个 .elf 测试二进制文件。仿真器如 mGBA 可以运行此 .elf 文件,但真实硬件需要 .gba 文件。您的测试二进制文件的路径由 cargo test 输出。例如,在 gba_test 库上运行 cargo test 时输出如下

Running unittests src\lib.rs (target\thumbv4t-none-eabi\debug\deps\gba_test-5b5cf1bdf24b2915)

括号中的路径是测试二进制文件的位置。您可以使用 arm-none-eabi-objcopy(从 ARM 网站 获取)从这个二进制文件创建一个 .gba 文件

arm-none-eabi-objcopy -O binary target\thumbv4t-none-eabi\debug\deps\gba_test-5b5cf1bdf24b2915 test.gba

接下来,运行 gbafix

cargo install gbafix
gbafix test.gba

现在,test.gba 已准备就绪,可以在真实的 Game Boy Advance 硬件上运行。有关将 .gba 文件闪存到卡带并运行的说明,请参阅您的闪存卡的文档。

使用 mgba-rom-test 运行

gba_test 已配置为使用 mgba-rom-test 二进制文件通过 SWI 调用 0x27 并将 r0 作为输出寄存器运行。退出值为 0 被认为是成功的测试运行。

要在 GitHub Actions 中的持续集成中使用 mgba-rom-test,建议使用 github-mgba-rom-test 操作。请参阅此项目的 GitHub Actions 设置,了解此工作流程的示例。

日志记录

一些模拟器,例如 mGBAno$gba,支持日志记录。 gba_test 提供了与 log crate 的可选集成,以记录测试运行的信息。您可以通过日志特性来启用日志记录

[dev-dependencies]
gba_test = {version = "0.1.0", features = ["log"]}

您还可以使用 log crate 在您的测试中进行日志记录

use gba_test::test;

#[test]
fn foo() {
    log::info!("important information");
}

要为您的模拟器生成日志输出,您需要使用针对该模拟器日志接口的特定日志实现。以下是一些推荐的日志实现

在调用测试运行器之前初始化日志记录器,如下所示

#![no_std]
#![cfg_attr(test, no_main)]
#![cfg_attr(test, feature(custom_test_frameworks))]
#![cfg_attr(test, test_runner(gba_test::runner))]
#![cfg_attr(test, reexport_test_harness_main = "test_harness")]

#[cfg(test)]
#[no_mangle]
pub fn main() {
    mgba_log::init();
    test_harness()
}

许可

本项目受以下任一许可协议的许可:

任您选择。

贡献

除非您明确声明,否则您提交的任何旨在包含在本作品中的贡献,根据 Apache-2.0 许可协议定义,应按上述方式双重许可,不附加任何其他条款或条件。

依赖

~130KB