Xcode对测试的集成支持使您能够以各种方式编写测试来支持你的开发工作。你可以使用测试来检测代码中的潜在回归,以发现预期的成功和失败,并验证应用程序的行为。测试通过确保对象以预期的方式运行来提高代码的稳定性。
当然,通过测试实现的稳定性水平取决于您编写的测试的质量。同样,编写好测试的容易性取决于你编写代码的方法。编写用于测试的代码有助于确保编写良好的测试。请阅读以下准则,以确保您的代码是可测试的,并简化编写良好测试的过程。
指南
定义API要求。为你添加到项目中的每个方法或函数定义需求和结果很重要。对于需求,包括输入和输出范围,抛出的异常和它们引发的条件,以及返回的值的类型(特别是如果值是类的实例)。指定需求并确保代码中满足要求有助于您编写强大,安全的代码。
有关使用例外来识别和报告客户端代码的不正确的库使用情况的示例,请参阅单元测试应用和框架示例代码项目。
在编写代码时写测试用例。在设计和编写每个方法或函数时,编写一个或多个测试用例以确保满足API的要求。记住,为现有代码编写测试比编写代码更困难。
检查边界条件。如果方法的参数必须具有特定范围内的值,则测试应传递包含范围的最低和最高值的值。例如,如果一个程序具有可以具有的值之间的一个整数参数0和100,具有包容性,该方法的测试代码应该通过的值0,50和100输入参数。
使用隐性测试。负测试确保您的代码适当地响应错误条件。验证您的代码在接收无效或意外的输入值时运行正确。还验证它返回错误代码或引发异常时应该。例如,如果一个整数参数必须在范围内的值0到100,包容,创建测试用例值传递-1并101确保了过程引发一个例外或返回错误代码。
编写全面的测试用例。全面的测试结合了不同的代码模块来实现API的一些更复杂的行为。虽然简单,孤立的测试提供价值,堆叠测试执行复杂的行为,并往往抓住更多的问题。这些类型的测试在更现实的条件下模拟代码的行为。例如,除了将对象添加到数组之外,还可以创建数组,向其中添加多个对象,使用不同的方法删除其中几个对象,然后确保剩余对象的集合和数量是正确的。
用测试用例覆盖你的错误修复。每当你修复一个错误,写一个或多个测试用例来验证修复。
****从OCUnit转换到XCTest****
XCTest是用Xcode 5引入的测试框架。一些较旧的项目可能仍然使用OCUnit,上一代测试框架。更新项目以使用XCTest,你可以利用XCTest提供的所有新功能和功能。
从OCUnit到XCTest的转换是一个复杂的操作,包括更新包含测试类和修改项目设置的源文件。Xcode包括一个迁移器,以便为你实现这些更改,方法是选择“编辑”>“转换”>“到XCTest”。
重要: 从Xcode 8开始,迁移器工具不再可用。但是,你仍然可以手动更新项目,如手动将OCUnit 转换为XCTest所述。
将OCUnit转换为XCTest迁移器在当前方案的目标上工作。迁移器检查所选目标,并建议一组自动转换的源更改。
注意: 建议在执行OCUnit到XCTest迁移时转换项目中的所有测试目标。
要将项目从OCUnit更新到XCTest:
1.选择使用方案菜单构建测试目标的方案。
例如,在这个较旧的工作区中有MacOS和iOS的计算器项目,以及基于OCUnit的测试。使用工具栏上的方案编辑器菜单:
在出现的菜单中,选择构建Mac_Calc_ApplicationTests目标的方案,以使其成为活动方案。
2.选择“编辑”>“转换”>“XCTest”
3.单击下一步以移至下一个工作表。
4.在显示的工作表中,选择要转换的测试目标。
要查看特定目标是否在转换后使用XCTest构建,请单击其名称。
5.单击下一步按钮。
助手提供了一个FileMerge接口,你可以在其中逐个文件地评估源更改。
更新的源文件在左侧,原始文件在右侧。你可以扫描所有潜在的更改,并丢弃你认为有问题的更改。
6.在你确认所有更改都有效后,请点击保存按钮。
Xcode将更改写入文件。
转换完成后,运行测试目标并检查其输出,以确保测试正常运行。如果出现任何问题,请参阅“ 调试测试”一章以确定要做什么。
手动从OCUnit转换为XCTest
如果OCUnit到XCTest迁移器无法转换你的项目,或者如果你使用Xcode 8或更高版本,则仍然可以使用以下过程手动迁移项目:
1.向项目添加新的XCTest测试目标。
2.将测试类和方法的实现文件添加到新的测试目标。
3.编辑测试类#import <XCTest/XCTest.h>并在测试方法中使用XCTest断言。
使用此方法可确保为XCTest测试目标正确配置项目设置。与使用迁移器时一样,运行测试目标,并在完成转换后检查其输出,以确保测试按预期运行。如果出现任何问题,请参阅“ 调试测试”一章以确定要做什么。