mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.promise: Remove some redundant checks, add tests confirming redundancy
This lines don't appear to do anything useful, and all tests pass when they are removed. Discovered via mutation testing. I added extra tests to exercise this code, because I wasn't certain that there were no side-effects caused by removal. Everything appears to be fine, thanks to the "pending" check at the start of promise_settle().
This commit is contained in:
parent
d08ddc1f4a
commit
aed0c1c5ab
2 changed files with 21 additions and 4 deletions
|
@ -30,6 +30,27 @@ describe("util.promise", function ()
|
|||
r("foo");
|
||||
assert.spy(cb).was_called(1);
|
||||
end);
|
||||
it("ignores resolve/reject of settled promises", function ()
|
||||
local res, rej;
|
||||
local p = promise.new(function (resolve, reject)
|
||||
res, rej = resolve, reject;
|
||||
end);
|
||||
local cb = spy.new(function (v)
|
||||
assert.equal("foo", v);
|
||||
end);
|
||||
p:next(cb, cb);
|
||||
assert.spy(cb).was_called(0);
|
||||
res("foo");
|
||||
assert.spy(cb).was_called(1);
|
||||
rej("bar");
|
||||
assert.spy(cb).was_called(1);
|
||||
rej(promise.resolve("bar"));
|
||||
assert.spy(cb).was_called(1);
|
||||
res(promise.reject("bar"));
|
||||
assert.spy(cb).was_called(1);
|
||||
res(promise.resolve("bar"));
|
||||
assert.spy(cb).was_called(1);
|
||||
end);
|
||||
it("allows chaining :next() calls", function ()
|
||||
local r;
|
||||
local result;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue