2017-08-17 22:00:37 +05:30
|
|
|
/* global Project */
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
import 'select2/select2';
|
|
|
|
import '~/gl_dropdown';
|
|
|
|
import '~/api';
|
|
|
|
import '~/project_select';
|
|
|
|
import '~/project';
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe('Project Title', () => {
|
|
|
|
preloadFixtures('issues/open-issue.html.raw');
|
|
|
|
loadJSONFixtures('projects.json');
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
beforeEach(() => {
|
|
|
|
loadFixtures('issues/open-issue.html.raw');
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
window.gon = {};
|
|
|
|
window.gon.api_version = 'v3';
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
// eslint-disable-next-line no-new
|
|
|
|
new Project();
|
|
|
|
});
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe('project list', () => {
|
|
|
|
let reqUrl;
|
|
|
|
let reqData;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const fakeResponseData = getJSONFixture('projects.json');
|
|
|
|
spyOn(jQuery, 'ajax').and.callFake((req) => {
|
|
|
|
const def = $.Deferred();
|
|
|
|
reqUrl = req.url;
|
|
|
|
reqData = req.data;
|
|
|
|
def.resolve(fakeResponseData);
|
|
|
|
return def.promise();
|
2016-09-13 17:45:13 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it('toggles dropdown', () => {
|
|
|
|
const $menu = $('.js-dropdown-menu-projects');
|
|
|
|
$('.js-projects-dropdown-toggle').click();
|
|
|
|
expect($menu).toHaveClass('open');
|
|
|
|
expect(reqUrl).toBe('/api/v3/projects.json?simple=true');
|
|
|
|
expect(reqData).toEqual({
|
|
|
|
search: '',
|
|
|
|
order_by: 'last_activity_at',
|
|
|
|
per_page: 20,
|
|
|
|
membership: true,
|
|
|
|
});
|
|
|
|
$menu.find('.dropdown-menu-close-icon').click();
|
|
|
|
expect($menu).not.toHaveClass('open');
|
2017-08-17 22:00:37 +05:30
|
|
|
});
|
|
|
|
});
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
window.gon = {};
|
|
|
|
});
|
|
|
|
});
|