iOS 测试 [译]《Testing with Xcode》第一章——QuickStart

点点寒彬 · 2016年07月15日 · 最后由 valie 回复于 2016年11月15日 · 2816 次阅读
本帖已被设为精华帖!

原文地址:https://developer.apple.com/library/prerelease/content/documentation/DeveloperTools/Conceptual/testing_with_xcode/chapters/02-quick_start.html#//apple_ref/doc/uid/TP40014132-CH2-SW1

文章导读

本篇介绍了 Xcode 执行测试的方法,说明了 Xcode 工具如何新建、执行一个测试用例。

看完之后你能学习到:

  • 如何使用 Xcode 来创建一个测试用例。

  • 如何执行测试用例

  • 如何观察 Xcode 的测试结果

声明

文章翻译自 Apple 官方文档《Testing with Xcode》,不保证每个字都能翻译的精准,如有翻译错误,请留言指出,不胜感激。

QuickStart

这个快速入门是为了告诉你,你可以很容易的给你开发的软件做一些必须的测试。

介绍测试导航菜单

当你开始测试工作的时候,你经常会使用 Xcode 的导航器。

测试导航菜单是工作区的一部分,是让你便捷的创建,管理,运行和检视测试代码。你可以点击在 issue 导航和 debug 导航中间的的图标进入测试导航菜单。当你有一个项目,其中的测试内容已确定,如下图你可以在这里看到类似的导航菜单。

twx-qs-1_2x

上图中的测试导航菜单举例展示了以列表的形式分级测试包,类型,以及方法。这个项目是一个类似计算器的 app。计算器的核心是以一个框架来执行代码,可以看到优先级最高的SampleCalcTests测试包,是为了测试应用的代码。


注意:Xcode 的测试目标会生成测试包,并展示在测试导航菜单中。

如果你测试时使用数据,图片和其他内容,他们可以被添加到测试包,在执行的时候使用NSBundleAPIs 实现存取。使用+[NSBundle bundleForClass:]和你的测试类时,区分类型,以确保得到正确的测试包来检索数据。更多详情请看NSBundle Class Reference.

Xcode 执行计划会所控制构建的内容。执行计划也会控制可用的测试方法来执行测试操作。你可以在测试菜单中使用 Control-clicking 以及通过快捷菜单来有选择的使用或者忽略测试包,类和方法。


在视图中被激活的测试包是SampleCalcTests. SampleCalcTests,它包含了一个测试包,轮换着控制(使用)九种测试方法。当你把鼠标放在列表中任意一项上,这是一个快速的方式来运行一个测试包中所有的测试项、一个类中所有的测试项、或者任意一个单独的测试。测试结束后会返回成功或失败的结果给 Xcode。当测试被执行时,这些图标会更新,给你展示测试的结果。绿色对勾表示通过,红色叉叉表示失败。这里测试导航菜单显示的测试结果,有两项被断言为失败。

twx-qs-2_2x

点击列表中任意一个测试类或者测试方法,会在代码编辑器中打开对应的测试类。测试类和测试方法也会在编辑器中做上标记。工作原理和在测试导航菜单上一样。测试失败会在代码编辑器中展示有关联断言的结果字符串。

在测试菜单的底部是增加按钮和过滤控制,你可以减少展示的内容,只显示活动的测试项或者只展示失败的测试,当然,你也可以按照名称来过滤。

更多测试导航菜单的详细信息,请看Test Navigator Help

为你的 APP 增加测试方法

在 Xcode5 和以后的版本中你在新建 app,框架和资源的时候会预设一个测试的目标。当你开始一个新的项目时打开测试导航菜单,你可以看到一个测试包,一个测试类和一个测试方法的模板。但是你可能会从一个 Xcode 早期版本中打开一个预先存在的项目,此项目没有确定的测试目标。这里的工作流程假设一个之前的项目是没有纳入测试的。

创建一个测试目标

点击测试导航菜单左下方的增加按钮来选择新建一个Unit Test Target

twx-qs-3_2x

在下一个对话框中选择 OS X 或者 IOSUnit Testing Bundle,然后点击Next。会出现一个新的对话框,编辑项目名称和其他你需要的参数。

twx-qs-4_2x

点击Finish来增加你的 target,在测试导航菜单师徒中包含了一个测试类的模板和两个测试方法的模板

运行测试和观察结果

现在你已经为你的项目增加测试方法了。你想要开发一些有用的测试方法。但是首先,先把鼠标放到测试导航菜单的SampleCalcTests上并点击运行按钮来执行所有的测试方法。测试结果会在函数名的旁边用绿色的标记标记出来,在代码编辑器中也一样。

twx-qs-6_2x

模板中的单元测试和演示的测试方法都是空的。这就是为什么他们都会被标记为成功,没有失败的断言。注意 34 行灰色菱形measureBlock:方法。点击菱形来展示演示结果的面板。

twx-qs-7_2x

面板允许你设置一个预期的基线、编辑基线和最大 STDDEV 参数。这些特点稍后会讨论。

编辑测试案例再次运行

由于这个样本项目是一个计算器 APP,你想要检查它能否正确的执行加减乘除和其他计算功能。由于测试是在 app 项目内部构建,你可以增加所有你愿意增加的测试情景在程序的任意层。创建测试要做的事就是给整个单元添加函数来测试实现文件。

例如。你插入如下#import和给SampleCalcTests.m增加变量

#import <XCTest/XCTest.h>

//

// Import the application specific header files

#import "CalcViewController.h"

#import "CalcAppDelegate.h"



@interface CalcTests : XCTestCase {

// add instance variables to the CalcTests class

@private

    NSApplication       *app;

    CalcAppDelegate     *appDelegate;

    CalcViewController  *calcViewController;

    NSView              *calcView;

}

@end

然后给测试方法一个描述的名称,就像testAddition一样,然后为方法增加一个执行的代码。

- (void) testAddition

{

   // obtain the app variables for test access

   app                  = [NSApplication sharedApplication];

   calcViewController   = (CalcViewController*)[[NSApplication sharedApplication] delegate];

   calcView             = calcViewController.view;



   // perform two addition tests

   [calcViewController press:[calcView viewWithTag: 6]];  // 6

   [calcViewController press:[calcView viewWithTag:13]];  // +

   [calcViewController press:[calcView viewWithTag: 2]];  // 2

   [calcViewController press:[calcView viewWithTag:12]];  // =

    XCTAssertEqualObjects([calcViewController.displayField stringValue], @"8", @"Part 1 failed.");



   [calcViewController press:[calcView viewWithTag:13]];  // +

   [calcViewController press:[calcView viewWithTag: 2]];  // 2

   [calcViewController press:[calcView viewWithTag:12]];  // =

    XCTAssertEqualObjects([calcViewController.displayField stringValue], @"10", @"Part 2 failed.");

}

注意测试导航菜单中样例的测试方法,testExample被替换成了testAddition

twx-qs-8_2x

现在点击测试导航菜单中的运行按钮(或者代码编辑器中的指示)来运行testAddition方法。

twx-qs-9_2x

就像你看到的一样,一个断言失败了,在测试导航菜单和代码编辑器中都高亮显示了。看源代码。Part 1 成功了,是 Part 2 有一个问题。在相近的测试中,错误很明显:在 76 行,[calcView viewWithTag:11]错了。应该是[calcView viewWithTag:12]。收集错误信息修复问题后,测试成功。

twx-qs-8a_2x

为普通的代码使用 setUp() 和 tearDown() 方法

Xcode 为活动的测试包运行所有的测试方法一次。在这个小例子中只有一个方法执行了。它需要获得三个计算器 app 提供的变量对象来运行。如果你写了四个或者五个测试方法在同样的类中。你会发现你需要为每一条测试案例输入重复的代码来获得 app 的运算结果。XCTest 框架提供给你来运行测试类,setUptearDown的实例方法,你可以用他们来放置每次执行测试方法的前置方法和结束方法。

使用setUptearDown方法很简单。从Mac_Calc_Tests.m文件中的testAddition代码中剪切 4 行// obtain the app variable for test access然后粘贴他们到模板默认的setUp实例方法中。

- (void)setUp

{

    [super setUp];

    // Put setup code here. This method is called before the invocation of each test method in the class.



   // obtain the app variables for test access

   app                  = [NSApplication sharedApplication];

   calcViewController   = (CalcViewController*)[[NSApplication sharedApplication] delegate];

   calcView             = calcViewController.view;

}

现在增加更多只使用最少代码的测试方法——testSubtraction和其他方法。

twx-qs-10_2x

总结

从这个简短的快速入门你可以看到,它给项目增加测试是非常简单的。这里有一些需要注意的地方:

  • Xcode 能建立绝大多数基础的测试框架。当你为你的项目增加一个测试 target 时,Xcode 会自动把它添加到关联的产品目标上去。一个最初的测试类只带一个被添加目标的测试方法,能在测试导航菜单中被找到。
  • 测试导航菜单让你很容易的定位和编辑测试方法。你可以在测试导航菜单中使用导航按钮直接运行测试方法,或者在打开的测试类中直接从代码编辑器中运行。当一个测试失败时,测试导航菜单和代码编辑器都会把失败的部分标记出来
  • 一个单独的测试方法可以包含该多个断言,结果只显示一个通过或者失败。这种方式允许你根据项目需要创建简单或者复杂的测试。
  • setUp方法和tearDown方法作为入口方法,能够让你把常用的代码统一的使用在方法中,保持代码的连贯性也更容易发现问题。

感谢

感谢小强在百忙之中抽空帮忙校验。

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 11 条回复 时间 点赞
恒温 将本帖设为了精华贴 07月15日 21:27

加油,坚持,给你合理

#2 楼 @lihuazhang 非常感谢,我会坚持下去😀

加油,起步很好呀

支持! 对于像我这样英语不好的就是福利。。。加油! 👍

#6 楼 @defias 我也是一点一点的憋出来的,我相信很多人想学但是懒于看英语。

#7 楼 @wyb199026 我喜欢用有道词典😚

#8 楼 @mads 我都是去查实体的词典,然后就下来,下次就不容易忘记。总体的词汇也就这么些,希望看多了,能够脱离词典。

我现在天天学英语,哈哈哈哈

#10 楼 @lina100303006 英语是硬伤啊,英语差真心受很大的局限

点点寒彬 [该话题已被删除] 中提及了此贴 07月28日 14:55

请问官方的示例代码在哪里下载

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册