Known Issues
Cross-platform
App does not launch
Either the app is not installed or the appId
is wrong. Note that depending on the app type, the identifier can be different.
To find the appID you can perform the following:
On Android:
Execute
adb shell pm list packages
to get a list of all installed packages.Search for the appID manually or use
grep
in the above command to search for part of the name:adb shell pm list packages | grep <name>
On iOS
Execute
xcrun simctl listapps booted | grep CFBundleIdentifier
to get a list of all installed packagesSearch for the appID manually or use
grep
in the above command to search for part of the name:xcrun simctl listapps booted | grep CFBundleIdentifier | grep <name>
Android
Text input is not supported for unicode
Unfortunately, Maestro does not yet have Android support of inputText
commands that have unicode characters in them (follow this GitHub issue for status updates). Only ASCII characters are supported
Accidental double tap
Sometimes, tapOn will try to tap again if it doesn't detect a hierarchy change. To fix such cases, use retryTapIfNoChange
. For example:
Unable to clear state
When running tests against a real device you may receive an error of (Unable to clear state for app <package>)
when running either:
or:
This error is common on physical devices by Oppo. The workaround is to return to the Developer Settings where ADB Debugging was enabled, and disable 'Verify apps over USB'.
iOS
hideKeyboard
command is flaky
hideKeyboard
command is flakyOn iOS, hideKeyboard
is done with the help of scrolling up and down from the middle of the screen since there is no native API to hide the keyboard.
If using this command doesn't hide the keyboard we recommend clicking on some non-tappable region with tapOn
points command, similar to how a user would hide the keyboard when interacting with your app.
Issues with lists (UICollectionView, UITableView) that fetch data on scroll
Apps that have pagination (fetch data on scroll) inside UITableView / UICollectionView views sometimes result in fetching data at the moments when it is not expected, hanging inside the lists, and flows being broken when testing with Maestro.
There is a bug in XCTest framework that makes UITableView / UICollectionView willDisplayCell
method being called whenever UI test APIs are being called. Since Maestro relies on XCTest APIs under the hood it might break the pagination logic for some apps.
Suggested workaround
Inside willDisplayCell
check whether the indexPath is really visible via UITableView.indexPathsForVisibleRows
or UICollectionView.indexPathsForVisibleItems
:
Last updated