2019-10-14 18:48:46 +00:00
|
|
|
import 'expect-more-jest';
|
|
|
|
import { validateAuthenticateRoutePermission } from './index';
|
|
|
|
import auth from '../api/auth';
|
|
|
|
|
|
|
|
jest.mock('./dashboard/dashboard.routes', () => ({
|
|
|
|
routes: [],
|
|
|
|
}));
|
|
|
|
jest.mock('./auth/auth.routes', () => ({
|
|
|
|
routes: [],
|
|
|
|
}));
|
|
|
|
jest.mock('./login/login.routes', () => ({
|
|
|
|
routes: [],
|
|
|
|
}));
|
|
|
|
jest.mock('../constants', () => {
|
|
|
|
return {
|
|
|
|
GRAVATAR_URL: 'https://www.gravatar.com/avatar',
|
|
|
|
CHANNELS: {
|
|
|
|
FACEBOOK: 'facebook',
|
|
|
|
},
|
2020-02-26 15:45:01 +00:00
|
|
|
ASSIGNEE_TYPE: {
|
|
|
|
ME: 'me',
|
|
|
|
UNASSIGNED: 'unassigned',
|
|
|
|
ALL: 'all',
|
|
|
|
},
|
|
|
|
STATUS_TYPE: {
|
|
|
|
OPEN: 'open',
|
|
|
|
RESOLVED: 'resolved',
|
2019-10-14 18:48:46 +00:00
|
|
|
},
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
window.roleWiseRoutes = {};
|
|
|
|
|
|
|
|
describe(`behavior`, () => {
|
|
|
|
describe(`when route is not protected`, () => {
|
|
|
|
it(`should go to the dashboard when user is logged in`, () => {
|
|
|
|
// Arrange
|
|
|
|
spyOn(auth, 'isLoggedIn').and.returnValue(true);
|
|
|
|
spyOn(auth, 'getCurrentUser').and.returnValue({
|
|
|
|
role: 'user',
|
|
|
|
});
|
|
|
|
const to = {
|
|
|
|
name: 'login',
|
|
|
|
};
|
|
|
|
const from = { name: '' };
|
|
|
|
const next = jest.fn();
|
|
|
|
// Act
|
|
|
|
validateAuthenticateRoutePermission(to, from, next);
|
|
|
|
// Assert
|
|
|
|
expect(next).toHaveBeenCalledWith('/app/dashboard');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe(`when route is protected`, () => {
|
|
|
|
describe(`when user not logged in`, () => {
|
|
|
|
it(`should redirect to login`, () => {
|
|
|
|
// Arrange
|
|
|
|
spyOn(auth, 'isLoggedIn').and.returnValue(false);
|
|
|
|
spyOn(auth, 'getCurrentUser').and.returnValue(null);
|
|
|
|
const to = {
|
|
|
|
name: 'some-protected-route',
|
|
|
|
};
|
|
|
|
const from = { name: '' };
|
|
|
|
const next = jest.fn();
|
|
|
|
// Act
|
|
|
|
validateAuthenticateRoutePermission(to, from, next);
|
|
|
|
// Assert
|
|
|
|
expect(next).toHaveBeenCalledWith('/app/login');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe(`when user is logged in`, () => {
|
|
|
|
describe(`when route is not accessible to current user`, () => {
|
|
|
|
it(`should redirect to dashboard`, () => {
|
|
|
|
// Arrange
|
|
|
|
spyOn(auth, 'isLoggedIn').and.returnValue(true);
|
|
|
|
spyOn(auth, 'getCurrentUser').and.returnValue({
|
|
|
|
role: 'user',
|
|
|
|
});
|
|
|
|
window.roleWiseRoutes.user = ['dashboard'];
|
|
|
|
const to = {
|
|
|
|
name: 'admin',
|
|
|
|
};
|
|
|
|
const from = { name: '' };
|
|
|
|
const next = jest.fn();
|
|
|
|
// Act
|
|
|
|
validateAuthenticateRoutePermission(to, from, next);
|
|
|
|
// Assert
|
|
|
|
expect(next).toHaveBeenCalledWith('/app/dashboard');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe(`when route is accessible to current user`, () => {
|
|
|
|
it(`should go there`, () => {
|
|
|
|
// Arrange
|
|
|
|
spyOn(auth, 'isLoggedIn').and.returnValue(true);
|
|
|
|
spyOn(auth, 'getCurrentUser').and.returnValue({
|
|
|
|
role: 'user',
|
|
|
|
});
|
|
|
|
window.roleWiseRoutes.user = ['dashboard', 'admin'];
|
|
|
|
const to = {
|
|
|
|
name: 'admin',
|
|
|
|
};
|
|
|
|
const from = { name: '' };
|
|
|
|
const next = jest.fn();
|
|
|
|
// Act
|
|
|
|
validateAuthenticateRoutePermission(to, from, next);
|
|
|
|
// Assert
|
|
|
|
expect(next).toHaveBeenCalledWith();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|