Files
bigcapital/packages/server/tests/routes/receivable_aging.test.js
2023-02-03 11:57:50 +02:00

235 lines
7.2 KiB
JavaScript

import {
request,
expect,
} from '~/testInit';
import Item from 'models/Item';
import {
tenantWebsite,
tenantFactory,
loginRes
} from '~/dbInit';
describe('routes: `/financial_statements/receivable_aging_summary`', () => {
it('Should retrieve customers list.', async () => {
const customer1 = await tenantFactory.create('customer', { display_name: 'Ahmed' });
const customer2 = await tenantFactory.create('customer', { display_name: 'Mohamed' });
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.send();
expect(res.status).equals(200);
expect(res.body.aging.customers).is.an('array');
expect(res.body.aging.customers.length).equals(2);
expect(res.body.aging.customers[0].customer_name).equals('Ahmed');
expect(res.body.aging.customers[1].customer_name).equals('Mohamed');
});
it('Should respon se the customers ids not found.', async () => {
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.query({
customer_ids: [3213, 3322],
})
.send();
expect(res.status).equals(400);
expect(res.body.errors).include.something.deep.equals({
type: 'CUSTOMERS.IDS.NOT.FOUND', code: 300, ids: [3213, 3322]
})
});
it('Should retrieve aging report columns.', async () => {
const customer1 = await tenantFactory.create('customer', { display_name: 'Ahmed' });
const customer2 = await tenantFactory.create('customer', { display_name: 'Mohamed' });
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.query({
as_date: '2020-06-01',
aging_days_before: 30,
aging_periods: 6,
})
.send();
expect(res.body.columns).length(6);
expect(res.body.columns[0].before_days).equals(0);
expect(res.body.columns[0].to_days).equals(30);
expect(res.body.columns[1].before_days).equals(31);
expect(res.body.columns[1].to_days).equals(60);
expect(res.body.columns[2].before_days).equals(61);
expect(res.body.columns[2].to_days).equals(90);
expect(res.body.columns[3].before_days).equals(91);
expect(res.body.columns[3].to_days).equals(120);
expect(res.body.columns[4].before_days).equals(121);
expect(res.body.columns[4].to_days).equals(150);
expect(res.body.columns[5].before_days).equals(151);
expect(res.body.columns[5].to_days).equals(null);
});
it('Should retrieve receivable total of the customers.', async () => {
const customer1 = await tenantFactory.create('customer', { display_name: 'Ahmed' });
const customer2 = await tenantFactory.create('customer', { display_name: 'Mohamed' });
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 10000,
credit: 0,
account_id: 10,
date: '2020-01-01',
});
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 1000,
credit: 0,
account_id: 10,
date: '2020-03-15',
});
// Receive
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 0,
credit: 8000,
account_id: 10,
date: '2020-06-01',
});
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.query({
as_date: '2020-06-01',
aging_days_before: 30,
aging_periods: 6,
})
.send();
expect(res.body.aging.total[0].total).equals(0);
expect(res.body.aging.total[1].total).equals(0);
expect(res.body.aging.total[2].total).equals(1000);
expect(res.body.aging.total[3].total).equals(0);
expect(res.body.aging.total[4].total).equals(0);
expect(res.body.aging.total[5].total).equals(2000);
});
it('Should retrieve customer aging.', async () => {
const customer1 = await tenantFactory.create('customer', { display_name: 'Ahmed' });
const customer2 = await tenantFactory.create('customer', { display_name: 'Mohamed' });
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 10000,
credit: 0,
account_id: 10,
date: '2020-01-14',
});
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 1000,
credit: 0,
account_id: 10,
date: '2020-03-15',
});
// Receive
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 0,
credit: 8000,
account_id: 10,
date: '2020-06-01',
});
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.query({
as_date: '2020-06-01',
aging_days_before: 30,
aging_periods: 6,
})
.send();
expect(res.body.aging.customers[0].aging[0].total).equals(0);
expect(res.body.aging.customers[0].aging[1].total).equals(0);
expect(res.body.aging.customers[0].aging[2].total).equals(1000);
expect(res.body.aging.customers[0].aging[3].total).equals(0);
expect(res.body.aging.customers[0].aging[4].total).equals(2000);
expect(res.body.aging.customers[0].aging[5].total).equals(0);
});
it('Should retrieve the queried customers ids only.', async () => {
const customer1 = await tenantFactory.create('customer', { display_name: 'Ahmed' });
const customer2 = await tenantFactory.create('customer', { display_name: 'Mohamed' });
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 10000,
credit: 0,
account_id: 10,
date: '2020-01-14',
});
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 1000,
credit: 0,
account_id: 10,
date: '2020-03-15',
});
// Receive
await tenantFactory.create('account_transaction', {
contact_id: customer1.id,
contact_type: 'customer',
debit: 0,
credit: 8000,
account_id: 10,
date: '2020-06-01',
});
const res = await request()
.get('/api/financial_statements/receivable_aging_summary')
.set('x-access-token', loginRes.body.token)
.set('organization-id', tenantWebsite.organizationId)
.query({
as_date: '2020-06-01',
aging_days_before: 30,
aging_periods: 6,
customer_ids: [customer1.id],
})
.send();
expect(res.body.aging.customers.length).equals(1);
})
});