title |
---|
viewport |
Control the size and orientation of the screen for your application.
{% note info %}
You can set the viewport's width and height globally by defining viewportWidth
and viewportHeight
in the {% url 'configuration' configuration %}.
{% endnote %}
cy.viewport(width, height)
cy.viewport(preset, orientation)
cy.viewport(width, height, options)
cy.viewport(preset, orientation, options)
{% fa fa-check-circle green %} Correct Usage
cy.viewport(550, 750) // Set viewport to 550px x 750px
cy.viewport('iphone-6') // Set viewport to 375px x 667px
{% fa fa-angle-right %} width (Number)
Width of viewport in pixels (must be a non-negative, finite number).
{% fa fa-angle-right %} height (Number)
Height of viewport in pixels (must be a non-negative, finite number).
{% fa fa-angle-right %} preset (String)
A preset dimension to set the viewport. Preset supports the following options:
Preset | width | height |
---|---|---|
ipad-2 |
768 | 1024 |
ipad-mini |
768 | 1024 |
iphone-3 |
320 | 480 |
iphone-4 |
320 | 480 |
iphone-5 |
320 | 568 |
iphone-6 |
375 | 667 |
iphone-6+ |
414 | 736 |
iphone-x |
375 | 812 |
iphone-xr |
414 | 896 |
macbook-11 |
1366 | 768 |
macbook-13 |
1280 | 800 |
macbook-15 |
1440 | 900 |
samsung-note9 |
414 | 846 |
samsung-s10 |
360 | 760 |
{% fa fa-angle-right %} orientation (String)
The orientation of the screen. The default orientation is portrait
. Pass landscape
as the orientation to reverse the width/height.
{% fa fa-angle-right %} options (Object)
Pass in an options object to change the default behavior of cy.viewport()
.
Option | Default | Description |
---|---|---|
log |
true |
{% usage_options log %} |
{% yields null cy.viewport %}
cy.viewport(1024, 768)
describe('Nav Menus', () => {
context('720p resolution', () => {
beforeEach(() => {
// run these tests as if in a desktop
// browser with a 720p monitor
cy.viewport(1280, 720)
})
it('displays full header', () => {
cy.get('nav .desktop-menu').should('be.visible')
cy.get('nav .mobile-menu').should('not.be.visible')
})
})
context('iphone-5 resolution', () => {
beforeEach(() => {
// run these tests as if in a mobile browser
// and ensure our responsive UI is correct
cy.viewport('iphone-5')
})
it('displays mobile menu on click', () => {
cy.get('nav .desktop-menu').should('not.be.visible')
cy.get('nav .mobile-menu')
.should('be.visible')
.find('i.hamburger').click()
cy.get('ul.slideout-menu').should('be.visible')
})
})
})
const sizes = ['iphone-6', 'ipad-2', [1024, 768]]
describe('Logo', () => {
sizes.forEach((size) => {
// make assertions on the logo using
// an array of different viewports
it(`Should display logo on ${size} screen`, () => {
if (Cypress._.isArray(size)) {
cy.viewport(size[0], size[1])
} else {
cy.viewport(size)
}
cy.visit('https://www.cypress.io')
cy.get('#logo').should('be.visible')
})
})
})
{% imgTag /img/api/viewport/loop-through-an-array-of-multiple-viewports.png "Command Log of multiple viewports" %}
cy.viewport('iphone-6') // viewport will change to 414px x 736px
// the viewport will now be changed to 736px x 414px
// and simulates the user holding the iPhone in landscape
cy.viewport('iphone-6', 'landscape')
This is something Cypress will eventually do, which will match how Chrome's responsive mobile browsing simulation works. Follow {% issue 7075 %} if you need this supported.
When hovering over each command, Cypress will automatically display the snapshot in the viewport dimensions that existed when that command ran.
By default, until you issue a cy.viewport()
command, Cypress sets the width to 1000px
and the height to 660px
by default.
You can {% url 'change these default dimensions' configuration#Viewport %} by adding the following to your configuration file (cypress.json
by default):
{
"viewportWidth": 1000,
"viewportHeight": 660
}
Additionally, Cypress automatically sets the viewport to its default size between each test.
By default, if your screen is not large enough to display all of the current dimension's pixels, Cypress will scale and center your application within the Cypress runner to accommodate.
Scaling the app should not affect any calculations or behavior of your application (in fact it won't even know it's being scaled).
The upsides to this are that tests should consistently pass or fail regardless of a developers' screen size. Tests will also consistently run in CI
because all of the viewports will be the same no matter what machine Cypress runs on.
{% requirements parent cy.viewport %}
{% assertions none cy.viewport %}
{% timeouts none cy.viewport %}
Change viewport size to test responsive nav
cy.get('#navbar').should('be.visible')
cy.viewport(320, 480)
// the navbar should have collapse since our screen is smaller
cy.get('#navbar').should('not.be.visible')
cy.get('.navbar-toggle').should('be.visible').click()
cy.get('.nav').find('a').should('be.visible')
The commands above will display in the Command Log as:
{% imgTag /img/api/viewport/viewport-size-width-and-height-changes-and-is-shown-in-the-commands.png "Command Log viewport" %}
When clicking on viewport
within the command log, the console outputs the following:
{% imgTag /img/api/viewport/console-log-shows-width-and-height-of-tested-viewport.png "Console Log viewport" %}
{% history %}
{% url "3.8.0" changelog#3-8-0 %} | Removed max viewport size and lowered min viewport size to 0
.
{% url "3.5.0" changelog#3-5-0 %} | Added support for presets iphone-xr
, iphone-x
, samsung-s10
, and samsung-note9
{% url "3.5.0" changelog#3-5-0 %} | Increased max viewport size to 4000
{% url "0.9.0" changelog#0-9-0 %} | cy.viewport()
command added
{% endhistory %}
- {% url 'configuration' configuration %}