iOS自动化三

本文章转载于搜狗测试

说完了UITest和Appium我们这次来介绍一下,被广泛认可的一个三方的UI测试框架KIF。

KIF是一个开源的专为iOS设计的移动应用测试框架,使用Objective-C语言开发,能和应用的代码工程完美结合。

它是使用私有API对UI界面进行操作的自动化测试框架,这种类型的测试框架已大行其道,非常受欢迎,KIF就是其中出色的一个,同时,KIF还继承了XCTest,很多大的软件公司比如Google都在用这个测试框架。可见,KIF的认可度还是蛮高的。

下面小编带着大家来简述一下KIF在使用过程中的优缺点,进而大概的了解一下这个框架的工作方式和功能特点

优点:

(1) 继承XCTest,UI测试可以和白盒测试相结合 (这点跟UITest比较像)

(2) 适合做持续集成 (持续集成一直被测试的发展之路,所以一个能做可持续集成的框架,生命力将会很顽强)

(3) 开源 (这是我最喜欢它的一个重要因素,对于一个开发者来说,一个开源的项目是一个非常幸福的事情)

(4) 单用例调试,编码调试轻松愉快 (因为集成自XCTest,所以在xcode中调试,能轻松实现单个用例调试)

当然 KIF的有点很明确,缺点也是相当明确。

缺点:

(1) 需要被测试工程源码 (这对于外包公司的人来说,或者说对于一个代码要求严格的公司来说,这无疑是一个沉重的打击)

(2) 对自定义的控件支持不好 (这个应该不用做太多解释)

(3) 不支持UIWebView (其实这个缺点应该影响不大,大多数框架对UIWebView的支持都不太好)

(4) 测试框架和被测试app在同一进程,测试框架的问题可能会影响被测试app (这个缺点有可能被开发质疑,有的时候出现问题,开发会认为是你的测试代码有问题,所以做好心理准备,和要对自己的代码有自信)

适用场景:

(1) 较为复杂的UI测试或者是UI测试和白盒测试相结盒的测试

测试代码:

配置

(1) 下载好KIF框架工程文件后,把KIF.xcodeproj文件拉进被测试工程里

iOS自动化三_第1张图片

(2) 新建一个测试target,点“Add Target”,选择iOS -> Test -> iOS Unit Testing Bundle。

(3) 对于这个target,把KIF里的静态库libKIF.a和系统的IOKit.framework和它关联

(4) 对于这个target,在Build Settings中的Other Linker Flags选项加一个值-ObjC

(5) 可以编写测试用例了,有两个重要的KIF测试类KIFTestCase(XCTestCase的子类)以及KIFUITestActor,看名字就知道哪个是做什么事的了。

执行操作

首先说明一下,KIF的UI控件操作和获取都是封装在一起的,每个接口里都包含了以什么属性获取控件,以及对这个控件执行什么操作两个部分。所以就没有获取控件这个部分的说明了。也因为这个原因,KIF的操作接口会非常的多,这里列举几个常用的。

(1)点击某个位置

tapScreenAtPoint:(CGPoint)screenPoint

(2) 点击以label命名的控件

tapViewWithAccessibilityLabel:(NSString )label

(3) 长按以label命名的控件,时间长为duration

longPressViewWithAccessibilityLabel:(NSString)label duration:(NSTimeInterval)duration;

(4) 在一个控件里输入一段字符

enterText:(NSString)text intoViewWithAccessibilityLabel:(NSString *)label

(5) 滑动某个控件

swipeViewWithAccessibilityLabel:(NSString)label inDirection:(KIFSwipeDirection)direction

验证机制

(1) UI层面

if(tryFindingViewWithAccessibilityLabel:”label” error:error)

{ //test pass}

else { //test fail}

(2) 非UI层面

由于是继承XCTest的,所以XCTest所具有的那些断言在KIF里都是可以通用的。共有18个。

XCTFail(format…) 生成一个失败的测试;

XCTAssertNil(a1, format…)为空判断,a1为空时通过,反之不通过;

XCTAssertNotNil(a1, format…)不为空判断,a1不为空时通过,反之不通过;

XCTAssert(expression, format…)当expression求值为TRUE时通过;

XCTAssertTrue(expression, format…)当expression求值为TRUE时通过;

XCTAssertFalse(expression, format…)当expression求值为False时通过;

XCTAssertEqualObjects(a1, a2, format…)判断相等,[a1 isEqual:a2]值为TRUE时通过,其中一个不为空时,不通过;

XCTAssertNotEqualObjects(a1, a2, format…)判断不等,[a1 isEqual:a2]值为False时通过;

XCTAssertEqual(a1, a2, format…)判断相等(当a1和a2是 C语言标量、结构体或联合体时使用,实际测试发现NSString也可以);

XCTAssertNotEqual(a1, a2, format…)判断不等(当a1和a2是 C语言标量、结构体或联合体时使用);

XCTAssertEqualWithAccuracy(a1, a2, accuracy, format…)判断相等,(double或float类型)提供一个误差范围,当在误差范围(+/-accuracy)以内相等时通过测试;

XCTAssertNotEqualWithAccuracy(a1, a2, accuracy, format…) 判断不等,(double或float类型)提供一个误差范围,当在误差范围以内不等时通过测试

XCTAssertThrows(expression,format…)异常测试,当expression发生异常时通过;反之不通过;(很变态

XCTAssertThrowsSpecific(expression, specificException, format…) 异常测试,当expression发生specificException异常时通过;反之发生其他异常或不发生异常均不通过;

XCTAssertThrowsSpecificNamed(expression, specificException, exception_name, format…)异常测试,当expression发生具体异常、具体异常名称的异常时通过测试,反之不通过;

XCTAssertNoThrow(expression, format…)异常测试,当expression没有发生异常时通过测试;

XCTAssertNoThrowSpecific(expression, specificException, format…)异常测试,当expression没有发生具体异常、具体异常名称的异常时通过测试,反之不通过;

XCTAssertNoThrowSpecificNamed(expression, specificException, exception_name, format…)异常测试,当expression没有发生具体异常、具体异常名称的异常时通过测试,反之不通过

KIF就介绍到这里,不知道大家的感悟怎么样,是不是有了一种别样的体会呢?

你可能感兴趣的:(iOS自动化三)