Skip to main content

Specify devices using regular expressions (regex)

Specify devices using regular expressions on BrowserStack’s Private Devices

BrowserStack’s Dynamic Device Allocation (DDA) allows you to use regular expressions (regex) to specify device attributes, enabling flexible and efficient test execution.

This feature is currently available only on Appium.

Use regex to specify device attributes

You can use regex to select devices for testing instead of providing specific device models or OS versions. Based on the regex you provide, an available device is allocated from the device pool that matches your specifications.

Capability Required/Optional Description Sample Values
platformName Required Specify the mobile operating system that you wish to test on android or ios
deviceName Required Specify the device name or use regular expression, a matching device based on your specification will be allocated Samsung .* allocates any Samsung device
iPhone [67]$ allocates iPhone 6 or iPhone 7
platformVersion Optional Provide major OS version or range of OS versions using regex 1[012] allocates version 10, 11 or 12
deviceType Optional Specify the type of device phone for phone or tablet for a tablet

Note the following while using the platformVersion capability:

  • Minor and patch OS versions are not honored in the platformVersion capability.
  • Escape characters are not supported.

Example: Using regex in browserstack.yml

Here’s an example of running a test on any Samsung Galaxy S series phone with an Android version between 10 and 12:

You can run tests on a wider set of devices. For example, to run tests on any Samsung Galaxy S series device refer to the following syntax:

browserstack.yml
Copy icon Copy
userName: "<user name>"
accessKey: "<access key>"
app: bs://sample.app
platforms:
  - platformName: android
    deviceName: Samsung Galaxy S*
    platformVersion: "1[012]"
    dedicatedDevice: true
browserstackLocal: true
dedicatedDevice: true
buildName: browserstack-build-1
projectName: BrowserStack Sample

The following code snippet demonstrates running a test from a pool of two devices:

browserstack.yml
Copy icon Copy
userName: "<user name>"
accessKey: "<access key>"
app: bs://sample.app
platforms:
  - platformName: android
    deviceName: Samsung Galaxy A52|Xiaomi Redmi Note 8
    platformVersion: "9.0|11.0"
    dedicatedDevice: true
browserstackLocal: true
dedicatedDevice: true
buildName: browserstack-build-1
projectName: BrowserStack Sample

If you are using the legacy mode of integrating your test suite, refer to DDA App Automate Legacy.

Differences between Private and Public Cloud DDA

Feature Public cloud DDA Private Devices DDA
Device pool All devices in infrastructure Limited to devices assigned to your GID
Team allocation Not applicable Limited to devices available to the team
Session failures or delays Rare, due to large device pool Possible, due to limited device pool
Device availability High, as all devices are available Limited to assigned devices

We're sorry to hear that. Please share your feedback so we can do better

Contact our Support team for immediate help while we work on improving our docs.

We're continuously improving our docs. We'd love to know what you liked





Thank you for your valuable feedback

Is this page helping you?

Yes
No

We're sorry to hear that. Please share your feedback so we can do better

Contact our Support team for immediate help while we work on improving our docs.

We're continuously improving our docs. We'd love to know what you liked





Thank you for your valuable feedback!

Talk to an Expert
Download Copy Check Circle