2019-01-12 23:47:41 +01:00
|
|
|
import React from 'react';
|
|
|
|
import { shallow } from 'enzyme';
|
2019-03-10 17:55:02 +01:00
|
|
|
import { keys, range, values } from 'ramda';
|
2019-01-12 23:47:41 +01:00
|
|
|
import SortableBarGraph from '../../src/visits/SortableBarGraph';
|
|
|
|
import GraphCard from '../../src/visits/GraphCard';
|
|
|
|
import SortingDropdown from '../../src/utils/SortingDropdown';
|
2019-03-10 17:55:02 +01:00
|
|
|
import PaginationDropdown from '../../src/utils/PaginationDropdown';
|
|
|
|
import { rangeOf } from '../../src/utils/utils';
|
2019-01-12 23:47:41 +01:00
|
|
|
|
|
|
|
describe('<SortableBarGraph />', () => {
|
|
|
|
let wrapper;
|
|
|
|
const sortingItems = {
|
|
|
|
name: 'Name',
|
|
|
|
amount: 'Amount',
|
|
|
|
};
|
|
|
|
const stats = {
|
|
|
|
Foo: 100,
|
|
|
|
Bar: 50,
|
|
|
|
};
|
2019-03-10 17:55:02 +01:00
|
|
|
const createWrapper = (withPagination = false, extraStats = {}) => {
|
2019-01-12 23:47:41 +01:00
|
|
|
wrapper = shallow(
|
2019-03-10 17:55:02 +01:00
|
|
|
<SortableBarGraph
|
|
|
|
title="Foo"
|
|
|
|
stats={{ ...stats, ...extraStats }}
|
|
|
|
sortingItems={sortingItems}
|
|
|
|
withPagination={withPagination}
|
|
|
|
/>
|
2019-01-12 23:47:41 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
|
|
|
afterEach(() => wrapper && wrapper.unmount());
|
|
|
|
|
|
|
|
it('renders stats unchanged when no ordering is set', () => {
|
|
|
|
const wrapper = createWrapper();
|
|
|
|
const graphCard = wrapper.find(GraphCard);
|
|
|
|
|
|
|
|
expect(graphCard.prop('stats')).toEqual(stats);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('renders properly ordered stats when ordering is set', () => {
|
|
|
|
let assert;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const wrapper = createWrapper();
|
2019-03-10 17:55:02 +01:00
|
|
|
const dropdown = wrapper.renderProp('title')().find(SortingDropdown);
|
2019-01-12 23:47:41 +01:00
|
|
|
|
|
|
|
assert = (sortName, sortDir, expectedKeys, expectedValues, done) => {
|
|
|
|
dropdown.prop('onChange')(sortName, sortDir);
|
|
|
|
setImmediate(() => {
|
2019-09-21 18:29:58 +02:00
|
|
|
const stats = wrapper.find(GraphCard).prop('stats');
|
2019-01-12 23:47:41 +01:00
|
|
|
|
2019-09-21 18:29:58 +02:00
|
|
|
expect(keys(stats)).toEqual(expectedKeys);
|
|
|
|
expect(values(stats)).toEqual(expectedValues);
|
2019-01-12 23:47:41 +01:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
it('name - ASC', (done) => assert('name', 'ASC', [ 'Bar', 'Foo' ], [ 50, 100 ], done));
|
|
|
|
it('name - DESC', (done) => assert('name', 'DESC', [ 'Foo', 'Bar' ], [ 100, 50 ], done));
|
|
|
|
it('value - ASC', (done) => assert('value', 'ASC', [ 'Bar', 'Foo' ], [ 50, 100 ], done));
|
|
|
|
it('value - DESC', (done) => assert('value', 'DESC', [ 'Foo', 'Bar' ], [ 100, 50 ], done));
|
|
|
|
});
|
|
|
|
|
2019-03-10 17:55:02 +01:00
|
|
|
describe('renders properly paginated stats when pagination is set', () => {
|
|
|
|
let assert;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const wrapper = createWrapper(true, range(1, 159).reduce((accum, value) => {
|
|
|
|
accum[`key_${value}`] = value;
|
|
|
|
|
|
|
|
return accum;
|
|
|
|
}, {}));
|
|
|
|
const dropdown = wrapper.renderProp('title')().find(PaginationDropdown);
|
|
|
|
|
|
|
|
assert = (itemsPerPage, expectedStats, done) => {
|
|
|
|
dropdown.prop('setValue')(itemsPerPage);
|
|
|
|
setImmediate(() => {
|
2019-09-21 18:29:58 +02:00
|
|
|
const stats = wrapper.find(GraphCard).prop('stats');
|
2019-03-10 17:55:02 +01:00
|
|
|
|
2019-09-21 18:29:58 +02:00
|
|
|
expect(keys(stats)).toEqual(expectedStats);
|
2019-03-10 17:55:02 +01:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
const buildExpected = (size) => [ 'Foo', 'Bar', ...rangeOf(size - 2, (i) => `key_${i}`) ];
|
|
|
|
|
|
|
|
it('50 items per page', (done) => assert(50, buildExpected(50), done));
|
|
|
|
it('100 items per page', (done) => assert(100, buildExpected(100), done));
|
|
|
|
it('200 items per page', (done) => assert(200, buildExpected(160), done));
|
|
|
|
it('500 items per page', (done) => assert(500, buildExpected(160), done));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders extra header content', () => {
|
|
|
|
wrapper = shallow(
|
|
|
|
<span>
|
|
|
|
<SortableBarGraph
|
|
|
|
title="Foo"
|
|
|
|
stats={stats}
|
|
|
|
sortingItems={sortingItems}
|
|
|
|
extraHeaderContent={() => (
|
|
|
|
<span>
|
|
|
|
<span className="foo-span">Foo</span>
|
|
|
|
<span className="bar-span">Bar</span>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
).find(SortableBarGraph);
|
|
|
|
const header = wrapper.renderProp('extraHeaderContent')();
|
2019-01-12 23:47:41 +01:00
|
|
|
|
2019-03-10 17:55:02 +01:00
|
|
|
expect(header.find('.foo-span')).toHaveLength(1);
|
|
|
|
expect(header.find('.bar-span')).toHaveLength(1);
|
2019-01-12 23:47:41 +01:00
|
|
|
});
|
|
|
|
});
|