diff options
Diffstat (limited to 'spec/frontend/pages/dashboard/todos/index/todos_spec.js')
-rw-r--r-- | spec/frontend/pages/dashboard/todos/index/todos_spec.js | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/spec/frontend/pages/dashboard/todos/index/todos_spec.js b/spec/frontend/pages/dashboard/todos/index/todos_spec.js new file mode 100644 index 00000000000..204fe3d0a68 --- /dev/null +++ b/spec/frontend/pages/dashboard/todos/index/todos_spec.js @@ -0,0 +1,111 @@ +import $ from 'jquery'; +import MockAdapter from 'axios-mock-adapter'; +import Todos from '~/pages/dashboard/todos/index/todos'; +import '~/lib/utils/common_utils'; +import '~/gl_dropdown'; +import axios from '~/lib/utils/axios_utils'; +import { addDelimiter } from '~/lib/utils/text_utility'; +import { visitUrl } from '~/lib/utils/url_utility'; + +jest.mock('~/lib/utils/url_utility', () => ({ + visitUrl: jest.fn().mockName('visitUrl'), +})); + +const TEST_COUNT_BIG = 2000; +const TEST_DONE_COUNT_BIG = 7300; + +describe('Todos', () => { + preloadFixtures('todos/todos.html'); + let todoItem; + let mock; + + beforeEach(() => { + loadFixtures('todos/todos.html'); + todoItem = document.querySelector('.todos-list .todo'); + mock = new MockAdapter(axios); + + return new Todos(); + }); + + afterEach(() => { + mock.restore(); + }); + + describe('goToTodoUrl', () => { + it('opens the todo url', done => { + const todoLink = todoItem.dataset.url; + + visitUrl.mockImplementation(url => { + expect(url).toEqual(todoLink); + done(); + }); + + todoItem.click(); + }); + + describe('meta click', () => { + let windowOpenSpy; + let metakeyEvent; + + beforeEach(() => { + metakeyEvent = $.Event('click', { keyCode: 91, ctrlKey: true }); + windowOpenSpy = jest.spyOn(window, 'open').mockImplementation(() => {}); + }); + + it('opens the todo url in another tab', () => { + const todoLink = todoItem.dataset.url; + + $('.todos-list .todo').trigger(metakeyEvent); + + expect(visitUrl).not.toHaveBeenCalled(); + expect(windowOpenSpy).toHaveBeenCalledWith(todoLink, '_blank'); + }); + + it('run native funcionality when avatar is clicked', () => { + $('.todos-list a').on('click', e => e.preventDefault()); + $('.todos-list img').trigger(metakeyEvent); + + expect(visitUrl).not.toHaveBeenCalled(); + expect(windowOpenSpy).not.toHaveBeenCalled(); + }); + }); + + describe('on done todo click', () => { + let onToggleSpy; + + beforeEach(done => { + const el = document.querySelector('.js-done-todo'); + const path = el.dataset.href; + + // Arrange + mock + .onDelete(path) + .replyOnce(200, { count: TEST_COUNT_BIG, done_count: TEST_DONE_COUNT_BIG }); + onToggleSpy = jest.fn(); + $(document).on('todo:toggle', onToggleSpy); + + // Act + el.click(); + + // Wait for axios and HTML to udpate + setImmediate(done); + }); + + it('dispatches todo:toggle', () => { + expect(onToggleSpy).toHaveBeenCalledWith(expect.anything(), TEST_COUNT_BIG); + }); + + it('updates pending text', () => { + expect(document.querySelector('.todos-pending .badge').innerHTML).toEqual( + addDelimiter(TEST_COUNT_BIG), + ); + }); + + it('updates done text', () => { + expect(document.querySelector('.todos-done .badge').innerHTML).toEqual( + addDelimiter(TEST_DONE_COUNT_BIG), + ); + }); + }); + }); +}); |