OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/karma/tests/work_packages/directives/work-package-details-toolba...

182 lines
5.8 KiB

//-- copyright
// OpenProject is a project management system.
// Copyright (C) 2012-2014 the OpenProject Foundation (OPF)
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License version 3.
//
// OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
// Copyright (C) 2006-2013 Jean-Philippe Lang
// Copyright (C) 2010-2013 the ChiliProject Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
// See doc/COPYRIGHT.rdoc for more details.
//++
/*jshint expr: true*/
describe('workPackageDetailsToolbar', function() {
var I18n, HookService, compile, scope, element, stateParams;
var html = "<work-package-details-toolbar work-package='workPackage'></work-package-details-toolbar>";
stateParams = {};
beforeEach(module('ui.router',
'openproject.api',
'openproject.models',
'openproject.layout',
'openproject.services',
'openproject.uiComponents',
'openproject.workPackages.directives',
'openproject.workPackages.models',
'openproject.workPackages.services'));
beforeEach(module('templates', function($provide) {
configurationService = new Object();
$provide.constant('$stateParams', stateParams);
$provide.constant('ConfigurationService', configurationService);
}));
beforeEach(inject(function($rootScope, $compile, _I18n_, _HookService_) {
I18n = _I18n_;
HookService = _HookService_;
scope = $rootScope.$new();
compile = function() {
element = $compile(html)(scope);
scope.$digest();
};
var stub = sinon.stub(I18n, 't');
stub.withArgs('js.button_log_time').returns('trans_log_time');
stub.withArgs('js.button_duplicate').returns('trans_duplicate');
stub.withArgs('js.button_move').returns('trans_move');
stub.withArgs('js.button_delete').returns('trans_delete');
stub.withArgs('js.button_plugin_action_1').returns('trans_plugin_action_1');
stub.withArgs('js.button_plugin_action_2').returns('trans_plugin_action_2');
}));
afterEach(function() {
I18n.t.restore();
});
var pluginActions = {
plugin_action_1: { plugin_action_1: ['plugin_action_1_css_1', 'plugin_action_1_css_2'] },
plugin_action_2: { plugin_action_2: ['plugin_action_2_css_1'] }
};
beforeEach(function() {
var workPackage = {
links: {
log_time: { href: 'log_timeMeLink' },
duplicate: { href: 'duplicateMeLink' },
move: { href: 'moveMeLink' },
delete: { href: 'deleteMeLink' },
plugin_action_1: { href: 'plugin_actionMeLink' },
plugin_action_2: { href: 'plugin_actionMeLink' }
}
};
scope.workPackage = workPackage;
var callStub = sinon.stub(HookService, "call");
var actions = [pluginActions.plugin_action_1, pluginActions.plugin_action_2];
callStub.withArgs('workPackageDetailsMoreMenu').returns(actions);
compile();
});
var getLink = function(listRoot, action) {
return angular.element(listRoot.find('li a.' + action));
};
var shouldBehaveLikeListOfWorkPackageActionLinks = function(listRootSelector, actions) {
var listRoot;
beforeEach(function() {
listRoot = element.find(listRootSelector);
});
describe('links', function() {
it('contains links for all core actions', function() {
angular.forEach(actions, function(css, action) {
var link = getLink(listRoot, css);
expect(link.length).to.be.ok;
});
});
it('contains links with correct description', function() {
angular.forEach(actions, function(css, action) {
var link = getLink(listRoot, css);
expect(link.text()).to.eq(I18n.t('js.button_' + action));
});
});
});
};
var shouldBehaveLikeCorrectWorkPackageActionLinkCss = function(listRootSelector, actions) {
var listRoot;
beforeEach(function() {
listRoot = element.find(listRootSelector);
});
describe('link css', function() {
it('contains links with correct description', function() {
angular.forEach(actions, function(css, action) {
var link = getLink(listRoot, css);
var pluginCss = pluginActions[action][action];
angular.forEach(pluginCss, function(value) {
expect(link.hasClass(value)).to.be.true;
});
expect(link.text()).to.eq(I18n.t('js.button_' + action));
});
});
});
};
describe('Core actions', function() {
var listRootSelector = 'ul.dropdown-menu';
var actions = {
log_time: 'icon-log_time',
duplicate: 'icon-duplicate',
move: 'icon-move',
delete: 'icon-delete'
};
shouldBehaveLikeListOfWorkPackageActionLinks(listRootSelector, actions);
});
describe('Plugin actions', function() {
var listRootSelector = 'ul.dropdown-menu';
var actions = {
plugin_action_1: 'plugin_action_1_css_1',
plugin_action_2: 'plugin_action_2_css_1'
};
shouldBehaveLikeListOfWorkPackageActionLinks(listRootSelector, actions);
shouldBehaveLikeCorrectWorkPackageActionLinkCss(listRootSelector, actions);
});
});