mirror of
https://github.com/elyby/accounts-frontend.git
synced 2025-05-31 14:11:58 +05:30
#389: automatically revoke account, when user clicks back during re-login
This commit is contained in:
@@ -1,5 +0,0 @@
|
||||
{
|
||||
"name": "Using fixtures to represent data",
|
||||
"email": "hello@cypress.io",
|
||||
"body": "Fixtures are a great way to mock data for responses to routes"
|
||||
}
|
||||
@@ -1,15 +1,15 @@
|
||||
import { account1, account2 } from '../fixtures/accounts.json';
|
||||
|
||||
const multiAccount
|
||||
= '{"accounts":{"available":[{"id":7,"username":"SleepWalker","email":"danilenkos@auroraglobal.com","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbHktc2NvcGVzIjoiYWNjb3VudHNfd2ViX3VzZXIiLCJpYXQiOjE1MTgzNzM4MDksImV4cCI6MTUxODM3NzQwOSwic3ViIjoiZWx5fDciLCJqdGkiOjM1NDh9.Fv4AbJ0iDbrH3bhbgF0ViJLfYYiwH78deR4fMlMhKrQ","refreshToken":"3gh6ZZ3R9jGeFdp0TmlY7sd0zBxH6Zfq48M86eUAv952RcAKx32RAnjlKkgd6i-MV-RKbjtADIdoRwMUWOYQjEYtwwXPjcQJ"},{"id":102,"username":"test","email":"admin@udf.su","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbHktc2NvcGVzIjoiYWNjb3VudHNfd2ViX3VzZXIiLCJpYXQiOjE1MTgzNzM4NjUsImV4cCI6MTUxODM3NzQ2NSwic3ViIjoiZWx5fDEwMiIsImp0aSI6MzU0OX0.eJEgvXT3leGqBe3tYNGZb0E4WEvWfrLPjcD7eNjyQYO","refreshToken":"Al75SIx-LFOCP7kaqZBVqMVmSljJw9_bdFQGyuM64c6ShP7YsXbkCD8vPOundAwUDfRZqsIbOHUROmAHPB0VBfjLfw96yqxx"}],"active":102},"user":{"id":102,"uuid":"e49cafdc-6e0c-442d-b608-dacdb864ee34","username":"test","token":"","email":"admin@udf.su","maskedEmail":"","avatar":"","lang":"en","isActive":true,"isOtpEnabled":true,"shouldAcceptRules":false,"passwordChangedAt":1478961317,"hasMojangUsernameCollision":true,"isGuest":false,"registeredAt":1478961317,"elyProfileLink":"http://ely.by/u102","originalResponse":{}}}';
|
||||
const singleAccount
|
||||
= '{"accounts":{"available":[{"id":102,"username":"test","email":"admin@udf.su","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbHktc2NvcGVzIjoiYWNjb3VudHNfd2ViX3VzZXIiLCJpYXQiOjE1MTgzNzM4NjUsImV4cCI6MTUxODM3NzQ2NSwic3ViIjoiZWx5fDEwMiIsImp0aSI6MzU0OX0.eJEgvXT3leGqBe3tYNGZb0E4WEvWfrLPjcD7eNjyQYO","refreshToken":"Al75SIx-LFOCP7kaqZBVqMVmSljJw9_bdFQGyuM64c6ShP7YsXbkCD8vPOundAwUDfRZqsIbOHUROmAHPB0VBfjLfw96yqxx"}],"active":102},"user":{"id":102,"uuid":"e49cafdc-6e0c-442d-b608-dacdb864ee34","username":"test","token":"","email":"admin@udf.su","maskedEmail":"","avatar":"","lang":"en","isActive":true,"isOtpEnabled":true,"shouldAcceptRules":false,"passwordChangedAt":1478961317,"hasMojangUsernameCollision":true,"isGuest":false,"registeredAt":1478961317,"elyProfileLink":"http://ely.by/u102","originalResponse":{}}}';
|
||||
|
||||
describe('when user\'s token and refreshToken are invalid', () => {
|
||||
beforeEach(() =>
|
||||
cy
|
||||
.visit('/')
|
||||
.then(() =>
|
||||
localStorage.setItem(
|
||||
'redux-storage',
|
||||
'{"accounts":{"available":[{"id":7,"username":"SleepWalker","email":"danilenkos@auroraglobal.com","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbHktc2NvcGVzIjoiYWNjb3VudHNfd2ViX3VzZXIiLCJpYXQiOjE1MTgzNzM4MDksImV4cCI6MTUxODM3NzQwOSwic3ViIjoiZWx5fDciLCJqdGkiOjM1NDh9.Fv4AbJ0iDbrH3bhbgF0ViJLfYYiwH78deR4fMlMhKrQ","refreshToken":"3gh6ZZ3R9jGeFdp0TmlY7sd0zBxH6Zfq48M86eUAv952RcAKx32RAnjlKkgd6i-MV-RKbjtADIdoRwMUWOYQjEYtwwXPjcQJ"},{"id":102,"username":"test","email":"admin@udf.su","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbHktc2NvcGVzIjoiYWNjb3VudHNfd2ViX3VzZXIiLCJpYXQiOjE1MTgzNzM4NjUsImV4cCI6MTUxODM3NzQ2NSwic3ViIjoiZWx5fDEwMiIsImp0aSI6MzU0OX0.eJEgvXT3leGqBe3tYNGZb0E4WEvWfrLPjcD7eNjyQYO","refreshToken":"Al75SIx-LFOCP7kaqZBVqMVmSljJw9_bdFQGyuM64c6ShP7YsXbkCD8vPOundAwUDfRZqsIbOHUROmAHPB0VBfjLfw96yqxx"}],"active":102},"user":{"id":102,"uuid":"e49cafdc-6e0c-442d-b608-dacdb864ee34","username":"test","token":"","email":"admin@udf.su","maskedEmail":"","avatar":"","lang":"en","isActive":true,"isOtpEnabled":true,"shouldAcceptRules":false,"passwordChangedAt":1478961317,"hasMojangUsernameCollision":true,"isGuest":false,"registeredAt":1478961317,"elyProfileLink":"http://ely.by/u102","originalResponse":{}}}'
|
||||
)
|
||||
)
|
||||
.then(() => localStorage.setItem('redux-storage', multiAccount))
|
||||
);
|
||||
|
||||
it('should ask for password', () => {
|
||||
@@ -31,6 +31,11 @@ describe('when user\'s token and refreshToken are invalid', () => {
|
||||
|
||||
cy.url().should('include', '/choose-account');
|
||||
|
||||
cy
|
||||
.get('[data-e2e-content]')
|
||||
.contains(account2.email)
|
||||
.should('not.exist');
|
||||
|
||||
cy
|
||||
.get('[data-e2e-content]')
|
||||
.contains(account1.username)
|
||||
@@ -40,14 +45,36 @@ describe('when user\'s token and refreshToken are invalid', () => {
|
||||
cy.contains('account preferences');
|
||||
});
|
||||
|
||||
it('it should redirect to login, when one account and clicking back', () => {
|
||||
cy
|
||||
.url()
|
||||
.should(() => localStorage.setItem('redux-storage', singleAccount));
|
||||
cy.visit('/');
|
||||
|
||||
cy.get('[data-e2e-go-back]').click();
|
||||
|
||||
cy.url().should('include', '/login');
|
||||
|
||||
cy.get('[data-e2e-toolbar]').contains('Join');
|
||||
});
|
||||
|
||||
it('should allow logout', () => {
|
||||
cy.visit('/');
|
||||
|
||||
cy.get('[data-e2e-toolbar]').contains(account2.username).click();
|
||||
cy.get('[data-e2e-toolbar]').contains('Log out').click();
|
||||
cy
|
||||
.get('[data-e2e-toolbar]')
|
||||
.contains(account2.username)
|
||||
.click();
|
||||
cy
|
||||
.get('[data-e2e-toolbar]')
|
||||
.contains('Log out')
|
||||
.click();
|
||||
|
||||
cy.contains(account2.email).should('not.exist');
|
||||
cy.get('[data-e2e-toolbar]').contains(account2.username).should('not.exist');
|
||||
cy
|
||||
.get('[data-e2e-toolbar]')
|
||||
.contains(account2.username)
|
||||
.should('not.exist');
|
||||
});
|
||||
|
||||
it('should allow enter new login from choose account', () => {
|
||||
@@ -98,12 +125,12 @@ describe('when user\'s token and refreshToken are invalid', () => {
|
||||
|
||||
cy
|
||||
.get('[data-e2e-content]')
|
||||
.contains(account2.username)
|
||||
.contains(account1.username)
|
||||
.click();
|
||||
|
||||
cy.url().should('include', '/password');
|
||||
|
||||
cy.get('[name="password"]').type(`${account2.password}{enter}`);
|
||||
cy.get('[name="password"]').type(`${account1.password}{enter}`);
|
||||
|
||||
cy.location('pathname', { timeout: 15000 }).should('eq', '/');
|
||||
cy.contains('account preferences');
|
||||
@@ -133,9 +160,7 @@ describe('when user\'s token and refreshToken are invalid', () => {
|
||||
cy.contains('[type=submit]', 'Log into another account').click();
|
||||
cy.contains('a', 'Create new account').click();
|
||||
|
||||
cy
|
||||
.get('@fetch')
|
||||
.should('be.calledWith', '/api/options');
|
||||
cy.get('@fetch').should('be.calledWith', '/api/options');
|
||||
|
||||
cy.url().should('contain', '/register');
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user