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
|
@ -57,9 +57,7 @@ local function promise_settle(promise, new_state, new_next, cbs, value)
|
|||
end
|
||||
|
||||
local function new_resolve_functions(p)
|
||||
local resolved = false;
|
||||
local function _resolve(v)
|
||||
if resolved then return; end
|
||||
resolved = true;
|
||||
if is_promise(v) then
|
||||
v:next(new_resolve_functions(p));
|
||||
|
@ -69,8 +67,6 @@ local function new_resolve_functions(p)
|
|||
|
||||
end
|
||||
local function _reject(e)
|
||||
if resolved then return; end
|
||||
resolved = true;
|
||||
if promise_settle(p, "rejected", next_rejected, p._pending_on_rejected, e) then
|
||||
p.reason = e;
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue