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:
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:
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
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!