diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /addon-sdk/source/test/test-timer.js | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'addon-sdk/source/test/test-timer.js')
-rw-r--r-- | addon-sdk/source/test/test-timer.js | 229 |
1 files changed, 229 insertions, 0 deletions
diff --git a/addon-sdk/source/test/test-timer.js b/addon-sdk/source/test/test-timer.js new file mode 100644 index 000000000..eed0fd047 --- /dev/null +++ b/addon-sdk/source/test/test-timer.js @@ -0,0 +1,229 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +"use strict"; + +var timer = require("sdk/timers"); +const { Loader } = require("sdk/test/loader"); +const { gc } = require("sdk/test/memory"); +const { all, defer } = require("sdk/core/promise"); + +exports.testSetTimeout = function(assert, end) { + timer.setTimeout(function() { + assert.pass("testSetTimeout passed"); + end(); + }, 1); +}; + +exports.testSetTimeoutGC = function*(assert) { + let called = defer(); + let gcDone = defer(); + + timer.setTimeout(called.resolve, 300); + gc().then(gcDone.resolve); + + yield called.promise; + yield gcDone.promise; + + assert.pass("setTimeout passed!"); +}; + +exports.testParamedSetTimeout = function(assert, end) { + let params = [1, 'foo', { bar: 'test' }, null, undefined]; + timer.setTimeout.apply(null, [function() { + assert.equal(arguments.length, params.length); + for (let i = 0, ii = params.length; i < ii; i++) + assert.equal(params[i], arguments[i]); + end(); + }, 1].concat(params)); +}; + +exports.testClearTimeout = function(assert, end) { + var myFunc = function myFunc() { + assert.fail("myFunc() should not be called in testClearTimeout"); + }; + var id = timer.setTimeout(myFunc, 1); + timer.setTimeout(function() { + assert.pass("testClearTimeout passed"); + end(); + }, 2); + timer.clearTimeout(id); +}; + +exports.testParamedClearTimeout = function(assert, end) { + let params = [1, 'foo', { bar: 'test' }, null, undefined]; + var myFunc = function myFunc() { + assert.fail("myFunc() should not be called in testClearTimeout"); + }; + var id = timer.setTimeout(myFunc, 1); + timer.setTimeout.apply(null, [function() { + assert.equal(arguments.length, params.length); + for (let i = 0, ii = params.length; i < ii; i++) + assert.equal(params[i], arguments[i]); + end(); + }, 1].concat(params)); + timer.clearTimeout(id); +}; + +exports.testSetInterval = function (assert, end) { + var count = 0; + var id = timer.setInterval(function () { + count++; + if (count >= 5) { + timer.clearInterval(id); + assert.pass("testSetInterval passed"); + end(); + } + }, 1); +}; + +exports.testSetIntervalGC = function*(assert) { + let called = defer(); + let gcDone = defer(); + let done = false; + let count = 0; + + let id = timer.setInterval(() => { + assert.pass("call count is " + count); + + if (done) { + timer.clearInterval(id); + called.resolve(); + return null; + } + + if (count++ == 0) { + assert.pass("first call to setInterval worked!"); + + gc().then(() => { + assert.pass("gc is complete!"); + done = true; + gcDone.resolve(); + }); + + assert.pass("called gc()!"); + } + + return null; + }, 1); + + yield gcDone.promise; + yield called.promise; + + assert.pass("setInterval was called after the gc!"); +}; + +exports.testParamedSetInerval = function(assert, end) { + let params = [1, 'foo', { bar: 'test' }, null, undefined]; + let count = 0; + let id = timer.setInterval.apply(null, [function() { + count ++; + if (count < 5) { + assert.equal(arguments.length, params.length); + for (let i = 0, ii = params.length; i < ii; i++) + assert.equal(params[i], arguments[i]); + } else { + timer.clearInterval(id); + end(); + } + }, 1].concat(params)); +}; + +exports.testClearInterval = function (assert, end) { + timer.clearInterval(timer.setInterval(function () { + assert.fail("setInterval callback should not be called"); + }, 1)); + var id = timer.setInterval(function () { + timer.clearInterval(id); + assert.pass("testClearInterval passed"); + end(); + }, 2); +}; + +exports.testParamedClearInterval = function(assert, end) { + timer.clearInterval(timer.setInterval(function () { + assert.fail("setInterval callback should not be called"); + }, 1, timer, {}, null)); + + let id = timer.setInterval(function() { + timer.clearInterval(id); + assert.equal(3, arguments.length); + end(); + }, 2, undefined, 'test', {}); +}; + + +exports.testImmediate = function(assert, end) { + let actual = []; + let ticks = 0; + timer.setImmediate(function(...params) { + actual.push(params); + assert.equal(ticks, 1, "is a next tick"); + assert.deepEqual(actual, [["start", "immediates"]]); + }, "start", "immediates"); + + timer.setImmediate(function(...params) { + actual.push(params); + assert.deepEqual(actual, [["start", "immediates"], + ["added"]]); + assert.equal(ticks, 1, "is a next tick"); + timer.setImmediate(function(...params) { + actual.push(params); + assert.equal(ticks, 2, "is second tick"); + assert.deepEqual(actual, [["start", "immediates"], + ["added"], + [], + ["last", "immediate", "handler"], + ["side-effect"]]); + end(); + }, "side-effect"); + }, "added"); + + timer.setImmediate(function(...params) { + actual.push(params); + assert.equal(ticks, 1, "is a next tick"); + assert.deepEqual(actual, [["start", "immediates"], + ["added"], + []]); + timer.clearImmediate(removeID); + }); + + function removed() { + assert.fail("should be removed"); + } + let removeID = timer.setImmediate(removed); + + timer.setImmediate(function(...params) { + actual.push(params); + assert.equal(ticks, 1, "is a next tick"); + assert.deepEqual(actual, [["start", "immediates"], + ["added"], + [], + ["last", "immediate", "handler"]]); + ticks = ticks + 1; + }, "last", "immediate", "handler"); + + + ticks = ticks + 1; +}; + +exports.testUnload = function(assert, end) { + var loader = Loader(module); + var sbtimer = loader.require("sdk/timers"); + + var myFunc = function myFunc() { + assert.fail("myFunc() should not be called in testUnload"); + }; + + sbtimer.setTimeout(myFunc, 1); + sbtimer.setTimeout(myFunc, 1, 'foo', 4, {}, undefined); + sbtimer.setInterval(myFunc, 1); + sbtimer.setInterval(myFunc, 1, {}, null, 'bar', undefined, 87); + loader.unload(); + timer.setTimeout(function() { + assert.pass("timer testUnload passed"); + end(); + }, 2); +}; + +require("sdk/test").run(exports); |