/* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; Components.utils.import("resource://gre/modules/PromiseUtils.jsm"); Components.utils.import("resource://gre/modules/Timer.jsm"); // Tests for PromiseUtils.jsm function run_test() { run_next_test(); } /////////////////////////////////////////////////////////////////////////////////////////// // Tests for PromiseUtils.resolveOrTimeout() /////////////////////////////////////////////////////////////////////////////////////////// /* Tests for the case when arguments to resolveOrTimeout * are not of correct type */ add_task(function* test_wrong_arguments() { let p = new Promise((resolve, reject) => {}); // for the first argument Assert.throws(() => PromiseUtils.resolveOrTimeout("string", 200), /first argument must be a Promise object/, "TypeError thrown because first argument is not a Promsie object"); // for second argument Assert.throws(() => PromiseUtils.resolveOrTimeout(p, "string"), /second argument must be a positive number/, "TypeError thrown because second argument is not a positive number"); // for the third argument Assert.throws(() => PromiseUtils.resolveOrTimeout(p, 200, "string"), /third optional argument must be a function/, "TypeError thrown because thrird argument is not a function"); }); /* Tests for the case when the optional third argument is not provided * In that case the returned promise rejects with a default Error */ add_task(function* test_optional_third_argument() { let p = new Promise((resolve, reject) => {}); yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200), /Promise Timeout/, "Promise rejects with a default Error"); }); /* Test for the case when the passed promise resolves quickly * In that case the returned promise also resolves with the same value */ add_task(function* test_resolve_quickly() { let p = new Promise((resolve, reject) => setTimeout(() => resolve("Promise is resolved"), 20)); let result = yield PromiseUtils.resolveOrTimeout(p, 200); Assert.equal(result, "Promise is resolved", "Promise resolves quickly"); }); /* Test for the case when the passed promise rejects quickly * In that case the returned promise also rejects with the same value */ add_task(function* test_reject_quickly() { let p = new Promise((resolve, reject) => setTimeout(() => reject("Promise is rejected"), 20)); yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200), /Promise is rejected/, "Promise rejects quickly"); }); /* Tests for the case when the passed promise doesn't settle * and rejection returns string/object/undefined */ add_task(function* test_rejection_function() { let p = new Promise((resolve, reject) => {}); // for rejection returning string yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200, () => { return "Rejection returned a string"; }), /Rejection returned a string/, "Rejection returned a string"); // for rejection returning object yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200, () => { return {Name:"Promise"}; }), Object, "Rejection returned an object"); // for rejection returning undefined yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200, () => { return; }), undefined, "Rejection returned undefined"); }); /* Tests for the case when the passed promise doesn't settles * and rejection throws an error */ add_task(function* test_rejection_throw_error() { let p = new Promise((resolve, reject) => {}); yield Assert.rejects(PromiseUtils.resolveOrTimeout(p, 200, () => { throw new Error("Rejection threw an Error"); }), /Rejection threw an Error/, "Rejection threw an error"); }); /////////////////////////////////////////////////////////////////////////////////////// // Tests for PromiseUtils.defer() /////////////////////////////////////////////////////////////////////////////////////// /* Tests for checking the resolve method of the Deferred object * returned by PromiseUtils.defer() */ add_task(function* test_resolve_string() { let def = PromiseUtils.defer(); let expected = "The promise is resolved " + Math.random(); def.resolve(expected); let result = yield def.promise; Assert.equal(result, expected, "def.resolve() resolves the promise"); }); /* Test for the case when undefined is passed to the resolve method * of the Deferred object */ add_task(function* test_resolve_undefined() { let def = PromiseUtils.defer(); def.resolve(); let result = yield def.promise; Assert.equal(result, undefined, "resolve works with undefined as well"); }); /* Test when a pending promise is passed to the resolve method * of the Deferred object */ add_task(function* test_resolve_pending_promise() { let def = PromiseUtils.defer(); let expected = 100 + Math.random(); let p = new Promise((resolve, reject) => { setTimeout(() => resolve(expected), 100); }); def.resolve(p); let result = yield def.promise; Assert.equal(result, expected, "def.promise assumed the state of the passed promise"); }); /* Test when a resovled promise is passed * to the resolve method of the Deferred object */ add_task(function* test_resolve_resolved_promise() { let def = PromiseUtils.defer(); let expected = "Yeah resolved" + Math.random(); let p = new Promise((resolve, reject) => resolve(expected)); def.resolve(p); let result = yield def.promise; Assert.equal(result, expected, "Resolved promise is passed to the resolve method"); }); /* Test for the case when a rejected promise is * passed to the resolve method */ add_task(function* test_resolve_rejected_promise() { let def = PromiseUtils.defer(); let p = new Promise((resolve, reject) => reject(new Error("There its an rejection"))); def.resolve(p); yield Assert.rejects(def.promise, /There its an rejection/, "Settled rejection promise passed to the resolve method"); }); /* Test for the checking the reject method of * the Deferred object returned by PromiseUtils.defer() */ add_task(function* test_reject_Error() { let def = PromiseUtils.defer(); def.reject(new Error("This one rejects")); yield Assert.rejects(def.promise, /This one rejects/, "reject method with Error for rejection"); }); /* Test for the case when a pending Promise is passed to * the reject method of Deferred object */ add_task(function* test_reject_pending_promise() { let def = PromiseUtils.defer(); let p = new Promise((resolve, reject) => { setTimeout(() => resolve(100), 100); }); def.reject(p); yield Assert.rejects(def.promise, Promise, "Rejection with a pending promise uses the passed promise itself as the reason of rejection"); }); /* Test for the case when a resolved Promise * is passed to the reject method */ add_task(function* test_reject_resolved_promise() { let def = PromiseUtils.defer(); let p = new Promise((resolve, reject) => resolve("This resolved")); def.reject(p); yield Assert.rejects(def.promise, Promise, "Rejection with a resolved promise uses the passed promise itself as the reason of rejection"); }); /* Test for the case when a rejected Promise is * passed to the reject method */ add_task(function* test_reject_resolved_promise() { let def = PromiseUtils.defer(); let p = new Promise((resolve, reject) => reject(new Error("This on rejects"))); def.reject(p); yield Assert.rejects(def.promise, Promise, "Rejection with a rejected promise uses the passed promise itself as the reason of rejection"); });