3

在我的 Xcode 测试套件中执行每个测试用例后,我需要测试状态。我知道观察者可以帮助实现它。但是我如何在我的测试中使用它呢?

4

2 回答 2

8

您走在正确的轨道上,可以通过 XCTestObservation 协议 ( https://developer.apple.com/documentation/xctest/xctestobservation )实现您想要做的事情。您可以在测试用例类中添加观察者,我建议在 setUp() 方法中执行此操作,因为它会在每个测试方法之前执行。

override func setUp() {
    super.setUp()

    continueAfterFailure = false

    XCUIApplication().launch()

    XCTestObservationCenter.shared.addTestObserver(UITestObserver())
}

为此,您应该实现一个符合 XCTestObservation 协议的类,然后为感兴趣的方法提供您自己的实现,以执行您需要/想要的任何操作。在您的情况下,您可能希望为此方法提供一个实现......

optional public func testCase(_ testCase: XCTestCase, didFailWithDescription description: String, inFile filePath: String?, atLine lineNumber: Int)

这是这个测试观察者类可能是什么样子的一个快速示例......

import XCTest

public class UITestObserver: NSObject, XCTestObservation {
    public func testCase(_ testCase: XCTestCase,
                           didFailWithDescription description: String,
                           inFile filePath: String?,
                           atLine lineNumber: Int) {
        print("failure description: \(description)")
        print("failed test case: \(testCase)")
        if let filePath = filePath {
            print("failure at file path: \(filePath)")
        }
        print("failure at line: \(lineNumber)")
    }
}

每当您的一个测试用例失败时,我提供的上面示例中的这个函数就会被调用,因此您不需要在测试用例类或方法中“做”任何事情。

希望这可以帮助!

于 2018-01-12T16:59:18.983 回答
1

每个执行的测试用例的结果都保存在一个名为 ***TestSummeries.plist 的文件中。

你会在下面找到它

~/Library/Developer/Xcode/DerivedData/<your-app-name>/Logs/Test/****_TestSummeries.plist

如果您多次运行测试,只需在执行前删除 DerivedData 中的所有内容。然后你会发现只有一个TestSummeries.plist。

然后解析 plist 并从 plist 文件中获取所需的数据。

**如果您需要有关它的更多信息,请随时在下面发表评论。

于 2017-12-20T08:29:52.420 回答