Имитация щелчка мышью с тестированием Jasmine Unit
Я новичок в Жасмин и до сих пор смог настроить пару основных тестов. Сейчас я пытаюсь создать тест, имитирующий событие щелчка мыши на элементе, например, div, теге и т. Д.
Мой тест должен быть в состоянии определить, расширяется ли при нажатии на ссылку контейнер div - я определяю это по имени класса.
В моем исходном коде есть прослушиватель событий, прослушивающий события щелчка:
MYSITE.$("sites.retail.UI.Product").Filter = (function () {
var STATE = MYSITE.system.BitState;
var NODE = MYSITE.system.DOM.node;
function _constructor() {
var _searchContainer = document.getElementById("filterWidget");
this.toggle = document.getElementById("filterHeader");
var _self = this;
MYSITE.system.event.attach(_searchContainer, "click",
function (e) {
if (NODE.hasClassName(e.target, "filterHeader")) {
if (!STATE.Manager.isFlagSelected('Global', null, STATE.Flags.Global.ProductListShowRefinements)) {
_self.collapse();
} else {
MYSITE.system.DOM.node.removeClassName(document.getElementById('filterCollapse'), "hide")
_self.expand();
}
e.prevent();
}
else if (NODE.hasClassName(e.target, "showMoreCont")) {
NODE.addClassName(NODE.getElementsByClassAndTagName(_searchContainer, "searchShowMoreCount", "div")[0], "hide");
NODE.removeClassName(NODE.getElementsByClassAndTagName(_searchContainer, "hiddenSearchContent", "div")[0], "hide");
e.prevent();
}
else if (NODE.hasClassName(e.target, "showLessCont")) {
NODE.removeClassName(NODE.getElementsByClassAndTagName(_searchContainer, "searchShowMoreCount", "div")[0], "hide");
NODE.addClassName(NODE.getElementsByClassAndTagName(_searchContainer, "hiddenSearchContent", "div")[0], "hide");
e.prevent();
}
}
);
_constructor.base.constructor.call(this, document.getElementById("filterWidget"), STATE.Manager.isFlagSelected('Global', null, STATE.Flags.Global.ProductListShowRefinements));
return this;
}
_constructor.extend(MYSITE.UI.Collapse);
_constructor.prototype.collapse = function (settings) {
this.toggle.className = "filterHeader closed"; //Set explicitly rather than addNew
STATE.Manager.setFlag('Global', null, parseInt(STATE.Flags.Global.ProductListShowRefinements));
_constructor.base.collapse.call(this, { steps: '1' });
}
и HTML-разметка
<div id="filterWidget">
<a class="filterHeader closed" id="filterHeader" href="#">
<span class="filterHeader">Refine your search</span>
</a>
<div class="collapsible" id="filterCollapse">
<div class="content">
</div></div></div>
Модульный тест я пытаюсь это:
describe("Filter", function() {
it("should use collapse function", function() {
loadFixtures('fixture.html');
var filter = new MYSITE.sites.retail.UI.Product.Filter();
jQuery.noConflict();
var btn = jQuery("#filterHeader");
var click = jQuery.Event('click');
btn.trigger(click);
expect(filter.toggle.className).toEqual("filterHeader open");
});
});
Но событие click, кажется, никогда не воспринимается исходным кодом.
Что я делаю неправильно?
заранее спасибо
2 ответа
JQuery-х trigger
Метод не создает реальное событие в браузере и не вызывает обработчики событий, зарегистрированные с помощью основных методов js, таких как addEventListener
!
В github есть проект, который используется командой jquery, когда тестирование включает в себя собственные события браузера, и вот плагин: https://github.com/eduardolundgren/jquery-simulate
Идея состоит в том, что реальное событие в конечном счете вызовет обработчик jquery, когда оно начнет течь, и бонусом является то, что даже другие виды обработчиков, зарегистрированные без jquery, тоже будут реагировать.
Проблема в том, что событие, инициированное запросом, не имеет целевого объекта по умолчанию. Попробуй это:
var click = jQuery.Event("click", { target: $('<div class="">test</div>') });