- The names and purposes of the visual parts of the Cypress Test Runner
- How to use the Selector Playground for targeting your page elements
Cypress runs tests in a unique interactive runner that allows you to see commands as they execute while also viewing the application under test.
The lefthand side of the test runner is a visual representation of your test suite. Each test block is properly nested and each test, when clicked, displays every Cypress command and assertion executed within the test’s block as well as any command or assertion executed in relevant
Each command and assertion, when hovered over, restores the Application Under Test (righthand side) to the state it was in when that command executed. This allows you to ‘time-travel’ back to previous states of your application when testing.
By default, Cypress keeps 50 tests worth of snapshots and command data for time traveling. If you are seeing extremely high memory consumption in your browser, you may want to lower the
numTestsKeptInMemoryin your configuration.
Each command, assertion, or error, when clicked on, displays extra information in the dev tools console. Clicking also ‘pins’ the Application Under Test (righthand side) to its previous state when the command executed.
The righthand side of the test runner is used to display the Application Under Test (AUT: the application that was navigated to using a
cy.visit() or any subsequent routing calls made from the visited application.
In the example below, we wrote the following code in our test file:
cy.visit('https://example.cypress.io') cy.title().should('include', 'Kitchen Sink')
In the corresponding Application Preview below, you can see
https://example.cypress.io is being displayed in the righthand side. Not only is the application visible, but it is fully interactable. You can open your developer tools to inspect elements as you would your normal application. The DOM is completely available for debugging.
The AUT also displays in the size and orientation specified in your tests. You can change the size or orientation with the
cy.viewport() command or in your Cypress configuration. If the AUT does not fit within the current browser window, it is scaled appropriately to fit within the window.
The current size and scale of the AUT is displayed in the top right corner of the window.
The image below shows that our application is displaying at
660px height and scaled to
Note: The righthand side may also be used to display syntax errors in your test file that prevent the tests from running.
The Selector Playground is an interactive feature that helps you:
- Determine a unique selector for an element.
- See what elements match a given selector.
- See what element matches a string of text.
Cypress will automatically calculate a unique selector to use targeted element by running through a series of selector strategies.
By default Cypress will favor:
This is configurable
Cypress allows you to control how a selector is determined.
Cypress.SelectorPlaygroundAPI to control the selectors you want returned.
You may find yourself struggling to write good selectors because:
- Your application uses dynamic ID’s and class names
- Your tests break whenever there are CSS or content changes
To help with these common challenges, the Selector Playground automatically prefers certain
data-* attributes when determining a unique selector.
Please read our Best Practices guide on helping you target elements and prevent tests from breaking on CSS or JS changes.
To open the Selector Playground, click the
button next to the URL at the top of the runner. Hover over elements in your app to preview a unique selector for that element in the tooltip.
Click on the element and its selector will appear at the top. From there, you can copy it to your clipboard (
) or print it to the console (
The box at the top that displays the selector is also a text input.
When you edit the selector, it will show you how many elements match and highlight those elements in your app.
You can also experiment with what
cy.contains() would yield given a string of text. Click on
cy.get and switch to
Type in text to see which element it matches. Note that
cy.contains() only yields the first element that matches the text, even if multiple elements on the page contain the text.
If you would like to interact with your app while the Selector Playground is open, the element highlighting might get in the way. Toggling the highlighting off will allow you to interact with your app more easily.