2024-01-22 06:49:21 +00:00
|
|
|
const {models} = require('vn-loopback/server/server');
|
|
|
|
|
2024-01-22 06:58:18 +00:00
|
|
|
describe('saleTracking updateTracking()', () => {
|
2024-01-22 06:49:21 +00:00
|
|
|
const saleFk = 1;
|
|
|
|
const originalQuantity = 10;
|
|
|
|
const code = 'PREPARED';
|
|
|
|
const isChecked = true;
|
|
|
|
const buyFk = 1;
|
|
|
|
const isScanned = false;
|
|
|
|
|
|
|
|
beforeAll(async() => {
|
|
|
|
ctx = {
|
|
|
|
req: {
|
|
|
|
accessToken: {userId: 104},
|
|
|
|
headers: {origin: 'http://localhost'},
|
2024-01-22 06:58:18 +00:00
|
|
|
__: value => value
|
2024-01-22 06:49:21 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2024-01-22 11:36:52 +00:00
|
|
|
it('should throw an error if the state does not exist', async() => {
|
2024-01-22 06:58:18 +00:00
|
|
|
const tx = await models.SaleTracking.beginTransaction({});
|
|
|
|
const options = {transaction: tx};
|
|
|
|
const code = 'FAKESTATE';
|
|
|
|
try {
|
|
|
|
await models.SaleTracking.updateTracking(
|
|
|
|
ctx,
|
|
|
|
saleFk,
|
|
|
|
originalQuantity,
|
|
|
|
code,
|
|
|
|
isChecked,
|
|
|
|
buyFk,
|
|
|
|
isScanned,
|
|
|
|
options
|
|
|
|
);
|
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
const error = e;
|
|
|
|
|
|
|
|
expect(error.message).toEqual('this state does not exist');
|
|
|
|
await tx.rollback();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2024-01-22 06:49:21 +00:00
|
|
|
it('should add a new saleTracking and saleBuy', async() => {
|
|
|
|
const tx = await models.SaleTracking.beginTransaction({});
|
|
|
|
const options = {transaction: tx};
|
|
|
|
|
|
|
|
try {
|
|
|
|
const saleTrackingBefore = await models.SaleTracking.find(null, options);
|
|
|
|
const saleBuyBefore = await models.SaleBuy.find(null, options);
|
|
|
|
await models.SaleTracking.updateTracking(
|
|
|
|
ctx,
|
|
|
|
saleFk,
|
|
|
|
originalQuantity,
|
|
|
|
code,
|
|
|
|
isChecked,
|
|
|
|
buyFk,
|
|
|
|
isScanned,
|
|
|
|
options
|
|
|
|
);
|
|
|
|
|
|
|
|
const saleTrackingAfter = await models.SaleTracking.find(null, options);
|
|
|
|
const saleBuyAfter = await models.SaleBuy.find(null, options);
|
|
|
|
|
|
|
|
expect(saleTrackingAfter.length).toEqual(saleTrackingBefore.length + 1);
|
|
|
|
expect(saleBuyAfter.length).toEqual(saleBuyBefore.length + 1);
|
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
await tx.rollback();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should only update a saleTracking', async() => {
|
|
|
|
const tx = await models.SaleTracking.beginTransaction({});
|
|
|
|
const options = {transaction: tx};
|
|
|
|
const saleFk = 2;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const saleTrackingBefore = await models.SaleTracking.find(null, options);
|
|
|
|
await models.SaleTracking.updateTracking(
|
|
|
|
ctx,
|
|
|
|
saleFk,
|
|
|
|
originalQuantity,
|
|
|
|
code,
|
|
|
|
isChecked,
|
|
|
|
buyFk,
|
|
|
|
isScanned,
|
|
|
|
options
|
|
|
|
);
|
|
|
|
const saleTrackingAfter = await models.SaleTracking.find(null, options);
|
|
|
|
|
|
|
|
expect(saleTrackingAfter.length).toEqual(saleTrackingBefore.length + 1);
|
|
|
|
|
|
|
|
await tx.rollback();
|
|
|
|
} catch (e) {
|
|
|
|
await tx.rollback();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|