salix/modules/ticket/back/methods/sale/specs/canEdit.spec.js

180 lines
4.9 KiB
JavaScript
Raw Normal View History

const models = require('vn-loopback/server/server').models;
describe('sale canEdit()', () => {
it('should return true if the role is production regardless of the saleTrackings', async() => {
const tx = await models.Sale.beginTransaction({});
try {
const options = {transaction: tx};
const productionUserID = 49;
const ctx = {req: {accessToken: {userId: productionUserID}}};
const sales = [25];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(true);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return true if the role is not production and none of the sales has saleTracking', async() => {
const tx = await models.Sale.beginTransaction({});
try {
const options = {transaction: tx};
const salesPersonUserID = 18;
const ctx = {req: {accessToken: {userId: salesPersonUserID}}};
2022-10-04 11:22:11 +00:00
const sales = [10];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(true);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return false if any of the sales has a saleTracking record', async() => {
const tx = await models.Sale.beginTransaction({});
try {
const options = {transaction: tx};
const buyerId = 35;
const ctx = {req: {accessToken: {userId: buyerId}}};
const sales = [31];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(false);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return false if any of the sales is cloned', async() => {
const tx = await models.Sale.beginTransaction({});
try {
const options = {transaction: tx};
const buyerId = 35;
const ctx = {req: {accessToken: {userId: buyerId}}};
const sales = [27];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(false);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return true if any of the sales is cloned and has the correct role', async() => {
const tx = await models.Sale.beginTransaction({});
2022-10-18 09:50:16 +00:00
const roleEnabled = await models.ACL.findOne({
where: {
model: 'Sale',
property: 'editCloned'
}
});
2022-10-18 09:50:16 +00:00
if (!roleEnabled || !roleEnabled.principalId) return;
2022-10-06 13:04:27 +00:00
try {
const options = {transaction: tx};
const roleId = await models.Role.findOne({
where: {
2022-10-18 09:50:16 +00:00
name: roleEnabled.principalId
}
});
const ctx = {req: {accessToken: {userId: roleId}}};
const sales = [27];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(true);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return false if any of the sales is of ticket weekly', async() => {
const tx = await models.Sale.beginTransaction({});
try {
const options = {transaction: tx};
const employeeId = 1;
const ctx = {req: {accessToken: {userId: employeeId}}};
const sales = [33];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(false);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
it('should return true if any of the sales is of ticketWeekly and has the correct role', async() => {
const tx = await models.Sale.beginTransaction({});
2022-10-18 09:50:16 +00:00
const roleEnabled = await models.ACL.findOne({
where: {
model: 'Sale',
property: 'editWeekly'
}
});
2022-10-18 09:50:16 +00:00
if (!roleEnabled || !roleEnabled.principalId) return;
try {
const options = {transaction: tx};
const roleId = await models.Role.findOne({
where: {
2022-10-18 09:50:16 +00:00
name: roleEnabled.principalId
}
});
const ctx = {req: {accessToken: {userId: roleId}}};
const sales = [33];
const result = await models.Sale.canEdit(ctx, sales, options);
expect(result).toEqual(true);
await tx.rollback();
} catch (e) {
await tx.rollback();
throw e;
}
});
});