swipe

Swipe gestures in any direction with customizable speed and distance.

The swipe command simulates a swipe gesture on the device screen. You can define a swipe by direction, by coordinates, or by starting from a specific UI element.

Parameters

Depending on the swipe behavior you expected, you need to choose between the following available parameters.

Parameter
Description

start

The starting coordinate for the swipe. Specify as x, y pixel coordinates or as x%, y% percentages relative to the screen dimensions.

end

The ending coordinate for the swipe. Specify as x, y pixel coordinates or as x%, y% percentages relative to the screen dimensions.

direction

The direction of the swipe. Accepts LEFT, RIGHT, UP, or DOWN. This parameter cannot be used with start and end.

from

An element selector to use as the starting point for the swipe. The swipe begins from the center of the specified element. Use the selectors available to define the element. Cannot be used with start and end.

duration

The duration of the swipe in milliseconds. A longer duration results in a slower swipe. Default: 400 milliseconds.

waitToSettleTimeoutMs

The maximum time in milliseconds to wait for the screen to settle before executing the next command. This is a best-effort timeout and does not interrupt core operations. Useful for screens with continuous animations like countdown timers.

Usage examples

The swipe command can be configured in several ways to accommodate different testing scenarios.

Swipe by direction

This example performs a swipe from the right to the left of the screen.

- swipe:
    direction: LEFT

The direction parameter uses the following relative start and end coordinates:

Direction
Start (width%, height%)
End (width%, height%)

LEFT

(90% of width, 50% of height)

(10% of width, 50% of height)

RIGHT

(10% of width, 50% of height)

(90% of width, 50% of height)

DOWN

(50% of width, 20% of height)

(50% of width, 90% of height)

UP

(50% of width, 50% of height)

(50% of width, 10% of height)

Swipe from an element

The swipe uses the same end points as a directional swipe in the chosen direction: the start is the center of the element, and the end follows that direction (e.g. for LEFT, 10% of screen width at the same vertical position).

This example initiates a swipe that starts from the center of the element with the ID feeditem_identifier and moves up.

Swipe by relative coordinates

This example performs a horizontal swipe from the right edge to the left edge of the screen using percentages. This approach ensures the gesture is consistent across devices with different screen dimensions.

Swipe by absolute coordinates

This example performs a swipe between two points defined by absolute pixel coordinates.

circle-exclamation

Swipe with a custom duration

This example performs a slow swipe by using a duration of 2000 milliseconds.

Swipe with a custom settle timeout

This example limits the time Maestro waits for the UI to settle after the swipe to 500 milliseconds.

Last updated