Capture Fetch with Cypress

10 November 2020

Contents

To capture the result of a fetch request with Cypress you will need to make use of cy.route2

Setup

The cy.route2 command needs to be enabled in your cypress.json file before usage, to do so add the following:

cypress.json

{
  "experimentalNetworkStubbing": true
}

Usage

Next, using the command to capture requests to a route looks a bit like this in a test:

cy.route2('POST', '/do-stuff').as('data')

In the above you need to use the cy.route2 function. In the above we're capturing POST requests to the /do-stuff endpoint. The object which contains the request and response data is stored in the @data which can be retreived and worked with like so:

cy.wait('@data').then((data) => {
  // do stuff using the data object
  console.log(data)
})

The cy.wait function retreives the data object, we use the .then function with a callback function to do stuff with the fully resolved data object

Furthermore, the HTTP response from the data object can be parsed using JSON.parse, you can then also add assertions based on the response object. Adding this in, the above code would look more like this:

cy.wait('@data').then((data) => {
  console.log(data)

  // parse the response body
  const res = JSON.parse(data.response.body)

  // assertions on the response
  assert.isTrue(res.success)
  assert.isNotNull(res.message)
})