airtap-multi
Version:
Use multiple browser providers as one
106 lines (71 loc) • 2.41 kB
Markdown
**Use multiple [browser providers](https://github.com/airtap/browser-provider) as one.**
[](https://www.npmjs.org/package/airtap-multi)
[](https://www.npmjs.org/package/airtap-multi)
[](http://travis-ci.com/airtap/multi)
[](https://standardjs.com)
```js
const Multi = require('airtap-multi')
const multi = new Multi()
multi.add('airtap-playwright')
multi.add('airtap-sauce')
// Get manifests with name 'firefox'
const manifests = await multi.manifests([{
name: 'firefox'
}])
// Only from the airtap-sauce provider
const manifests = await multi.manifests([{
name: 'firefox',
provider: 'airtap-sauce'
}])
// Instantiate a browser (see browser-provider for details)
const browser = multi.browser(manifest, target)
```
Implements the [`browser-provider`](https://github.com/airtap/browser-provider) interface with a few additional methods.
Add a provider that's been installed in a nearby `node_modules`. The optional `options` object will be passed to the provider's constructor.
Add multiple providers in the form of `{ [id]: options }`:
```js
multi.add({
'airtap-sauce': {
username: 'example',
key: 'secret'
}
})
```
If the second `options` argument is provided, those options will be deeply merged into the options of each provider.
Add a provider as a constructor function.
Add multiple providers using an array, where each array element is of the above types (string, object or function).
### `provider = multi.get(id)`
Get an added provider by its id.
```js
for (const [id, provider] of multi) {
// ..
}
```
```js
for (const id of multi.keys()) {
// ..
}
```
```js
for (const provider of multi.values()) {
// ..
}
```
With [npm](https://npmjs.org) do:
```
npm install airtap-multi
```
[](LICENSE.md) © 2020-present Airtap contributors