2017-08-17 22:00:37 +05:30
|
|
|
/* eslint-disable space-before-function-paren, no-var, one-var, one-var-declaration-per-line, new-parens, no-return-assign, new-cap, vars-on-top, max-len */
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
import $ from 'jquery';
|
2018-03-17 18:26:18 +05:30
|
|
|
import MockAdapter from 'axios-mock-adapter';
|
2017-08-17 22:00:37 +05:30
|
|
|
import '~/commons/bootstrap';
|
2018-03-17 18:26:18 +05:30
|
|
|
import axios from '~/lib/utils/axios_utils';
|
|
|
|
import Sidebar from '~/right_sidebar';
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
(function() {
|
|
|
|
var $aside, $icon, $labelsIcon, $page, $toggle, assertSidebarState;
|
|
|
|
|
|
|
|
this.sidebar = null;
|
|
|
|
|
|
|
|
$aside = null;
|
|
|
|
|
|
|
|
$toggle = null;
|
|
|
|
|
|
|
|
$icon = null;
|
|
|
|
|
|
|
|
$page = null;
|
|
|
|
|
|
|
|
$labelsIcon = null;
|
|
|
|
|
|
|
|
assertSidebarState = function(state) {
|
|
|
|
var shouldBeCollapsed, shouldBeExpanded;
|
|
|
|
shouldBeExpanded = state === 'expanded';
|
|
|
|
shouldBeCollapsed = state === 'collapsed';
|
|
|
|
expect($aside.hasClass('right-sidebar-expanded')).toBe(shouldBeExpanded);
|
|
|
|
expect($page.hasClass('right-sidebar-expanded')).toBe(shouldBeExpanded);
|
|
|
|
expect($icon.hasClass('fa-angle-double-right')).toBe(shouldBeExpanded);
|
|
|
|
expect($aside.hasClass('right-sidebar-collapsed')).toBe(shouldBeCollapsed);
|
|
|
|
expect($page.hasClass('right-sidebar-collapsed')).toBe(shouldBeCollapsed);
|
|
|
|
return expect($icon.hasClass('fa-angle-double-left')).toBe(shouldBeCollapsed);
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('RightSidebar', function() {
|
2018-03-17 18:26:18 +05:30
|
|
|
describe('fixture tests', () => {
|
|
|
|
var fixtureName = 'issues/open-issue.html.raw';
|
|
|
|
preloadFixtures(fixtureName);
|
|
|
|
loadJSONFixtures('todos/todos.json');
|
|
|
|
let mock;
|
|
|
|
|
|
|
|
beforeEach(function() {
|
|
|
|
loadFixtures(fixtureName);
|
|
|
|
mock = new MockAdapter(axios);
|
|
|
|
this.sidebar = new Sidebar();
|
|
|
|
$aside = $('.right-sidebar');
|
|
|
|
$page = $('.layout-page');
|
|
|
|
$icon = $aside.find('i');
|
|
|
|
$toggle = $aside.find('.js-sidebar-toggle');
|
|
|
|
return $labelsIcon = $aside.find('.sidebar-collapsed-icon');
|
|
|
|
});
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
afterEach(() => {
|
|
|
|
mock.restore();
|
2017-08-17 22:00:37 +05:30
|
|
|
});
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
it('should expand/collapse the sidebar when arrow is clicked', function() {
|
|
|
|
assertSidebarState('expanded');
|
|
|
|
$toggle.click();
|
|
|
|
assertSidebarState('collapsed');
|
|
|
|
$toggle.click();
|
|
|
|
assertSidebarState('expanded');
|
|
|
|
});
|
|
|
|
it('should float over the page and when sidebar icons clicked', function() {
|
|
|
|
$labelsIcon.click();
|
|
|
|
return assertSidebarState('expanded');
|
|
|
|
});
|
|
|
|
it('should collapse when the icon arrow clicked while it is floating on page', function() {
|
|
|
|
$labelsIcon.click();
|
|
|
|
assertSidebarState('expanded');
|
|
|
|
$toggle.click();
|
|
|
|
return assertSidebarState('collapsed');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should broadcast todo:toggle event when add todo clicked', function(done) {
|
|
|
|
var todos = getJSONFixture('todos/todos.json');
|
|
|
|
mock.onPost(/(.*)\/todos$/).reply(200, todos);
|
|
|
|
|
|
|
|
var todoToggleSpy = spyOnEvent(document, 'todo:toggle');
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
$('.issuable-sidebar-header .js-issuable-todo').click();
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
expect(todoToggleSpy.calls.count()).toEqual(1);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
it('should not hide collapsed icons', () => {
|
|
|
|
[].forEach.call(document.querySelectorAll('.sidebar-collapsed-icon'), (el) => {
|
|
|
|
expect(el.querySelector('.fa, svg').classList.contains('hidden')).toBeFalsy();
|
|
|
|
});
|
|
|
|
});
|
2017-08-17 22:00:37 +05:30
|
|
|
});
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
describe('sidebarToggleClicked', () => {
|
|
|
|
const event = jasmine.createSpyObj('event', ['preventDefault']);
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
spyOn($.fn, 'hasClass').and.returnValue(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
gl.lazyLoader = undefined;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('calls loadCheck if lazyLoader is set', () => {
|
|
|
|
gl.lazyLoader = jasmine.createSpyObj('lazyLoader', ['loadCheck']);
|
|
|
|
|
|
|
|
Sidebar.prototype.sidebarToggleClicked(event);
|
|
|
|
|
|
|
|
expect(gl.lazyLoader.loadCheck).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('does not throw if lazyLoader is not defined', () => {
|
|
|
|
gl.lazyLoader = undefined;
|
|
|
|
|
|
|
|
const toggle = Sidebar.prototype.sidebarToggleClicked.bind(null, event);
|
|
|
|
|
|
|
|
expect(toggle).not.toThrow();
|
2017-08-17 22:00:37 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}).call(window);
|