ladybird/Libraries/LibJS/Tests/builtins/Promise/Promise.all.js

116 lines
3 KiB
JavaScript

test("length is 1", () => {
expect(Promise.all).toHaveLength(1);
});
describe("normal behavior", () => {
test("returns a Promise", () => {
const promise = Promise.all();
expect(promise).toBeInstanceOf(Promise);
});
test("resolve", () => {
const promise1 = Promise.resolve(3);
const promise2 = 42;
const promise3 = new Promise((resolve, reject) => {
resolve("foo");
});
let resolvedValues = null;
let wasRejected = false;
Promise.all([promise1, promise2, promise3]).then(
values => {
resolvedValues = values;
},
() => {
wasRejected = true;
}
);
runQueuedPromiseJobs();
expect(resolvedValues).toEqual([3, 42, "foo"]);
expect(wasRejected).toBeFalse();
});
test("reject", () => {
const promise1 = Promise.resolve(3);
const promise2 = 42;
const promise3 = new Promise((resolve, reject) => {
reject("foo");
});
let rejectionReason = null;
let wasResolved = false;
Promise.all([promise1, promise2, promise3]).then(
() => {
wasResolved = true;
},
reason => {
rejectionReason = reason;
}
);
runQueuedPromiseJobs();
expect(rejectionReason).toBe("foo");
expect(wasResolved).toBeFalse();
});
});
describe("exceptional behavior", () => {
test("cannot invoke capabilities executor twice", () => {
function fn() {}
expect(() => {
function promise(executor) {
executor(fn, fn);
executor(fn, fn);
}
Promise.all.call(promise, []);
}).toThrow(TypeError);
expect(() => {
function promise(executor) {
executor(fn, undefined);
executor(fn, fn);
}
Promise.all.call(promise, []);
}).toThrow(TypeError);
expect(() => {
function promise(executor) {
executor(undefined, fn);
executor(fn, fn);
}
Promise.all.call(promise, []);
}).toThrow(TypeError);
});
test("promise without resolve method", () => {
expect(() => {
function promise(executor) {}
Promise.all.call(promise, []);
}).toThrow(TypeError);
});
test("no parameters", () => {
let rejectionReason = null;
Promise.all().catch(reason => {
rejectionReason = reason;
});
runQueuedPromiseJobs();
expect(rejectionReason).toBeInstanceOf(TypeError);
});
test("non-iterable", () => {
let rejectionReason = null;
Promise.all(1).catch(reason => {
rejectionReason = reason;
});
runQueuedPromiseJobs();
expect(rejectionReason).toBeInstanceOf(TypeError);
});
});