salix/modules/client/back/models/specs/client.spec.js

115 lines
4.1 KiB
JavaScript
Raw Permalink Normal View History

const models = require('vn-loopback/server/server').models;
2021-03-24 11:45:26 +00:00
const LoopBackContext = require('loopback-context');
describe('Client Model', () => {
const activeCtx = {
accessToken: {userId: 9},
http: {
req: {
headers: {origin: 'http://localhost'},
[`__`]: value => {
return value;
}
}
}
};
const ctx = {req: activeCtx};
const chatModel = models.Chat;
const instance = {id: 1101, name: 'Bruce Banner'};
const previousWorkerId = 1106; // DavidCharlesHaller
const currentWorkerId = 1107; // HankPym
2021-03-24 11:45:26 +00:00
beforeEach(() => {
spyOn(LoopBackContext, 'getCurrentContext').and.returnValue({
active: activeCtx
});
2021-03-23 15:19:45 +00:00
});
2021-03-24 11:45:26 +00:00
describe('notifyAssignment()', () => {
it('should call to the Chat send() method for both workers', async() => {
spyOn(chatModel, 'send').and.callThrough();
2021-03-23 15:19:45 +00:00
await models.Client.notifyAssignment(instance, previousWorkerId, currentWorkerId);
2021-03-23 15:19:45 +00:00
2021-03-24 11:45:26 +00:00
expect(chatModel.send).toHaveBeenCalledWith(ctx, '@DavidCharlesHaller', `Client assignment has changed`);
expect(chatModel.send).toHaveBeenCalledWith(ctx, '@HankPym', `Client assignment has changed`);
2021-03-23 15:19:45 +00:00
});
2021-03-24 11:45:26 +00:00
it('should call to the Chat send() method for the previous worker', async() => {
spyOn(chatModel, 'send').and.callThrough();
2021-03-23 15:19:45 +00:00
await models.Client.notifyAssignment(instance, null, currentWorkerId);
2021-03-23 15:19:45 +00:00
2021-03-24 11:45:26 +00:00
expect(chatModel.send).toHaveBeenCalledWith(ctx, '@HankPym', `Client assignment has changed`);
});
2021-03-23 15:19:45 +00:00
2021-03-24 11:45:26 +00:00
it('should call to the Chat send() method for the current worker', async() => {
spyOn(chatModel, 'send').and.callThrough();
2021-03-23 15:19:45 +00:00
await models.Client.notifyAssignment(instance, previousWorkerId, null);
2021-03-23 15:19:45 +00:00
2021-03-24 11:45:26 +00:00
expect(chatModel.send).toHaveBeenCalledWith(ctx, '@DavidCharlesHaller', `Client assignment has changed`);
2021-03-23 15:19:45 +00:00
});
});
describe('changeCredit()', () => {
it('should fail to change the credit as a salesAssistant set to zero by a financialBoss', async() => {
const tx = await models.Client.beginTransaction({});
let error;
try {
const options = {transaction: tx};
2023-06-28 12:10:21 +00:00
const ctx = {options};
// Set credit to zero by a financialBoss
const financialBoss = await models.VnUser.findOne({
where: {name: 'financialBoss'}
}, options);
2023-06-28 12:10:21 +00:00
ctx.options.accessToken = {userId: financialBoss.id};
2023-06-28 12:10:21 +00:00
await models.Client.changeCredit(ctx, instance, {credit: 0});
const salesAssistant = await models.VnUser.findOne({
where: {name: 'salesAssistant'}
}, options);
2023-06-28 12:10:21 +00:00
ctx.options.accessToken = {userId: salesAssistant.id};
2023-06-28 12:10:21 +00:00
await models.Client.changeCredit(ctx, instance, {credit: 300});
await tx.rollback();
} catch (e) {
error = e;
await tx.rollback();
}
expect(error.message).toEqual(`You can't change the credit set to zero from a financialBoss`);
});
it('should fail to change to a high credit amount as a salesAssistant', async() => {
const tx = await models.Client.beginTransaction({});
let error;
try {
const options = {transaction: tx};
2023-06-28 12:10:21 +00:00
const ctx = {options};
const salesAssistant = await models.VnUser.findOne({
where: {name: 'salesAssistant'}
}, options);
2023-06-28 12:10:21 +00:00
ctx.options.accessToken = {userId: salesAssistant.id};
2023-06-28 12:10:21 +00:00
await models.Client.changeCredit(ctx, instance, {credit: 99999});
await tx.rollback();
} catch (e) {
error = e;
await tx.rollback();
}
expect(error.message).toEqual(`You don't have enough privileges to set this credit amount`);
});
});
2021-03-23 15:19:45 +00:00
});