From fc1af042432831c4245b3adf4d61ef00c3ae09f0 Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Sun, 16 Sep 2018 12:18:02 +0200 Subject: [PATCH] Created tests for Paginator and SearchBar --- src/short-urls/Paginator.js | 8 ++--- test/short-urls/Paginator.test.js | 32 +++++++++++++++++ test/short-urls/SearchBar.test.js | 59 +++++++++++++++++++++++++++++++ 3 files changed, 95 insertions(+), 4 deletions(-) create mode 100644 test/short-urls/Paginator.test.js create mode 100644 test/short-urls/SearchBar.test.js diff --git a/src/short-urls/Paginator.js b/src/short-urls/Paginator.js index 893e2da8..3890c27b 100644 --- a/src/short-urls/Paginator.js +++ b/src/short-urls/Paginator.js @@ -20,13 +20,13 @@ export default function Paginator({ paginator = {}, serverId }) { } const renderPages = () => - range(1, pagesCount + 1).map((i) => ( - + range(1, pagesCount + 1).map((pageNumber) => ( + - {i} + {pageNumber} )); diff --git a/test/short-urls/Paginator.test.js b/test/short-urls/Paginator.test.js new file mode 100644 index 00000000..f4893c41 --- /dev/null +++ b/test/short-urls/Paginator.test.js @@ -0,0 +1,32 @@ +import React from 'react'; +import { shallow } from 'enzyme'; +import { PaginationItem } from 'reactstrap'; +import Paginator from '../../src/short-urls/Paginator'; + +describe('', () => { + let wrapper; + + afterEach(() => { + if (wrapper) { + wrapper.unmount(); + } + }); + + it('renders nothing if the number of pages is below 2', () => { + wrapper = shallow(); + expect(wrapper.text()).toEqual(''); + }); + + it('renders previous, next and the list of pages', () => { + const paginator = { + currentPage: 1, + pagesCount: 5, + }; + const extraPagesPrevNext = 2; + const expectedItems = paginator.pagesCount + extraPagesPrevNext; + + wrapper = shallow(); + + expect(wrapper.find(PaginationItem)).toHaveLength(expectedItems); + }); +}); diff --git a/test/short-urls/SearchBar.test.js b/test/short-urls/SearchBar.test.js new file mode 100644 index 00000000..75bc122e --- /dev/null +++ b/test/short-urls/SearchBar.test.js @@ -0,0 +1,59 @@ +import React from 'react'; +import { shallow } from 'enzyme'; +import sinon from 'sinon'; +import { SearchBarComponent } from '../../src/short-urls/SearchBar'; +import SearchField from '../../src/utils/SearchField'; +import Tag from '../../src/tags/helpers/Tag'; + +describe('', () => { + let wrapper; + const listShortUrlsMock = sinon.spy(); + + afterEach(() => { + listShortUrlsMock.resetHistory(); + + if (wrapper) { + wrapper.unmount(); + } + }); + + it('renders a SearchField', () => { + wrapper = shallow(); + + expect(wrapper.find(SearchField)).toHaveLength(1); + }); + + it('renders no tags when the list of tags is empty', () => { + wrapper = shallow(); + + expect(wrapper.find(Tag)).toHaveLength(0); + }); + + it('renders the proper amount of tags', () => { + const tags = [ 'foo', 'bar', 'baz' ]; + + wrapper = shallow(); + + expect(wrapper.find(Tag)).toHaveLength(tags.length); + }); + + it('updates short URLs list when search field changes', () => { + wrapper = shallow(); + const searchField = wrapper.find(SearchField); + + expect(listShortUrlsMock.callCount).toEqual(0); + searchField.simulate('change'); + expect(listShortUrlsMock.callCount).toEqual(1); + }); + + it('updates short URLs list when a tag is removed', () => { + wrapper = shallow( + + ); + const tag = wrapper.find(Tag).first(); + + expect(listShortUrlsMock.callCount).toEqual(0); + tag.simulate('close'); + expect(listShortUrlsMock.callCount).toEqual(1); + }); +});