summaryrefslogtreecommitdiff
path: root/spec/frontend/pages/dashboard
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-06-18 11:18:50 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-06-18 11:18:50 +0000
commit8c7f4e9d5f36cff46365a7f8c4b9c21578c1e781 (patch)
treea77e7fe7a93de11213032ed4ab1f33a3db51b738 /spec/frontend/pages/dashboard
parent00b35af3db1abfe813a778f643dad221aad51fca (diff)
downloadgitlab-ce-8c7f4e9d5f36cff46365a7f8c4b9c21578c1e781.tar.gz
Add latest changes from gitlab-org/gitlab@13-1-stable-ee
Diffstat (limited to 'spec/frontend/pages/dashboard')
-rw-r--r--spec/frontend/pages/dashboard/todos/index/todos_spec.js111
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),
+ );
+ });
+ });
+ });
+});