{title}
@@ -134,7 +134,7 @@ export default class SortableBarGraph extends React.Component {
return (
', () => {
let wrapper;
@@ -15,9 +17,14 @@ describe('', () => {
Foo: 100,
Bar: 50,
};
- const createWrapper = (extraHeaderContent) => {
+ const createWrapper = (withPagination = false, extraStats = {}) => {
wrapper = shallow(
-
+
);
return wrapper;
@@ -37,7 +44,7 @@ describe('', () => {
beforeEach(() => {
const wrapper = createWrapper();
- const dropdown = wrapper.find(SortingDropdown);
+ const dropdown = wrapper.renderProp('title')().find(SortingDropdown);
assert = (sortName, sortDir, expectedKeys, expectedValues, done) => {
dropdown.prop('onChange')(sortName, sortDir);
@@ -59,15 +66,56 @@ describe('', () => {
it('value - DESC', (done) => assert('value', 'DESC', [ 'Foo', 'Bar' ], [ 100, 50 ], done));
});
- it('renders extra header functions', () => {
- const wrapper = createWrapper((
-
- Foo
- Bar
-
- ));
+ describe('renders properly paginated stats when pagination is set', () => {
+ let assert;
- expect(wrapper.find('.foo-span')).toHaveLength(1);
- expect(wrapper.find('.bar-span')).toHaveLength(1);
+ 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(() => {
+ const graphCard = wrapper.find(GraphCard);
+ const statsKeys = keys(graphCard.prop('stats'));
+
+ expect(statsKeys).toEqual(expectedStats);
+ 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(
+
+ (
+
+ Foo
+ Bar
+
+ )}
+ />
+
+ ).find(SortableBarGraph);
+ const header = wrapper.renderProp('extraHeaderContent')();
+
+ expect(header.find('.foo-span')).toHaveLength(1);
+ expect(header.find('.bar-span')).toHaveLength(1);
});
});