115 lines
3.3 KiB
JavaScript
115 lines
3.3 KiB
JavaScript
/**
|
|
* Button.js
|
|
*
|
|
* Unit test
|
|
*
|
|
* Created by Alexander Yuzhin on 6/20/14
|
|
* Copyright (c) 2014 Ascensio System SIA. All rights reserved.
|
|
*
|
|
*/
|
|
|
|
define([
|
|
'backbone',
|
|
'../../../../../apps/common/main/lib/component/Button.js',
|
|
'../../../../../apps/common/main/lib/component/Menu.js'
|
|
],function() {
|
|
var chai = require('chai'),
|
|
should = chai.should();
|
|
|
|
describe('Common.UI.Button', function(){
|
|
var button,
|
|
domPlaceholder = document.createElement('div');
|
|
|
|
it('Create simple button', function(){
|
|
$('body').append(domPlaceholder);
|
|
|
|
button = new Common.UI.Button({
|
|
id: 'id-btn-simple',
|
|
caption: 'test'
|
|
});
|
|
|
|
button.render($(domPlaceholder));
|
|
|
|
should.exist(button);
|
|
$('#id-btn-simple').should.have.length(1);
|
|
});
|
|
|
|
it('Button caption', function(){
|
|
button.caption.should.equal('test');
|
|
});
|
|
|
|
it('Button update caption', function(){
|
|
button.setCaption('update caption');
|
|
|
|
// object
|
|
button.caption.should.equal('update caption');
|
|
|
|
// dom
|
|
assert.equal(button.cmpEl.find('button:first').andSelf().filter('button').text(), 'update caption', 'dom caption');
|
|
});
|
|
|
|
it('Button toggle', function(){
|
|
button.toggle();
|
|
assert.equal(button.isActive(), true, 'should by active');
|
|
button.toggle();
|
|
assert.equal(button.isActive(), false, 'should NOT by active');
|
|
|
|
button.toggle(false);
|
|
assert.equal(button.isActive(), false, 'should NOT by active');
|
|
button.toggle(true);
|
|
assert.equal(button.isActive(), true, 'should by active');
|
|
|
|
button.toggle(false);
|
|
});
|
|
|
|
it('Button disable', function(){
|
|
assert.equal(button.isDisabled(), false, 'should NOT by disable');
|
|
|
|
button.setDisabled(true);
|
|
assert.equal(button.isDisabled(), true, 'should by disable');
|
|
|
|
button.setDisabled(false);
|
|
assert.equal(button.isDisabled(), false, 'should NOT by disable');
|
|
});
|
|
|
|
it('Remove simple button', function(){
|
|
button.remove();
|
|
$('#id-btn-simple').should.have.length(0);
|
|
|
|
button = null;
|
|
// domPlaceholder.remove();
|
|
});
|
|
|
|
it('Create split button', function(){
|
|
$('body').append(domPlaceholder);
|
|
|
|
button = new Common.UI.Button({
|
|
id : 'id-btn-split',
|
|
caption : 'split',
|
|
split : true,
|
|
menu : new Common.UI.Menu({
|
|
items: [
|
|
{
|
|
caption: 'print',
|
|
value: 'print'
|
|
}
|
|
]
|
|
})
|
|
});
|
|
|
|
button.render($(domPlaceholder));
|
|
|
|
should.exist(button);
|
|
$('#id-btn-split').should.have.length(1);
|
|
$('#id-btn-split button').should.have.length(2);
|
|
});
|
|
|
|
it('Remove split button', function(){
|
|
button.remove();
|
|
$('#id-btn-split').should.have.length(0);
|
|
|
|
button = null;
|
|
// domPlaceholder.remove();
|
|
});
|
|
});
|
|
}); |