目录
目录README.md

XCAppTest

Utilities for easier interaction with XCUITest methods.

What’s included

  • XCUIElement extensions:

    • Checking existence of elements:
      • assertExists()
      • assertExists(waitForAppToIdle: true)
      • assertNotExists()
      • assertExists(false)
    • Checking interactivity of elements:
      • assertIsHittable()
      • assertIsNotHittable()
      • assertIsHittable(false)
      • assertIsEnabled()
      • assertIsDisabled()
      • assertIsEnabled(false)
      • assertIsInteractive() (exists, isHittable, isEnabled)
    • Checking properties of elements:
      • assertHasLabel("label")
      • assertContainsText("label")
      • assertHasValue("equatable value")
      • assertHasPlaceholder("placeholder")
    • Checking traits of elements:
      • assertIsSelected()
      • assertIsNotSelected()
      • assertIsSelected(false)
    • Performing actions:
      • tapWhenReady()
      • waitForInteractivity()
      • slowTypeText("text")
      • tap(withNormalizedOffset: .center)
  • XCUIApplication extensions:

    • Accessing other apps:
      • XCUIApplication.safari
    • Checking foreground state:
      • assertIsInForeground()
      • assertIsNotInForeground()
      • assertIsInForeground(false)
    • Performing actions:
      • moveToBackground()
  • XCUIElementQuery extensions:

    • Checking number of elements:
      • assertHasCount(2)
      • assertNotExists()
  • CGVector extensions:

    • Normalized offsets:
      • topLeft, top, topRight
      • left, center, right
      • bottomLeft, bottom, bottomRight

All of the above assertion functions have optional message as last parameter that can be used to configure what is displayed if assertion fails. For example: element.assertExists("My element should be visible"). For details see documentation.

Example

Here is a short example from one of my apps that makes use of this library. In the test I am checking that it is possible to navigate to “Premium features” screen, verify that most important data is visible and check that it is possible to leave that screen.

Note that some of the buttons are identified by enum case instead of raw string. You can see type safe identifiers tip below to see how this is implemented.

func testOpenClosePremiumScreen() throws {
    try launch(configuration: .init(premiumUnlocked: false))

    app.buttons[.toggleBottomSheetButton].tap()
    app.buttons["Unlock Premium"].tapWhenReady()
    assertPremiumScreenIsVisible()
    app.buttons[.unlockFeaturesButton].assertIsEnabled().assertContainsText("Lifetime access")
    app.buttons["Restore Purchase"].assertIsEnabled()

    app.buttons["Dismiss"].tap()
    app.staticTexts["Pipilo Premium"].assertNotExists()
}

Installation

Swift Package Manager

  1. Add the following to the dependencies array in your Package.swift file:
.package(url: "https://github.com/Tunous/XCAppTest.git", .upToNextMajor(from: "0.4.0")),
  1. Add XCAppTest as a dependency for your tests target:
.target(name: "MyAppTests", dependencies: ["XCAppTest"]),
  1. Add import XCAppTest in your tests source code.

Xcode

Add https://github.com/Tunous/XCAppTest.git, to the list of Swift packages for your project in Xcode and include it as a dependency on your tests target.

关于
67.0 KB
邀请码
    Gitlink(确实开源)
  • 加入我们
  • 官网邮箱:gitlink@ccf.org.cn
  • QQ群
  • QQ群
  • 公众号
  • 公众号

©Copyright 2023 CCF 开源发展委员会
Powered by Trustie& IntelliDE 京ICP备13000930号