2019-09-11 18:53:05 +02:00
|
|
|
/// <reference types="Cypress" />
|
|
|
|
|
|
|
|
/// JSON fixture file can be loaded directly using
|
|
|
|
// the built-in JavaScript bundler
|
|
|
|
// @ts-ignore
|
2022-02-10 20:32:21 +01:00
|
|
|
const requiredExample = require('../../fixtures/example');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
context('Files', () => {
|
|
|
|
beforeEach(() => {
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.visit('https://example.cypress.io/commands/files');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
// load example.json fixture file and store
|
|
|
|
// in the test context object
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.fixture('example.json').as('example');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.fixture() - load a fixture', () => {
|
|
|
|
// https://on.cypress.io/fixture
|
|
|
|
|
|
|
|
// Instead of writing a response inline you can
|
|
|
|
// use a fixture file's content.
|
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.server();
|
|
|
|
cy.fixture('example.json').as('comment');
|
2019-09-11 18:53:05 +02:00
|
|
|
// when application makes an Ajax request matching "GET comments/*"
|
|
|
|
// Cypress will intercept it and reply with object
|
|
|
|
// from the "comment" alias
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.route('GET', 'comments/*', '@comment').as('getComment');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// we have code that gets a comment when
|
|
|
|
// the button is clicked in scripts.js
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.get('.fixture-btn').click();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.wait('@getComment')
|
|
|
|
.its('responseBody')
|
2019-09-11 18:53:05 +02:00
|
|
|
.should('have.property', 'name')
|
2022-02-10 20:32:21 +01:00
|
|
|
.and('include', 'Using fixtures to represent data');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// you can also just write the fixture in the route
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.route('GET', 'comments/*', 'fixture:example.json').as('getComment');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// we have code that gets a comment when
|
|
|
|
// the button is clicked in scripts.js
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.get('.fixture-btn').click();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.wait('@getComment')
|
|
|
|
.its('responseBody')
|
2019-09-11 18:53:05 +02:00
|
|
|
.should('have.property', 'name')
|
2022-02-10 20:32:21 +01:00
|
|
|
.and('include', 'Using fixtures to represent data');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// or write fx to represent fixture
|
|
|
|
// by default it assumes it's .json
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.route('GET', 'comments/*', 'fx:example').as('getComment');
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// we have code that gets a comment when
|
|
|
|
// the button is clicked in scripts.js
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.get('.fixture-btn').click();
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.wait('@getComment')
|
|
|
|
.its('responseBody')
|
2019-09-11 18:53:05 +02:00
|
|
|
.should('have.property', 'name')
|
2022-02-10 20:32:21 +01:00
|
|
|
.and('include', 'Using fixtures to represent data');
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.fixture() or require - load a fixture', function () {
|
|
|
|
// we are inside the "function () { ... }"
|
|
|
|
// callback and can use test context object "this"
|
|
|
|
// "this.example" was loaded in "beforeEach" function callback
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(this.example, 'fixture in the test context').to.deep.equal(requiredExample);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// or use "cy.wrap" and "should('deep.equal', ...)" assertion
|
|
|
|
// @ts-ignore
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.wrap(this.example, 'fixture vs require').should('deep.equal', requiredExample);
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.readFile() - read a files contents', () => {
|
|
|
|
// https://on.cypress.io/readfile
|
|
|
|
|
|
|
|
// You can read a file and yield its contents
|
|
|
|
// The filePath is relative to your project's root.
|
|
|
|
cy.readFile('cypress.json').then((json) => {
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(json).to.be.an('object');
|
|
|
|
});
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
it('cy.writeFile() - write to a file', () => {
|
|
|
|
// https://on.cypress.io/writefile
|
|
|
|
|
|
|
|
// You can write to a file
|
|
|
|
|
|
|
|
// Use a response from a request to automatically
|
|
|
|
// generate a fixture file for use later
|
2022-02-10 20:32:21 +01:00
|
|
|
cy.request('https://jsonplaceholder.cypress.io/users').then((response) => {
|
|
|
|
cy.writeFile('cypress/fixtures/users.json', response.body);
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
cy.fixture('users').should((users) => {
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(users[0].name).to.exist;
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
// JavaScript arrays and objects are stringified
|
|
|
|
// and formatted into text.
|
|
|
|
cy.writeFile('cypress/fixtures/profile.json', {
|
|
|
|
id: 8739,
|
|
|
|
name: 'Jane',
|
|
|
|
email: 'jane@example.com',
|
2022-02-10 20:32:21 +01:00
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
cy.fixture('profile').should((profile) => {
|
2022-02-10 20:32:21 +01:00
|
|
|
expect(profile.name).to.eq('Jane');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|