New test to understand better route & request. changed login function without tested it.

This commit is contained in:
Thoscellen 2019-08-22 14:28:29 +02:00
parent 099f346faa
commit f852ffce0b
3 changed files with 65 additions and 54 deletions

View File

@ -0,0 +1,7 @@
{
"status": "error",
"data": [],
"errors": [
"Stub: This email is already registered, please choose another one."
]
}

View File

@ -1,6 +1,5 @@
/// <reference types="Cypress" />
// import userMutoid from '../../fixtures/userMutoid';
var Mutoid;
describe('As a visitor, I am able to log in', function () {
@ -20,40 +19,26 @@ describe('As a visitor, I am able to log in', function () {
});
describe('As a visitor, I can only create an account the right way.', function () {
before(function () {
cy.fixture("userMutoid.json").as("Mutoid").then(() => {
expect(this.Mutoid.email).to.exist;
expect(this.Mutoid.password).to.exist;
Mutoid = this.Mutoid;
});
});
describe('As a visitor, I can only register the right way.', function () {
beforeEach(', go to the login webpage.', function () {
cy.visit("/online");
});
it('Check that the Create Account tab is accessible', function () {
it('Check that the "Create Account" tab is accessible', function () {
// Assert
cy.get('.menu-reg').first().find('a[href$="action=register"]')
.should('be.visible');
cy.get('.menu-reg').first().find('a[href$="action=register"]').should('be.visible');
});
it('Check that the Create Account tab shows a form to fill when active', function () {
it('Check that the "Create Account" tab shows a form to fill when active', function () {
// Act : Visiter le formulaire pour s'inscrire.
cy.get('.menu-reg').find('a[href$="action=register"]').click();
// Assert
cy.url().should('include', '?action=register');
// L'onglet "Create accout" possède la classe "active".
cy.get('.menu-reg').find('a[href$="action=register"]').should('have.class', 'active')
// Les formulaires existent et sont visible
cy.get('input#register-email')
.should('be.visible');
cy.get('input#register-password')
.should('be.visible');
// Le bouton "Create Account" existe.
cy.get('#register-form').find(":submit");
cy.get('.menu-reg').find('a[href$="action=register"]').should('have.class', 'active') // L'onglet "Create accout" possède la classe "active".
cy.get('input#register-email').should('be.visible'); // Les formulaires existent et sont visible
cy.get('input#register-password').should('be.visible');
cy.get('#register-form').find(":submit"); // Le bouton "Create Account" existe.
});
it('Allow to land directly on the Register page', function () {
@ -82,30 +67,54 @@ describe('As a visitor, I can only create an account the right way.', function (
it('Prevent to create an account with an already existing account', function () {
// Arrange
cy.get('.menu-reg').first().find('a[href$="action=register"]').click();
cy.fixture("users.json").as("users").then((users) => {
let mutoid = users["Mutoid"];
expect(mutoid.email).to.exist;
expect(mutoid.password).to.exist;
expect(mutoid.type).eq("user");
cy.get('.menu-reg').first().find('a[href$="action=register"]').click();
// Act
cy.get('input#register-email').type(Mutoid.email);
cy.get('input#register-password').type(Mutoid.password);
cy.get('#register-form').find(":submit").click();
// Act
cy.get('input#register-email').type(mutoid.email);
cy.get('input#register-password').type(mutoid.password);
cy.get('#register-form').find(":submit").click();
// Assert
cy.get('input#register-email').should('have.class', 'input_error');
cy.get('input#register-password').should('have.class', 'input_error');
cy.get('div#register-error')
.should('be.visible')
.and('contain', 'This email is already registered, please choose another one.')
// Assert
cy.get('input#register-email').should('have.class', 'input_error');
cy.get('input#register-password').should('have.class', 'input_error');
cy.get('div#register-error')
.should('be.visible')
.and('contain', 'This email is already registered, please choose another one.')
});
})
it.only('Check that it explain correclty to the user when he try to create an already exxisting account', function () {
cy.server();
cy.fixture("users.json").as("users").then((users) => {
let mutoid = users["Mutoid"];
cy.route("online/api/user", "fx:/errors/registerExistingUser.json");
cy.request({
method:'POST',
url:"online/api/user",
body:mutoid,
failOnStatusCode:false,
qs:"t=" + new Date().getTime(),
});
});
})
});
describe.only("As a user, I can only log in and out the right way", function () {
describe("As a user, I can only log in and out the right way", function () {
before(function () {
cy.fixture("users.json").as("users").then((users) => {
Mutoid = users["Mutoid"];
expect(Mutoid.email).to.exist;
expect(Mutoid.password).to.exist;
expect(Mutoid.type).eq("user");
mutoid = users["Mutoid"];
expect(mutoid.email).to.exist;
expect(mutoid.password).to.exist;
expect(mutoid.type).eq("user");
});
})
@ -113,7 +122,6 @@ describe.only("As a user, I can only log in and out the right way", function ()
cy.visit("/online");
})
it('Prevent to log in with empty credentials', function () {
// Act
cy.get('form#login-form').find(':submit').click();
@ -132,7 +140,7 @@ describe.only("As a user, I can only log in and out the right way", function ()
// Act
cy.get("#login-email").type(Mutoid.email);
cy.get("#login-email").type(mutoid.email);
cy.get('form#login-form').find(':submit').click();
// Assert
cy.url().should('include', '?action=login'); // Pas de redirection
@ -146,7 +154,7 @@ describe.only("As a user, I can only log in and out the right way", function ()
it('Prevent to log in with just the password', function () {
// Act
cy.get("#login-password").type(Mutoid.password)
cy.get("#login-password").type(mutoid.password)
cy.get('form#login-form').find(':submit').click();
// Assert
cy.url().should('include', '?action=login'); // Pas de redirection
@ -158,10 +166,10 @@ describe.only("As a user, I can only log in and out the right way", function ()
cy.get('input#login-password').should('have.class', 'input_error');
})
it('Prevent to log in Mutoid with an invalid password', function () {
it('Prevent to log in mutoid with an invalid password', function () {
// Act
cy.get("#login-email").type(Mutoid.email)
cy.get("#login-password").type(Mutoid.email)
cy.get("#login-email").type(mutoid.email)
cy.get("#login-password").type(mutoid.email)
cy.get('form#login-form').find(':submit').click();
// Assert
cy.url().should('include', '?action=login'); // Pas de redirection
@ -175,8 +183,8 @@ describe.only("As a user, I can only log in and out the right way", function ()
it('Logs Mutoid in.', function () {
// Act
cy.get("#login-email").type(Mutoid.email)
cy.get("#login-password").type(Mutoid.password)
cy.get("#login-email").type(mutoid.email)
cy.get("#login-password").type(mutoid.password)
cy.get("#login-form").find(":submit").click()
// Assert
cy.url().should('contain', '/online/#/reader/category/all/')
@ -186,7 +194,7 @@ describe.only("As a user, I can only log in and out the right way", function ()
it('Logs Mutoid in via API', function () {
// act
cy.login(Mutoid);
cy.login(mutoid);
cy.visit("/online");
// assert
cy.getCookie('session').should('exist');
@ -194,7 +202,7 @@ describe.only("As a user, I can only log in and out the right way", function ()
it('Logs Mutoid out.', function () {
// Arrange
cy.login(Mutoid)
cy.login(mutoid)
cy.visit('/online');
// act
cy.get("div#user").find("a.user__settings").click();

View File

@ -3,11 +3,7 @@ Cypress.Commands.add('login', function (user) {
cy.request({
method: 'POST',
url: "/online/api/auth?t=" + new Date().getTime(),
body: {
"email": user.email,
"password": user.password,
"remember": false
}
body: user
}).as("response")
});