Skip to content

The Settings API

Appium has introduced a set of extension APIs that allow you to adjust parameters for a given session during session execution. Called "Settings", these parameters mirror the role of Capabilities, but Capabilities cannot be adjusted once a session has started. Settings can be adjusted any number of times during the course of a session.

There are 3 important points to the concept of Settings: - Settings are mutable; they can be changed during a session using the Settings API - Settings are only relevant during the session in which they are set. They are typically reset for each new session, though depending on the driver, some settings may persist between sessions. - Settings adjust the way the appium server behaves during test automation. They don't refer to settings for the device or app under test

An example of a setting would be the ignoreUnimportantViews setting recognized by the UiAutomator2 driver. The driver can be instructed to ignore lements in the view hierarchy which it deems irrelevant. Adjusting this setting to have a value of true can cause tests to run faster. But if you want to access elements which would be ignored under this setting, you could always reset it to false later in the session.

Settings are implemented via the following API endpoints:

Command Method/Route Params Description Returns
Update Settings POST /session/:id/appium/settings settings (Record<string, any>) Update setting values. The settings object needs to be a set of keys and values, where keys are the name of the settings and values are whatever value is documented as appropriate for that setting. null
Get Settings GET /session/:id/appium/settings Return the current settings. Record<string, any>

Which settings are available depends on the driver you are using. Refer to the driver's documentation for a list of supported settings.

Initializing Settings via Capabilities

When you want to start an Appium session with a setting in a certain state, you can do so by including a capability of the form appium:settings[<name>] with the appropriate value. So to turn on the ignoreUnimportantViews setting mentioned above from the very beginning of a session, you would construct a set of capabilities that includes the following in its JSON representation:

{
    "appium:settings[ignoreUnimportantViews]": true
}

Of course, initializing a setting via capabilities doesn't prevent you from changing it later on via the Settings API. To learn more about how to use the Settings API in the context of your specific client library, visit the documentation for that library.