GitXplorerGitXplorer
I

DropBear

public
26 stars
5 forks
4 issues

Commits

List of commits on branch master.
Verified
c602e0c9c7840b8626e69c9f8d4179659fe32670

Merge pull request #34 from IanKeen/ikeen_ergonomic_improvements

IIanKeen committed 2 years ago
Unverified
ae9281db0d22bf26c5cf5c974e4e3422cd8b8b98

Add shims to avoid the `.element` wrapping when dealing with sets

IIanKeen committed 2 years ago
Unverified
d9119c5a0e2f8afb3ce3b4ff7791ffe7a9a29bb1

Increase elementset arity

IIanKeen committed 2 years ago
Unverified
fae2d040cb9b4384462125c900f2923684805359

Update dropbeargen-0.14.1.zip

IIanKeen committed 2 years ago
Unverified
bfa2cc47943a59cfad933c1880aabe61663dcc85

Update SwiftSyntax

IIanKeen committed 2 years ago
Unverified
8ffcdda2d08c6be3b5e28493a44a41144bcdbb9f

Update podspecs

IIanKeen committed 2 years ago

README

The README file for this repository.

DropBear

Requirements

Coming soon

Installation

Note: For information on installing DropBearGen or DropBearSupport, view their respective READMEs.

Using CocoaPods

Simply add the following line to your UI Test target in your Podfile:

pod 'DropBear'

Robots

Coming soon

Assertion System

DropBear's assertion system can work either as an extension on current XCUI Test capabilities, or it can be paired with DropBear's Robot pattern, shown above.

When used along with DropBear's Robot pattern, assertions also become chainable, giving you clean and concise readability without losing your place as you write your tests.

To better highlight the features of the assertion system, we've broken it out in to two parts.

Assertions

Empty

The .empty assertion is used to check if a String-based value is empty. This will also return true if a UITextField's placeholder value matches the current value of the UITextField.

Example usage:

FooRobot()
    .assert(.fooTextField, .empty)

Enabled

The .enabled assertion is a simple wrapped around element.isEnabled, and can be used with any element type.

Example usage:

FooRobot()
    .assert(.fooButton, .enabled)

Equal

The .equal assertion compares the element's value to another value that the assertion accepts as a parameter. Currently, the accepted types that can be used to validate with are Bool, Double, Int, and String.

Note: The assertion compares values as lowercase, making this assertion case-insensitive.

Example usage:

FooRobot()
    .assert(.fooTextField, .equal(to: "Hello, world!"))

Exists

The .exists assertion checks for the existence of the speicified element. By default, using this assertion will wait for the existence of the element for 5 seconds, after which time it will fail if the element does not exist.

If you would like to override the amount of time that the test waits for the element to exist, DropBear also provides a mechanism for accomplishing that.

Example usage:

FooRobot()
    .assert(.fooTextField, .exists) // Will wait for up to 5 seconds for existence

or

FooRobot()
    .assert(.fooTextField, .exists(waiting: 10)) // Will wait for up to 10 seconds for existence

Contains

The .contains assertion checks the label and value properties of the element for any matches against the parameter passed into the assertion. The only acceptable parameter type is String.

Assuming our example UITextField has a value of Hello, world!, the following example usage would assert true.

Example usage:

FooRobot()
    .assert(.fooTextField, .contains("world"))

Operators

DropBear's assertion system also provides operators for simplifying your test writing.

!

The ! operator is a method that takes an assertion as the only unnamed parameter. This operator inverts the result of the assertion it takes, giving you a not-style result.

FooRobot()
    .assert(.fooTextField, !(.exists))

&&

The && operator evaluates two or more assertion results and only asserts true if all results are true.

FooRobot()
    .assert(.fooTextField, .exists && .contains("world"))

||

The || operator evaluates two or more assertion results and asserts true if any results are true.

FooRobot()
    .assert(.fooTextField, .exists || .contains("world"))