在继续Javascript函数之前强制更改DOM(用于测试目的)
我正在尝试使用QUnit编写一些javascript单元测试。特别是,我想测试各种用户操作,我一直在用jQuery.simulate从jQueryUI进行测试 当然,问题是这些更改/事件发生在函数结束之后,因为Javascript是单线程的在继续Javascript函数之前强制更改DOM(用于测试目的),javascript,jquery,asynchronous,Javascript,Jquery,Asynchronous,我正在尝试使用QUnit编写一些javascript单元测试。特别是,我想测试各种用户操作,我一直在用jQuery.simulate从jQueryUI进行测试 当然,问题是这些更改/事件发生在函数结束之后,因为Javascript是单线程的 $("#myTextBox").focus().is(":focus") // returns false; 所以,我一直在做的事情,我知道这是一个非常丑陋的解决方案,就是用一系列承诺和设置超时来运行我的测试: 所有嵌套的匿名函数都让我头疼,更不用说因为打
$("#myTextBox").focus().is(":focus") // returns false;
所以,我一直在做的事情,我知道这是一个非常丑陋的解决方案,就是用一系列承诺和设置超时来运行我的测试:
所有嵌套的匿名函数都让我头疼,更不用说因为打字量太大而降低了工作效率
javascript中一定有更好的异步到同步模式,对吗?请?$“输入”。焦点。is:焦点对我来说很好:你从QUnit试过这个吗?
var giveItASec = function () {
return new Promise(function (resolve, reject) {
setTimeout(function () {
resolve();
});
});
}
test("My test", function (assert) {
var done = assert.async();
Promise.resolve().then(function () {
// do some assertions
// DOM Manipulation
return giveItASec();
}).then(function () {
// more assertions about the DOM
// repeat pattern as needed
done();
});
});