练习30:自动化测试

    自动化测试经常用于例如Python和Ruby的其它语言,但是很少用于C。一部分原因是自动化加载和测试C的代码片段具有较高的难度。这一章中,我们会创建一个非常小型的测试“框架”,并且使用你的框架目录构建测试用例的示例。

    我接下来打算使用,并且你会包含进框架目录的框架,叫做“minunit”,它以所编写的一小段代码作为开始,之后我扩展了它,就像这样:

    原始的内容所剩不多了,现在我使用宏,并且在模板测试运行器的末尾创建了大量的宏。在这小段代码中我们创建了整套函数单元测试系统,一旦它结合上shell脚本来运行测试,你可以将其用于你的C代码。

    为了基础这个练习,你应该让你的src/libex29.c正常工作,并且完成练习29的附加题,是ex29.c加载程序并合理运行。练习29中我这事了一个附加题来使它像单元测试一样工作,但是现在我打算重新想你展示如何使用minunit.h来做这件事。

    首先我们需要创建一个简单的空单元测试,命名为tests/libex29_tests.c,在里面输入:

    这份代码展示了tests/minunit.h中的RUN_TESTS宏,以及如何使用其他的测试运行器宏。我没有编写实际的测试函数,所以你只能看到单元测试的结构。我首先会分解这个文件:

    libex29_tests.c:1

    libex29_tests.c:3-7

    第一个测试。测试函数具有固定的结构,它们不带任何参数并且返回,成功时为NULL。这非常重要,因为其他宏用于向测试运行器返回错误信息。

    libex29_tests.c:9-25

    与第一个测试相似的更多测试。

    libex29_tests.c:27

    控制其他测试的运行器函数。它和其它测试用例格式一致,但是使用额外的东西来配置。

    libex29_tests.c:28

    mu_suite_start测试设置一些通用的东西。

    这就是使用mu_run_test返回结果的地方。

    libex29_tests.c:35

    在你运行所有测试之后,你应该返回NULL,就像普通的测试函数一样。

    libex29_tests.c:38

    最后需要使用RUN_TESTS宏来启动main函数,让它运行all_tests启动器。

    这就是用于运行测试所有代码了,现在你需要尝试使它运行在项目框架中。下面是我的执行结果:

    我首先执行,之后我运行了构建,它将模板改造为libYOUR_LIBRARY.alibYOUR_LIBRARY.so文件。要记住你需要在练习29的附加题中完成它。但如果你没有完成的话,下面是我所使用的Makefile的文件差异:

    完成这些改变后,你现在应该能够构建任何东西,并且你可以最后补完剩余的单元测试函数:

    附加题