Browser configuration
Eyes-Storybook will take a screenshot of the page as specified in the browser
configuration parameter.
Possible values are:
chrome
firefox
edgechromium
edgelegacy
ie10
ie11
safari
chrome-one-version-back
chrome-two-versions-back
firefox-one-version-back
firefox-two-versions-back
safari-one-version-back
safari-two-versions-back
edgechromium-one-version-back
edgechromium-two-versions-back
Previous browser versions
*-one-version-back
and *-two-versions-back
are relative to the version of the same browser. For example, if chrome
refers to version 112, then chrome-one-version-back
will be Chrome 111 and chrome-two-versions-back
will be Chrome 110.
Getting a screenshot of multiple browsers in parallel
You can send an array of browsers.
Example
module.exports = {
browser: [
{width: 800, height: 600, name: 'firefox'},
{width: 1024, height: 768, name: 'chrome'},
{width: 1024, height: 768, name: 'ie11'}
]
}
Device emulation
To enable Chrome's device emulation, you can send a device name and screen orientation.
Example
module.exports = {
browser: {
deviceName: 'iPhone 16',
screenOrientation: 'landscape',
name: 'chrome' // optional, just to make it explicit this is browser emulation and not a real device. Only chrome is supported for device emulation.
}
}
Possible values for screen orientation are landscape
and portrait
. If no value is specified, the default is portrait
.
The list of device names is available here.
In addition, you can use Chrome's device emulation with custom viewport sizes, pixel density, and mobile mode, by passing deviceScaleFactor
and mobile
in addition to width
and height
.
Example
module.exports = {
browser: {
width: 800,
height: 600,
deviceScaleFactor: 3,
mobile: true,
name: 'chrome' // optional, just to make it explicit this is browser emulation and not a real device. Only chrome is supported for device emulation.
}
}
iOS device
Example
module.exports = {
browser: {
iosDeviceInfo: {
deviceName: 'iPhone XR',
screenOrientation: 'landscape', // optional, default: 'portrait'
iosVersion: 'latest' // optional, default: undefined (i.e. the default is determined by the Ultrafast grid)
},
}
}
The list of devices is available here.
Possible values for iosVersion
are:
'latest'
- the latest iOS version that's supported by the UFG'latest-1'
- one version prior to the latest versionundefined
- the UFG's default
Faking IE Browser
Some pages render differently on Internet Explorer and as such, it may be important to take the DOM snapshot while running on a fake IE browser using the Ultrafast Grid.
Use the fakeIE
flag to render the stories in Chrome masquerading as IE.
We do this by simulating the userAgent
and documentMode
of the page, making the page believe it is being rendered on IE.
There is a small performance impact when using fake IE tests as the browser needs to fake IE for each story it renders.