2021-12-21 13:43:53 +00:00
|
|
|
const models = require('vn-loopback/server/server').models;
|
2022-07-14 11:40:50 +00:00
|
|
|
const LoopBackContext = require('loopback-context');
|
2021-12-21 13:43:53 +00:00
|
|
|
|
2023-09-21 07:14:46 +00:00
|
|
|
describe('Sale refund()', () => {
|
2022-07-14 11:40:50 +00:00
|
|
|
const userId = 5;
|
2023-09-25 08:49:47 +00:00
|
|
|
const ctx = {req: {accessToken: userId}, args: {}};
|
2022-07-14 11:40:50 +00:00
|
|
|
const activeCtx = {
|
2023-06-01 06:32:06 +00:00
|
|
|
accessToken: {userId},
|
2022-07-14 11:40:50 +00:00
|
|
|
};
|
|
|
|
const servicesIds = [3];
|
2023-05-26 10:03:36 +00:00
|
|
|
const withWarehouse = true;
|
2022-07-14 11:40:50 +00:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
spyOn(LoopBackContext, 'getCurrentContext').and.returnValue({
|
|
|
|
active: activeCtx
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should create ticket with the selected lines', async() => {
|
2021-12-21 13:43:53 +00:00
|
|
|
const tx = await models.Sale.beginTransaction({});
|
2022-07-14 11:40:50 +00:00
|
|
|
const salesIds = [7, 8];
|
2022-01-21 10:40:48 +00:00
|
|
|
|
2021-12-21 13:43:53 +00:00
|
|
|
try {
|
|
|
|
const options = {transaction: tx};
|
|
|
|
|
2023-11-30 14:16:41 +00:00
|
|
|
const refundedTickets = await models.Sale.refund(ctx, salesIds, servicesIds, withWarehouse, options);
|
2021-12-21 13:43:53 +00:00
|
|
|
|
2023-11-30 14:16:41 +00:00
|
|
|
expect(refundedTickets).toBeDefined();
|
2021-12-21 13:43:53 +00:00
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
await tx.rollback();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
});
|
2022-01-21 10:40:48 +00:00
|
|
|
|
2023-04-24 06:57:10 +00:00
|
|
|
it('should create one ticket for each unique ticketFk in the sales', async() => {
|
2022-01-21 10:40:48 +00:00
|
|
|
const tx = await models.Sale.beginTransaction({});
|
2022-07-14 11:40:50 +00:00
|
|
|
const salesIds = [6, 7];
|
2022-01-21 10:40:48 +00:00
|
|
|
|
|
|
|
try {
|
|
|
|
const options = {transaction: tx};
|
2023-09-25 08:49:47 +00:00
|
|
|
const ticketsBefore = await models.Ticket.find({}, options);
|
2022-01-21 10:40:48 +00:00
|
|
|
|
2023-11-30 14:16:41 +00:00
|
|
|
const tickets = await models.Sale.refund(ctx, salesIds, servicesIds, withWarehouse, options);
|
2022-07-14 11:40:50 +00:00
|
|
|
|
2024-01-12 15:18:26 +00:00
|
|
|
const refundedTicket = await getTicketRefund(tickets[0].id, options);
|
2023-09-25 08:49:47 +00:00
|
|
|
const ticketsAfter = await models.Ticket.find({}, options);
|
2023-04-24 06:57:10 +00:00
|
|
|
const salesLength = refundedTicket.ticketSales().length;
|
|
|
|
const componentsLength = refundedTicket.ticketSales()[0].components().length;
|
2022-07-14 11:40:50 +00:00
|
|
|
|
2023-04-24 06:57:10 +00:00
|
|
|
expect(refundedTicket).toBeDefined();
|
2023-09-25 08:49:47 +00:00
|
|
|
expect(salesLength).toEqual(1);
|
|
|
|
expect(ticketsBefore.length).toEqual(ticketsAfter.length - 2);
|
2022-07-14 11:40:50 +00:00
|
|
|
expect(componentsLength).toEqual(4);
|
2022-01-21 10:40:48 +00:00
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
await tx.rollback();
|
2022-07-14 11:40:50 +00:00
|
|
|
throw e;
|
2022-01-21 10:40:48 +00:00
|
|
|
}
|
|
|
|
});
|
2024-01-12 15:18:26 +00:00
|
|
|
|
|
|
|
it('should create a ticket without sales', async() => {
|
|
|
|
const servicesIds = [4];
|
|
|
|
const tx = await models.Sale.beginTransaction({});
|
|
|
|
const options = {transaction: tx};
|
|
|
|
try {
|
|
|
|
const tickets = await models.Sale.refund(ctx, null, servicesIds, withWarehouse, options);
|
|
|
|
const refundedTicket = await getTicketRefund(tickets[0].id, options);
|
|
|
|
|
|
|
|
expect(refundedTicket).toBeDefined();
|
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
await tx.rollback();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
});
|
2021-12-21 13:43:53 +00:00
|
|
|
});
|
2024-01-12 15:18:26 +00:00
|
|
|
|
|
|
|
async function getTicketRefund(id, options) {
|
|
|
|
return models.Ticket.findOne({
|
|
|
|
where: {
|
|
|
|
id
|
|
|
|
},
|
|
|
|
include: [
|
|
|
|
{
|
|
|
|
relation: 'ticketSales',
|
|
|
|
scope: {
|
|
|
|
include: {
|
|
|
|
relation: 'components'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
relation: 'ticketServices',
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}, options);
|
|
|
|
}
|