diff options
author | Matthew Wild <mwild1@gmail.com> | 2021-03-25 13:51:16 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2021-03-25 13:51:16 +0000 |
commit | 3952fae8ce728d56b9ef2044e490d99a6c12f444 (patch) | |
tree | fc6be322593893ecf6b362a5836002395414fad1 /spec/util_promise_spec.lua | |
parent | 85d3eb829bb48512ab27a4c4971403e1f2284fb0 (diff) | |
download | prosody-3952fae8ce728d56b9ef2044e490d99a6c12f444.tar.gz prosody-3952fae8ce728d56b9ef2044e490d99a6c12f444.zip |
util.promise: Add support for arbitrary keys in all()/all_settled()
Diffstat (limited to 'spec/util_promise_spec.lua')
-rw-r--r-- | spec/util_promise_spec.lua | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/spec/util_promise_spec.lua b/spec/util_promise_spec.lua index 6fb5d6bd..4be9b5a0 100644 --- a/spec/util_promise_spec.lua +++ b/spec/util_promise_spec.lua @@ -352,6 +352,23 @@ describe("util.promise", function () assert.spy(cb_err).was_called(1); assert.equal("fail", result); end); + it("works with non-numeric keys", function () + local r1, r2; + local p1, p2 = promise.new(function (resolve) r1 = resolve end), promise.new(function (resolve) r2 = resolve end); + local p = promise.all({ [true] = p1, [false] = p2 }); + + local result; + local cb = spy.new(function (v) + result = v; + end); + p:next(cb); + assert.spy(cb).was_called(0); + r2("yep"); + assert.spy(cb).was_called(0); + r1("nope"); + assert.spy(cb).was_called(1); + assert.same({ [true] = "nope", [false] = "yep" }, result); + end); end); describe("all_settled()", function () it("works with fulfilled promises", function () @@ -406,6 +423,26 @@ describe("util.promise", function () { status = "rejected", reason = "this fails" }; }, result); end); + it("works with non-numeric keys", function () + local r1, r2; + local p1, p2 = promise.new(function (resolve) r1 = resolve end), promise.new(function (resolve) r2 = resolve end); + local p = promise.all_settled({ foo = p1, bar = p2 }); + + local result; + local cb = spy.new(function (v) + result = v; + end); + p:next(cb); + assert.spy(cb).was_called(0); + r2("yep"); + assert.spy(cb).was_called(0); + r1("nope"); + assert.spy(cb).was_called(1); + assert.same({ + foo = { status = "fulfilled", value = "nope" }; + bar = { status = "fulfilled", value = "yep" }; + }, result); + end); end); describe("catch()", function () it("works", function () |