a1563917ba
* Adds filter for agents, labels and inboxes * Added Inboxes Reports Feature * Fixed populating of filter dropdown issue * If applied, fixes code climate style-lint warnings * Fixes codeclimate warnings * if applied, Refactors sidebar file to fix codclimate warnings * if applied, fixes the download reports button for filtered report-data * If applied, replaces native img tag with thumbnail component * If applied, replaces hardcoded color string with variable * If applied, adds a11y labels to multiselect dropdowns * If applied, Renames reports methods to generic names * If applied, Adds test cases for Labels and Inboxes * If applied, write a test spec for fileDownload helper * if applied, Moves fileDownload method to a utils folder * If applied, Fixes the report file name type * Test Spec for Reports Store module * Fix specs - add restoreAllMocks Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com> Co-authored-by: Pranav Raj S <pranav@chatwoot.com>
86 lines
2.5 KiB
JavaScript
86 lines
2.5 KiB
JavaScript
import reportsAPI from '../reports';
|
|
import ApiClient from '../ApiClient';
|
|
import describeWithAPIMock from './apiSpecHelper';
|
|
|
|
describe('#Reports API', () => {
|
|
it('creates correct instance', () => {
|
|
expect(reportsAPI).toBeInstanceOf(ApiClient);
|
|
expect(reportsAPI.apiVersion).toBe('/api/v2');
|
|
expect(reportsAPI).toHaveProperty('get');
|
|
expect(reportsAPI).toHaveProperty('show');
|
|
expect(reportsAPI).toHaveProperty('create');
|
|
expect(reportsAPI).toHaveProperty('update');
|
|
expect(reportsAPI).toHaveProperty('delete');
|
|
expect(reportsAPI).toHaveProperty('getReports');
|
|
expect(reportsAPI).toHaveProperty('getSummary');
|
|
expect(reportsAPI).toHaveProperty('getAgentReports');
|
|
expect(reportsAPI).toHaveProperty('getLabelReports');
|
|
expect(reportsAPI).toHaveProperty('getInboxReports');
|
|
});
|
|
describeWithAPIMock('API calls', context => {
|
|
it('#getAccountReports', () => {
|
|
reportsAPI.getReports('conversations_count', 1621103400, 1621621800);
|
|
expect(context.axiosMock.get).toHaveBeenCalledWith('/api/v2/reports', {
|
|
params: {
|
|
metric: 'conversations_count',
|
|
since: 1621103400,
|
|
until: 1621621800,
|
|
type: 'account',
|
|
},
|
|
});
|
|
});
|
|
|
|
it('#getAccountSummary', () => {
|
|
reportsAPI.getSummary(1621103400, 1621621800);
|
|
expect(context.axiosMock.get).toHaveBeenCalledWith(
|
|
'/api/v2/reports/summary',
|
|
{
|
|
params: {
|
|
since: 1621103400,
|
|
until: 1621621800,
|
|
type: 'account',
|
|
},
|
|
}
|
|
);
|
|
});
|
|
|
|
it('#getAgentReports', () => {
|
|
reportsAPI.getAgentReports(1621103400, 1621621800);
|
|
expect(context.axiosMock.get).toHaveBeenCalledWith(
|
|
'/api/v2/reports/agents',
|
|
{
|
|
params: {
|
|
since: 1621103400,
|
|
until: 1621621800,
|
|
},
|
|
}
|
|
);
|
|
});
|
|
|
|
it('#getLabelReports', () => {
|
|
reportsAPI.getLabelReports(1621103400, 1621621800);
|
|
expect(context.axiosMock.get).toHaveBeenCalledWith(
|
|
'/api/v2/reports/labels',
|
|
{
|
|
params: {
|
|
since: 1621103400,
|
|
until: 1621621800,
|
|
},
|
|
}
|
|
);
|
|
});
|
|
|
|
it('#getInboxReports', () => {
|
|
reportsAPI.getInboxReports(1621103400, 1621621800);
|
|
expect(context.axiosMock.get).toHaveBeenCalledWith(
|
|
'/api/v2/reports/inboxes',
|
|
{
|
|
params: {
|
|
since: 1621103400,
|
|
until: 1621621800,
|
|
},
|
|
}
|
|
);
|
|
});
|
|
});
|
|
});
|