Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
107 lines
2.7 KiB
JavaScript
107 lines
2.7 KiB
JavaScript
import { validateAuthenticateRoutePermission } from './index';
|
|
import store from '../store'; // This import will be mocked
|
|
import { vi } from 'vitest';
|
|
|
|
// Mock the store module
|
|
vi.mock('../store', () => ({
|
|
default: {
|
|
getters: {
|
|
isLoggedIn: false,
|
|
getCurrentUser: {
|
|
account_id: null,
|
|
id: null,
|
|
accounts: [],
|
|
},
|
|
},
|
|
},
|
|
}));
|
|
|
|
describe('#validateAuthenticateRoutePermission', () => {
|
|
let next;
|
|
|
|
beforeEach(() => {
|
|
next = vi.fn(); // Mock the next function
|
|
});
|
|
|
|
describe('when user is not logged in', () => {
|
|
it('should redirect to login', () => {
|
|
const to = { name: 'some-protected-route', params: { accountId: 1 } };
|
|
|
|
// Mock the store to simulate user not logged in
|
|
store.getters.isLoggedIn = false;
|
|
|
|
// Mock window.location.assign
|
|
const mockAssign = vi.fn();
|
|
delete window.location;
|
|
window.location = { assign: mockAssign };
|
|
|
|
validateAuthenticateRoutePermission(to, next);
|
|
|
|
expect(mockAssign).toHaveBeenCalledWith('/app/login');
|
|
});
|
|
});
|
|
|
|
describe('when user is logged in', () => {
|
|
beforeEach(() => {
|
|
// Mock the store's getter for a logged-in user
|
|
store.getters.isLoggedIn = true;
|
|
store.getters.getCurrentUser = {
|
|
account_id: 1,
|
|
id: 1,
|
|
accounts: [
|
|
{
|
|
id: 1,
|
|
role: 'agent',
|
|
permissions: ['agent'],
|
|
status: 'active',
|
|
},
|
|
],
|
|
};
|
|
});
|
|
|
|
describe('when route is not accessible to current user', () => {
|
|
it('should redirect to dashboard', () => {
|
|
const to = {
|
|
name: 'general_settings_index',
|
|
params: { accountId: 1 },
|
|
meta: { permissions: ['administrator'] },
|
|
};
|
|
|
|
validateAuthenticateRoutePermission(to, next);
|
|
|
|
expect(next).toHaveBeenCalledWith('/app/accounts/1/dashboard');
|
|
});
|
|
});
|
|
|
|
describe('when route is accessible to current user', () => {
|
|
beforeEach(() => {
|
|
// Adjust store getters to reflect the user has admin permissions
|
|
store.getters.getCurrentUser = {
|
|
account_id: 1,
|
|
id: 1,
|
|
accounts: [
|
|
{
|
|
id: 1,
|
|
role: 'administrator',
|
|
permissions: ['administrator'],
|
|
status: 'active',
|
|
},
|
|
],
|
|
};
|
|
});
|
|
|
|
it('should go to the intended route', () => {
|
|
const to = {
|
|
name: 'general_settings_index',
|
|
params: { accountId: 1 },
|
|
meta: { permissions: ['administrator'] },
|
|
};
|
|
|
|
validateAuthenticateRoutePermission(to, next);
|
|
|
|
expect(next).toHaveBeenCalledWith();
|
|
});
|
|
});
|
|
});
|
|
});
|