2012-12-05 12:01:22 +04:00

484 lines
19 KiB
JavaScript

(function($) {
module("common", {
setup: function() {
fx = $('#async-fixture');
$.support.transition = false;
}
});
test("should be defined on jquery object", function () {
var div = $("<div id='modal-test'></div>")
ok(div.editable, 'editable method is defined')
});
test("should return element", function () {
var div = $('<div id="a"></div>');
ok(div.editable() == div, 'element returned');
});
test("should expose defaults var for settings", function () {
ok($.fn.editable.defaults, 'default object exposed');
});
test("should store editable instance in data object", function () {
var editable = $('<a href="#" id="a">link</a>').editable();
ok(!!editable.data('editable'), 'editable instance exists');
});
test("should add 'editable' class when applied", function () {
var editable = $('<a href="#" id="a">link</a>').appendTo('#qunit-fixture').editable();
ok($('.editable').length, 'editable class exists');
});
test("container should be close when element is removed from dom", function () {
var e = $('<a href="#" data-pk="1" data-url="post.php" data-name="text1">abc</a>').appendTo('#qunit-fixture').editable(),
e1 = $('<a href="#" data-pk="1" data-url="post.php" data-name="text2">abc</a>').appendTo('#qunit-fixture').editable().wrap('<div>');
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover shown');
e.remove();
ok(!p.is(':visible'), 'popover closed');
});
// test("should store name and value and lastSavedValue", function () {
test("should store name and value", function () {
var v = 'abr><"&<b>e</b>',
visible_v = 'abr><"&e',
esc_v = $('<div>').text(v).html(),
e = $('<a href="#123" data-name="abc" data-value="123">qwe</a>').appendTo('#qunit-fixture').editable(),
e2 = $('<a href="#" id="a2">'+v+'</a>').appendTo('#qunit-fixture').editable(),
e3 = $('<a href="#" id="a3">'+esc_v+'</a>').appendTo('#qunit-fixture').editable();
equal(e.data('editable').options.name, 'abc', 'name exists');
equal(e.data('editable').value, '123', 'value exists');
// equal(e.data('editable').lastSavedValue, '123', 'lastSavedValue exists');
equal(e2.data('editable').value, visible_v, 'value taken from elem content correctly');
// equal(e2.data('editable').lastSavedValue, visible_v, 'lastSavedValue taken from text correctly');
equal(e3.data('editable').value, v, 'value taken from elem content correctly (escaped)');
// equal(e3.data('editable').lastSavedValue, v, 'lastSavedValue taken from text correctly (escaped)');
});
test("should take container's title from json options", function () {
//do not test inline
if($.fn.editableContainer.Constructor.prototype.containerName === 'editableform') {
expect(0);
return;
}
var title = 'abc',
//add to fx because qunit-fixture has wrong positioning
e = $('<a href="#" id="a"></a>').appendTo(fx).editable({
placement: 'bottom',
title: title
});
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover shown');
//todo: for jqueryui phantomjs calcs wrong position. Need investigation
if(!$.browser.webkit && $.fn.editableContainer.Constructor.prototype.containerName !== 'tooltip') {
ok(p.offset().top > e.offset().top, 'placement ok');
}
//check title
ok(p.find(':contains("'+title+'")').length, 'title ok');
e.remove();
});
test("onblur: cancel", function () {
var oldValue = 'abc',
newValue = 'cde',
e = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="a">'+oldValue+'</a>').appendTo('#qunit-fixture').editable({
onblur: 'cancel',
url: function() {}
}),
e2 = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="b">abcd</a>').appendTo('#qunit-fixture').editable();
//click inside
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
p.click();
p.find('input').click();
ok(p.is(':visible'), 'popover1 still visible');
//click outside
p.find('input').val(newValue);
$('#qunit-fixture').click();
ok(!p.is(':visible'), 'popover1 closed');
equal(e.data('editable').value, oldValue, 'old value exists');
//click on another editable
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
e2.click();
var p2 = tip(e2);
ok(!p.is(':visible'), 'popover1 closed');
ok(p2.is(':visible'), 'popover2 visible');
equal(e.data('editable').value, oldValue, 'old value exists');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = true (default)
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
e2.editable('show');
p2 = tip(e2);
ok(!p.is(':visible'), 'popover1 closed');
ok(p2.is(':visible'), 'popover2 visible');
equal(e.data('editable').value, oldValue, 'old value exists');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = false
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
e2.editable('show', false);
p2 = tip(e2);
ok(p.is(':visible'), 'popover1 visible');
ok(p2.is(':visible'), 'popover2 visible');
e.editable('hide');
e2.editable('hide');
ok(!p.is(':visible'), 'popover1 closed');
ok(!p2.is(':visible'), 'popover2 closed');
});
test("onblur: submit", function () {
var oldValue = 'abc',
newValue = 'cde',
e = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="a">'+oldValue+'</a>').appendTo('#qunit-fixture').editable({
onblur: 'submit',
url: function() {}
}),
e2 = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="b">abcd</a>').appendTo('#qunit-fixture').editable();
//click inside
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
p.click();
p.find('input').click();
ok(p.is(':visible'), 'popover1 still visible');
//click outside
p.find('input').val(newValue);
$('#qunit-fixture').click();
ok(!p.is(':visible'), 'popover1 closed');
equal(e.data('editable').value, newValue, 'new value saved');
//click on another editable
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(oldValue);
e2.click();
var p2 = tip(e2);
ok(!p.is(':visible'), 'popover1 closed');
ok(p2.is(':visible'), 'popover2 visible');
equal(e.data('editable').value, oldValue, 'old value re-saved');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = true (default)
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
e2.editable('show');
p2 = tip(e2);
ok(!p.is(':visible'), 'popover1 closed');
ok(p2.is(':visible'), 'popover2 visible');
equal(e.data('editable').value, newValue, 'new value saved');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = false
e.click();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(oldValue);
e2.editable('show', false);
p2 = tip(e2);
ok(p.is(':visible'), 'popover1 visible');
ok(p2.is(':visible'), 'popover2 visible');
e.editable('hide');
e2.editable('hide');
ok(!p.is(':visible'), 'popover1 closed');
ok(!p2.is(':visible'), 'popover2 closed');
});
test("onblur: ignore", function () {
var oldValue = 'abc',
newValue = 'cde',
e = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="a">'+oldValue+'</a>').appendTo('#qunit-fixture').editable({
onblur: 'ignore',
url: function() {}
}),
e2 = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="b">abcd</a>').appendTo('#qunit-fixture').editable();
//click inside
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
p.find('input').val(newValue);
p.click();
p.find('input').click();
ok(p.is(':visible'), 'popover1 still visible');
//click outside
p.find('input').val(newValue);
$('#qunit-fixture').click();
ok(p.is(':visible'), 'popover1 still visible');
//click on another editable
e2.click();
var p2 = tip(e2);
ok(p.is(':visible'), 'popover1 still visible');
ok(p2.is(':visible'), 'popover2 visible');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = true (default)
e2.editable('show');
p2 = tip(e2);
ok(p.is(':visible'), 'popover1 still visible');
ok(p2.is(':visible'), 'popover2 visible');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
//call show method of another editable, closeAll = false
e2.editable('show', false);
p2 = tip(e2);
ok(p.is(':visible'), 'popover1 still visible');
ok(p2.is(':visible'), 'popover2 visible');
e2.editable('hide');
ok(!p2.is(':visible'), 'popover2 closed');
e.editable('hide');
ok(!p.is(':visible'), 'popover1 closed');
});
test("should not wrap buttons when parent has position:absolute", function () {
var d = $('<div style="position: absolute; top: 200px">').appendTo(fx),
e = $('<a href="#" data-pk="1" data-url="post.php" data-name="text1">abc</a>').appendTo(d).editable({
showbuttons: true
});
e.click();
var p = tip(e);
ok(p.find('button').offset().top < p.find('.editable-input').offset().top + p.find('.editable-input').height(), 'buttons top ok');
ok(p.find('button').offset().left > p.find('.editable-input').offset().left + p.find('.editable-input').width(), 'buttons left ok');
d.remove();
});
test("toggle: manual", function () {
var e = $('<a href="#" id="a"></a>').appendTo('#qunit-fixture').editable({
toggle: 'manual'
});
e.click();
ok(!e.data('editableContainer'), 'popover not visible after click');
e.editable('show');
var p = tip(e);
ok(p.is(':visible'), 'shown manually');
});
test("toggle: dblclick", function () {
var e = $('<a href="#" id="a"></a>').appendTo('#qunit-fixture').editable({
toggle: 'dblclick'
}),
p, p2,
e2 = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="b">abcd</a>').appendTo('#qunit-fixture').editable();
e.click();
ok(!e.data('editableContainer'), 'popover not visible after click');
e2.click();
p2 = tip(e2);
ok(p2.is(':visible'), 'popover2 visible');
e.dblclick();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
ok(!p2.is(':visible'), 'popover2 closed');
});
test("toggle: mouseenter", function () {
var e = $('<a href="#" id="a"></a>').appendTo('#qunit-fixture').editable({
toggle: 'mouseenter'
}),
p, p2,
e2 = $('<a href="#" data-type="text" data-pk="1" data-url="post.php" id="b">abcd</a>').appendTo('#qunit-fixture').editable();
e.click();
ok(!e.data('editableContainer'), 'popover not visible after click');
e.dblclick();
ok(!e.data('editableContainer'), 'popover not visible after dblclick');
e2.click();
p2 = tip(e2);
ok(p2.is(':visible'), 'popover2 visible');
e.mouseenter();
ok(e.data('editableContainer'), 'container defined');
p = tip(e);
ok(p.is(':visible'), 'popover1 visible');
ok(!p2.is(':visible'), 'popover2 closed');
//hover once again --> container should stay open
e.hover();
p = tip(e);
ok(p.is(':visible'), 'popover1 visible after second hover');
});
test("showbuttons: false", function () {
var e = $('<a href="#" id="a" data-type="text"></a>').appendTo('#qunit-fixture').editable({
showbuttons: false
});
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover visible');
ok(!p.find('.editable-submit').length, 'submit not rendered');
ok(!p.find('.editable-cancel').length, 'cancel not rendered');
ok(!p.find('.editable-buttons').length, '.editable-buttons block not rendered');
});
asyncTest("composite pk defined as json in data-pk attribute", function () {
var e = $('<a href="#" data-pk="{a: 1, b: 2}" data-url="post-pk.php">abc</a>').appendTo(fx).editable({
name: 'username'
}),
newText = 'cd<e>;"'
$.mockjax({
url: 'post-pk.php',
response: function(settings) {
equal(settings.data.pk.a, 1, 'first part ok');
equal(settings.data.pk.b, 2, 'second part ok');
}
});
e.click()
var p = tip(e);
ok(p.find('input[type=text]').length, 'input exists')
p.find('input').val(newText);
p.find('form').submit();
setTimeout(function() {
e.remove();
start();
}, timeout);
});
asyncTest("cancelnochange: true", function () {
var v = 'abc',
e = $('<a href="#" data-type="text" data-pk="1" data-url="post-no.php" data-name="text1">'+v+'</a>').appendTo(fx).editable({
cancelnochange: true
}),
req = 0;
$.mockjax({
url: 'post-no.php',
response: function() {
req++;
}
});
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover visible');
p.find('input[type="text"]').val(v);
p.find('form').submit();
setTimeout(function() {
ok(!p.is(':visible'), 'popover closed');
equal(req, 0, 'request was not performed');
e.remove();
start();
}, timeout);
});
asyncTest("cancelnochange: false", function () {
var v = 'abc',
e = $('<a href="#" data-type="text" data-pk="1" data-url="post-yes.php" data-name="text1">'+v+'</a>').appendTo(fx).editable({
cancelnochange: false
}),
req = 0;
$.mockjax({
url: 'post-yes.php',
response: function() {
req++;
}
});
e.click();
var p = tip(e);
ok(p.is(':visible'), 'popover visible');
p.find('input[type="text"]').val(v);
p.find('form').submit();
setTimeout(function() {
ok(!p.is(':visible'), 'popover closed');
equal(req, 1, 'request was performed');
e.remove();
start();
}, timeout);
});
//unfortunatly, testing this feature does not always work in browsers. Tested manually.
/*
test("enablefocus option", function () {
// focusing not passed in phantomjs
if($.browser.webkit) {
ok(true, 'skipped in PhantomJS');
return;
}
var e = $('<a href="#">abc</a>').appendTo('#qunit-fixture').editable({
enablefocus: true
}),
e1 = $('<a href="#">abcd</a>').appendTo('#qunit-fixture').editable({
enablefocus: false
});
e.click()
var p = tip(e);
ok(p.is(':visible'), 'popover 1 visible');
p.find('button[type=button]').click();
ok(!p.is(':visible'), 'popover closed');
ok(e.is(':focus'), 'element 1 is focused');
e1.click()
p = tip(e1);
ok(p.is(':visible'), 'popover 2 visible');
p.find('button[type=button]').click();
ok(!p.is(':visible'), 'popover closed');
ok(!e1.is(':focus'), 'element 2 is not focused');
});
*/
}(jQuery));