2020-02-19 15:55:06 +11:00
|
|
|
// ***********************************************
|
|
|
|
// This example commands.js shows you how to
|
|
|
|
// create various custom commands and overwrite
|
|
|
|
// existing commands.
|
|
|
|
//
|
|
|
|
// For more comprehensive examples of custom
|
|
|
|
// commands please read more here:
|
|
|
|
// https://on.cypress.io/custom-commands
|
|
|
|
// ***********************************************
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check the swagger schema:
|
|
|
|
*
|
|
|
|
* @param {string} method API Method in swagger doc, "get", "put", "post", "delete"
|
2020-08-06 12:47:24 +10:00
|
|
|
* @param {number} statusCode API status code in swagger doc
|
2020-02-19 15:55:06 +11:00
|
|
|
* @param {string} path Swagger doc endpoint path, exactly as defined in swagger doc
|
|
|
|
* @param {*} data The API response data to check against the swagger schema
|
|
|
|
*/
|
2020-08-06 12:47:24 +10:00
|
|
|
Cypress.Commands.add('validateSwaggerSchema', (method, statusCode, path, data) => {
|
2020-02-19 15:55:06 +11:00
|
|
|
cy.task('validateSwaggerSchema', {
|
|
|
|
file: Cypress.env('swaggerBase'),
|
|
|
|
endpoint: path,
|
|
|
|
method: method,
|
2020-08-06 12:47:24 +10:00
|
|
|
statusCode: statusCode,
|
2020-02-19 15:55:06 +11:00
|
|
|
responseSchema: data,
|
|
|
|
verbose: true
|
|
|
|
}).should('equal', null);
|
|
|
|
});
|
|
|
|
|
|
|
|
Cypress.Commands.add('getToken', () => {
|
2020-08-06 11:57:31 +10:00
|
|
|
// login with existing user
|
|
|
|
cy.task('backendApiPost', {
|
|
|
|
path: '/api/tokens',
|
2020-02-19 15:55:06 +11:00
|
|
|
data: {
|
2020-08-06 12:47:24 +10:00
|
|
|
identity: 'admin@example.com',
|
|
|
|
secret: 'changeme'
|
2020-02-19 15:55:06 +11:00
|
|
|
}
|
2020-08-06 11:57:31 +10:00
|
|
|
}).then(res => {
|
2020-08-06 12:47:24 +10:00
|
|
|
cy.wrap(res.token);
|
2020-02-19 15:55:06 +11:00
|
|
|
});
|
|
|
|
});
|