我有一个应用程序,其中使用页面控件来指示多个屏幕。当用户点击页面控件(例如:当前所选页面的右侧)时,滚动视图将滚动到以下屏幕。它工作正常。
我想为这个场景编写UI测试。我发现我无法点击特定页面控件“点”来触发该操作。我可以检查的是页面控件是否存在以及当前所选页面。
另一个问题是,即使我能够这样做,我如何检查滚动视图是否已滚动?我只能访问滚动视图的框架,而不是它的边界。
我刚刚开始使用Xcode UITest,它让我感到失望。我认为它现在会很强大(它是由Xcode 7引入的,之前它是作为UI自动化提供的),但它似乎还没有。
我将恢复单元测试+手动功能测试。如果有人有其他想法,请分享。
答案 0 :(得分:5)
不要放弃这么快,Xcode UITest有时会令人沮丧但是一旦你弄清楚要使用什么技巧,它们就会非常强大:
您可以像这样测试您的UIPageControl:
func testPageIndicator() {
let app = XCUIApplication()
app.launch()
let scrollView = app.scrollViews.element(boundBy: 0)
let pageIndicator = app.pageIndicators.element(boundBy: 0)
// test that page indicator is updated when user scrolls to page 2
scrollView.swipeLeft()
XCTAssertEqual(pageIndicator.value as? String, "page 2 of 3")
// test that scrollview scrolls to page 3 when user taps right of the current page in page indicator
pageIndicator.coordinate(withNormalizedOffset: CGVector(dx: 0.9, dy: 0.2)).tap()
XCTAssert(app.otherElements["page_3"].waitForExistence(timeout: 2))
XCTAssertFalse(app.otherElements["page_2"].exists)
XCTAssertEqual(pageIndicator.value as? String, "page 3 of 3")
}
您可以使用coordinate
方法告知测试在哪里点击UIElement。您将CGVector对象传递给描述点击位置的方法。
例如,CGVector(dx: 0.9, dy: 0.2)
告诉测试在位于其宽度的90%和高度的20%处的点处挖掘元素。
您可以使用此按钮点按UIPageIndicator
中当前页面右侧的左侧(参见上面的代码示例)
要测试您是否在UIScrollView中的正确页面上,您可以将每个页面accessibilityIdentifier
设置为唯一的字符串,然后在您点击页面控件后断言具有该标识符的UIElement存在。
在我的情况下,这些页面是3个UIViews。我将accessibilityIdentifier
设置为" page_1"," page_2"和" page_3"然后断言" page_3"存在和" page_2"没有按'吨
答案 1 :(得分:0)
这是我要获取的页数和当前页数的扩展名。它使用正则表达式在字符串value
中找到两个数字,并假定其中一个较大的是页面数,而较小的一个是当前页面。
它的好处是,即使您的设备/模拟器未设置为英语,它也可以正常工作。
extension XCUIElement {
func currentPageAndNumberOfPages() -> (Int, Int)? {
guard elementType == .pageIndicator, let pageIndicatorValue = value as? String else {
return nil
}
// Extract two numbers. This should be language agnostic.
// Examples: en:"3 of 5", ja:"全15ページ中10ページ目", es:"4 de 10", etc
let regex = try! NSRegularExpression(pattern: "^\\D*(\\d+)\\D+(\\d+)\\D*$", options: [])
let matches = regex.matches(in: pageIndicatorValue, options: [], range: NSRange(location: 0, length: pageIndicatorValue.count))
if matches.isEmpty {
return nil
}
let group1 = matches[0].range(at: 1)
let group2 = matches[0].range(at: 2)
let numberString1 = pageIndicatorValue[Range(group1, in: pageIndicatorValue)!]
let numberString2 = pageIndicatorValue[Range(group2, in: pageIndicatorValue)!]
let number1 = Int(numberString1) ?? 0
let number2 = Int(numberString2) ?? 0
let numberOfPages = max(number1, number2)
var currentPage = min(number1, number2)
// Make it 0 based index
currentPage = currentPage > 0 ? (currentPage - 1) : currentPage
return (currentPage, numberOfPages)
}
/// return current page index (0 based) of an UIPageControl referred by XCUIElement
func currentPage() -> Int? {
return currentPageAndNumberOfPages()?.0 ?? nil
}
/// return number of pages of an UIPageControl referred by XCUIElement
func numberOfPages() -> Int? {
return currentPageAndNumberOfPages()?.1 ?? nil
}
}
您可以像这样使用它:
let pageCount = app.pageIndicators.element(boundBy: 0).numberOfPages() ?? 0
for _ in 0 ..< pageCount {
app.pageIndicators.element(boundBy: 0).swipeLeft()
}