0898014ebd
In 4.0.20 all tests were reworked. The 'testrunner' was removed and the PhantomJS Runner QUnit plugin was added making it possible to run the tests from cli. However it is still necessary to run the tests in all supported browsers to test the fixes for all browser quirks and normalization. Also all tests are loaded in one html file. See #27014 git-svn-id: https://develop.svn.wordpress.org/trunk@27679 602fd350-edb4-49c9-b593-d223f7449a82
205 lines
4.6 KiB
JavaScript
205 lines
4.6 KiB
JavaScript
(function() {
|
|
module("tinymce.ui.Control");
|
|
|
|
test("Initial states", function() {
|
|
var ctrl;
|
|
|
|
ctrl = new tinymce.ui.Control({});
|
|
|
|
// Check inital states
|
|
equal(ctrl.disabled(), false);
|
|
equal(ctrl.active(), false);
|
|
equal(ctrl.visible(), true);
|
|
equal(ctrl.text(), "");
|
|
equal(ctrl.width(), 0);
|
|
equal(ctrl.height(), 0);
|
|
equal(ctrl.name(), "");
|
|
equal(ctrl.title(), "");
|
|
equal(ctrl.parent(), undefined);
|
|
deepEqual(ctrl.settings, {});
|
|
});
|
|
|
|
test("Settings", function() {
|
|
var ctrl = new tinymce.ui.Control({
|
|
disabled: true,
|
|
active: true,
|
|
visible: true,
|
|
text: 'Text',
|
|
title: 'Title',
|
|
width: 100,
|
|
height: 200,
|
|
name: 'Name'
|
|
});
|
|
|
|
// Check settings states
|
|
equal(ctrl.disabled(), true);
|
|
equal(ctrl.active(), true);
|
|
equal(ctrl.visible(), true);
|
|
equal(ctrl.text(), "Text");
|
|
equal(ctrl.width(), 100);
|
|
equal(ctrl.height(), 200);
|
|
equal(ctrl.name(), "Name");
|
|
equal(ctrl.title(), "Title");
|
|
equal(ctrl.parent(), undefined);
|
|
deepEqual(ctrl.settings, {
|
|
disabled: true,
|
|
active: true,
|
|
visible: true,
|
|
text: 'Text',
|
|
title: 'Title',
|
|
width: 100,
|
|
height: 200,
|
|
name: 'Name'
|
|
});
|
|
});
|
|
|
|
/*
|
|
test("Properties", function() {
|
|
var ctrl, cont;
|
|
|
|
cont = new tinymce.ui.Container({});
|
|
ctrl = new tinymce.ui.Control({});
|
|
|
|
// Set all states
|
|
ctrl = ctrl.
|
|
disabled(true).
|
|
active(true).
|
|
visible(true).
|
|
text("Text").
|
|
title("Title").
|
|
width(100).
|
|
height(200).
|
|
name("Name").parent(cont);
|
|
|
|
// Check states
|
|
equal(ctrl.disabled(), true);
|
|
equal(ctrl.active(), true);
|
|
equal(ctrl.visible(), true);
|
|
equal(ctrl.text(), "Text");
|
|
equal(ctrl.width(), 100);
|
|
equal(ctrl.height(), 200);
|
|
equal(ctrl.name(), "Name");
|
|
equal(ctrl.title(), "Title");
|
|
equal(ctrl.parent(), cont);
|
|
deepEqual(ctrl.settings, {});
|
|
});
|
|
|
|
test("Chained methods", function() {
|
|
var ctrl = new tinymce.ui.Control({});
|
|
|
|
// Set all states
|
|
ctrl = ctrl.
|
|
refresh().
|
|
bind('click', function() {}).
|
|
unbind().
|
|
renderTo(document.getElementById('viewport')).
|
|
fire("nothing").
|
|
remove();
|
|
|
|
// Check so that the chain worked
|
|
ok(ctrl instanceof tinymce.ui.Control);
|
|
});
|
|
|
|
test("Events", function() {
|
|
var ctrl = new tinymce.ui.Control({
|
|
handlers: {
|
|
handler1: function() {
|
|
count++;
|
|
}
|
|
}
|
|
}), count;
|
|
|
|
ctrl.bind('MyEvent', function(target, args) {
|
|
ok(target === ctrl);
|
|
ok(ctrl === this);
|
|
deepEqual(args, {myKey: 'myVal'});
|
|
});
|
|
|
|
ctrl.fire('MyEvent', {myKey: 'myVal'});
|
|
|
|
function countAndBreak(target, args) {
|
|
count++;
|
|
return false;
|
|
}
|
|
|
|
// Bind two events
|
|
ctrl.bind('MyEvent2', countAndBreak);
|
|
ctrl.bind('MyEvent2', countAndBreak);
|
|
|
|
// Check if only one of them was called
|
|
count = 0;
|
|
ctrl.fire('MyEvent2', {myKey: 'myVal'});
|
|
equal(count, 1);
|
|
|
|
// Fire unbound event
|
|
ctrl.fire('MyEvent3', {myKey: 'myVal'});
|
|
|
|
// Unbind all
|
|
ctrl.unbind();
|
|
count = 0;
|
|
ctrl.fire('MyEvent2', {myKey: 'myVal'});
|
|
equal(count, 0, 'Unbind all');
|
|
|
|
// Unbind by name
|
|
ctrl.bind('MyEvent1', countAndBreak);
|
|
ctrl.bind('MyEvent2', countAndBreak);
|
|
ctrl.unbind('MyEvent2');
|
|
count = 0;
|
|
ctrl.fire('MyEvent1', {myKey: 'myVal'});
|
|
ctrl.fire('MyEvent2', {myKey: 'myVal'});
|
|
equal(count, 1);
|
|
|
|
// Unbind by name callback
|
|
ctrl.bind('MyEvent1', countAndBreak);
|
|
ctrl.bind('MyEvent1', function() {count++;});
|
|
ctrl.unbind('MyEvent1', countAndBreak);
|
|
count = 0;
|
|
ctrl.fire('MyEvent1', {myKey: 'myVal'});
|
|
equal(count, 1);
|
|
|
|
// Bind by named handler
|
|
ctrl.unbind();
|
|
ctrl.bind('MyEvent', 'handler1');
|
|
count = 0;
|
|
ctrl.fire('MyEvent', {myKey: 'myVal'});
|
|
equal(count, 1);
|
|
});
|
|
|
|
test("hasClass,addClass,removeClass", function() {
|
|
var ctrl = new tinymce.ui.Control({classes: 'class1 class2 class3'});
|
|
|
|
equal(ctrl.classes(), 'class1 class2 class3');
|
|
ok(ctrl.hasClass('class1'));
|
|
ok(ctrl.hasClass('class2'));
|
|
ok(ctrl.hasClass('class3'));
|
|
ok(!ctrl.hasClass('class4'));
|
|
|
|
ctrl.addClass('class4');
|
|
equal(ctrl.classes(), 'class1 class2 class3 class4');
|
|
ok(ctrl.hasClass('class1'));
|
|
ok(ctrl.hasClass('class2'));
|
|
ok(ctrl.hasClass('class3'));
|
|
ok(ctrl.hasClass('class4'));
|
|
|
|
ctrl.removeClass('class4');
|
|
equal(ctrl.classes(), 'class1 class2 class3');
|
|
ok(ctrl.hasClass('class1'));
|
|
ok(ctrl.hasClass('class2'));
|
|
ok(ctrl.hasClass('class3'));
|
|
ok(!ctrl.hasClass('class4'));
|
|
|
|
ctrl.removeClass('class3').removeClass('class2');
|
|
equal(ctrl.classes(), 'class1');
|
|
ok(ctrl.hasClass('class1'));
|
|
ok(!ctrl.hasClass('class2'));
|
|
ok(!ctrl.hasClass('class3'));
|
|
|
|
ctrl.removeClass('class3').removeClass('class1');
|
|
equal(ctrl.classes(), '');
|
|
ok(!ctrl.hasClass('class1'));
|
|
ok(!ctrl.hasClass('class2'));
|
|
ok(!ctrl.hasClass('class3'));
|
|
});
|
|
*/
|
|
})();
|