Chromium Code Reviews| Index: remoting/webapp/base/js/base_unittest.js |
| diff --git a/remoting/webapp/base/js/base_unittest.js b/remoting/webapp/base/js/base_unittest.js |
| index a5a6a6f6049ac6022f3d6a137a3a06db5c8ad1e0..0f1073900f20b7350fc62bfcc82c0744e49b994a 100644 |
| --- a/remoting/webapp/base/js/base_unittest.js |
| +++ b/remoting/webapp/base/js/base_unittest.js |
| @@ -6,18 +6,18 @@ |
| 'use strict'; |
| -module('base'); |
| +QUnit.module('base'); |
| -test('mix(dest, src) should copy properties from |src| to |dest|', |
| +QUnit.test('mix(dest, src) should copy properties from |src| to |dest|', |
| function() { |
| var src = { a: 'a', b: 'b'}; |
| var dest = { c: 'c'}; |
| base.mix(dest, src); |
| - deepEqual(dest, {a: 'a', b: 'b', c: 'c'}); |
| + QUnit.deepEqual(dest, {a: 'a', b: 'b', c: 'c'}); |
| }); |
| -test('mix(dest, src) should assert if properties are overwritten', |
| +QUnit.test('mix(dest, src) should assert if properties are overwritten', |
| function() { |
| var src = { a: 'a', b: 'b'}; |
| var dest = { a: 'a'}; |
| @@ -33,21 +33,21 @@ test('mix(dest, src) should assert if properties are overwritten', |
| } |
| }); |
| -test('values(obj) should return an array containing the values of |obj|', |
| +QUnit.test('values(obj) should return an array containing the values of |obj|', |
| function() { |
| var output = base.values({ a: 'a', b: 'b'}); |
| - notEqual(output.indexOf('a'), -1, '"a" should be in the output'); |
| - notEqual(output.indexOf('b'), -1, '"b" should be in the output'); |
| + QUnit.notEqual(output.indexOf('a'), -1, '"a" should be in the output'); |
| + QUnit.notEqual(output.indexOf('b'), -1, '"b" should be in the output'); |
| }); |
| -test('deepCopy(obj) should return null on NaN and undefined', |
| +QUnit.test('deepCopy(obj) should return null on NaN and undefined', |
| function() { |
| QUnit.equal(base.deepCopy(NaN), null); |
| QUnit.equal(base.deepCopy(undefined), null); |
| }); |
| -test('deepCopy(obj) should copy primitive types recursively', |
| +QUnit.test('deepCopy(obj) should copy primitive types recursively', |
| function() { |
| QUnit.equal(base.deepCopy(1), 1); |
| QUnit.equal(base.deepCopy('hello'), 'hello'); |
| @@ -62,7 +62,7 @@ test('deepCopy(obj) should copy primitive types recursively', |
| QUnit.deepEqual(base.deepCopy([1, [2, [3]]]), [1, [2, [3]]]); |
| }); |
| -test('modify the original after deepCopy(obj) should not affect the copy', |
| +QUnit.test('modify the original after deepCopy(obj) should not affect the copy', |
| function() { |
| var original = [1, 2, 3, 4]; |
| var copy = base.deepCopy(original); |
| @@ -70,7 +70,7 @@ test('modify the original after deepCopy(obj) should not affect the copy', |
| QUnit.deepEqual(copy, [1, 2, 3, 4]); |
| }); |
| -test('dispose(obj) should invoke the dispose method on |obj|', |
| +QUnit.test('dispose(obj) should invoke the dispose method on |obj|', |
| function() { |
| /** |
| * @constructor |
| @@ -84,19 +84,20 @@ test('dispose(obj) should invoke the dispose method on |obj|', |
| sinon.assert.called(obj.dispose); |
| }); |
| -test('dispose(obj) should not crash if |obj| is null', |
| +QUnit.test('dispose(obj) should not crash if |obj| is null', |
| function() { |
| - expect(0); |
| + QUnit.expect(0); |
| base.dispose(null); |
| }); |
| -test('urljoin(url, opt_param) should return url if |opt_param| is missing', |
| +QUnit.test( |
| + 'urljoin(url, opt_param) should return url if |opt_param| is missing', |
| function() { |
| QUnit.equal( |
| base.urlJoin('http://www.chromium.org'), 'http://www.chromium.org'); |
| }); |
| -test('urljoin(url, opt_param) should urlencode |opt_param|', |
| +QUnit.test('urljoin(url, opt_param) should urlencode |opt_param|', |
| function() { |
| var result = base.urlJoin('http://www.chromium.org', { |
| a: 'a', |
| @@ -109,13 +110,13 @@ test('urljoin(url, opt_param) should urlencode |opt_param|', |
| '&escapist=%3A%2F%3F%23%5B%5D%40%24%26%2B%2C%3B%3D'); |
| }); |
| -test('escapeHTML(str) should escape special characters', function() { |
| +QUnit.test('escapeHTML(str) should escape special characters', function() { |
| QUnit.equal( |
| base.escapeHTML('<script>alert("hello")</script>'), |
| '<script>alert("hello")</script>'); |
| }); |
| -QUnit.asyncTest('Promise.sleep(delay) should fulfill the promise after |delay|', |
| +QUnit.test('Promise.sleep(delay) should fulfill the promise after |delay|', |
| /** |
| * 'this' is not defined for jscompile, so it can't figure out the type of |
| * this.clock. |
| @@ -125,10 +126,9 @@ QUnit.asyncTest('Promise.sleep(delay) should fulfill the promise after |delay|', |
| var isCalled = false; |
| var clock = /** @type {QUnit.Clock} */ (this.clock); |
| - base.Promise.sleep(100).then(function(){ |
| + var promise = base.Promise.sleep(100).then(function(){ |
| isCalled = true; |
| - ok(true, 'Promise.sleep() is fulfilled after delay.'); |
| - QUnit.start(); |
| + QUnit.ok(true, 'Promise.sleep() is fulfilled after delay.'); |
| }); |
| // Tick the clock for 2 seconds and check if the promise is fulfilled. |
| @@ -137,28 +137,33 @@ QUnit.asyncTest('Promise.sleep(delay) should fulfill the promise after |delay|', |
| // Promise fulfillment always occur on a new stack. Therefore, we will run |
| // the verification in a requestAnimationFrame. |
| window.requestAnimationFrame(function(){ |
| - ok(!isCalled, 'Promise.sleep() should not be fulfilled prematurely.'); |
| + QUnit.ok( |
| + !isCalled, 'Promise.sleep() should not be fulfilled prematurely.'); |
| clock.tick(101); |
| }); |
| + |
| + return promise; |
| }); |
| -QUnit.asyncTest('Promise.negate should fulfill iff the promise does not.', |
| +QUnit.test('Promise.negate should fulfill iff the promise does not.', |
| function() { |
| - |
| - base.Promise.negate(Promise.reject()).then( |
| - QUnit.ok.bind(null, true), |
| - /** @type {Function} */ (QUnit.ok.bind(null, false))); |
| - base.Promise.negate(Promise.resolve()).then( |
| - QUnit.ok.bind(null, false), |
| - /** @type {Function} */ (QUnit.ok.bind(null, true))); |
| - window.requestAnimationFrame(function(){ |
| - QUnit.start(); |
| + return base.Promise.negate(Promise.reject()) |
| + .then(function() { |
| + QUnit.ok(true); |
| + }).catch(function() { |
|
John Williams
2015/03/17 19:22:37
Nit: If you start one line with a dot, you should
|
| + QUnit.ok(false); |
| + }).then(function() { |
| + return base.Promise.negate(Promise.resolve()); |
| + }).then(function() { |
| + QUnit.ok(false); |
| + }).catch(function() { |
| + QUnit.ok(true); |
| }); |
| }); |
| -module('base.Deferred'); |
| +QUnit.module('base.Deferred'); |
| -QUnit.asyncTest('resolve() should fulfill the underlying promise.', function() { |
| +QUnit.test('resolve() should fulfill the underlying promise.', function() { |
| /** @returns {Promise} */ |
| function async() { |
| var deferred = new base.Deferred(); |
| @@ -166,17 +171,14 @@ QUnit.asyncTest('resolve() should fulfill the underlying promise.', function() { |
| return deferred.promise(); |
| } |
| - async().then( |
| - /** @param {string} value */ |
| - function(value){ |
| - QUnit.equal(value, 'bar'); |
| - QUnit.start(); |
| - }, function() { |
| - QUnit.ok(false, 'The reject handler should not be invoked.'); |
| - }); |
| + return async().then(function(/** string */ value){ |
| + QUnit.equal(value, 'bar'); |
| + }, function() { |
| + QUnit.ok(false, 'The reject handler should not be invoked.'); |
|
John Williams
2015/03/17 19:22:37
I don't think the 2nd argument to 'then' is necess
|
| + }); |
| }); |
| -QUnit.asyncTest('reject() should fail the underlying promise.', function() { |
| +QUnit.test('reject() should fail the underlying promise.', function() { |
| /** @returns {Promise} */ |
| function async() { |
| var deferred = new base.Deferred(); |
| @@ -184,11 +186,10 @@ QUnit.asyncTest('reject() should fail the underlying promise.', function() { |
| return deferred.promise(); |
| } |
| - async().then(function(){ |
| + return async().then(function(){ |
| QUnit.ok(false, 'The then handler should not be invoked.'); |
| }, function(value) { |
| QUnit.equal(value, 'bar'); |
| - QUnit.start(); |
| }); |
| }); |
| @@ -197,25 +198,26 @@ QUnit.asyncTest('reject() should fail the underlying promise.', function() { |
| var source = null; |
| var listener = null; |
| -module('base.EventSource', { |
| - setup: function() { |
| +QUnit.module('base.EventSource', { |
| + beforeEach: function() { |
| source = new base.EventSourceImpl(); |
| source.defineEvents(['foo', 'bar']); |
| listener = sinon.spy(); |
| source.addEventListener('foo', listener); |
| }, |
| - teardown: function() { |
| + afterEach: function() { |
| source = null; |
| listener = null; |
| } |
| }); |
| -test('raiseEvent() should invoke the listener', function() { |
| +QUnit.test('raiseEvent() should invoke the listener', function() { |
| source.raiseEvent('foo'); |
| sinon.assert.called(listener); |
| }); |
| -test('raiseEvent() should invoke the listener with the correct event data', |
| +QUnit.test( |
| + 'raiseEvent() should invoke the listener with the correct event data', |
| function() { |
| var data = { |
| field: 'foo' |
| @@ -224,25 +226,25 @@ test('raiseEvent() should invoke the listener with the correct event data', |
| sinon.assert.calledWith(listener, data); |
| }); |
| -test( |
| +QUnit.test( |
| 'raiseEvent() should not invoke listeners that are added during raiseEvent', |
| function() { |
| source.addEventListener('foo', function() { |
| source.addEventListener('foo', function() { |
| - ok(false); |
| + QUnit.ok(false); |
| }); |
| - ok(true); |
| + QUnit.ok(true); |
| }); |
| source.raiseEvent('foo'); |
| }); |
| -test('raiseEvent() should not invoke listeners of a different event', |
| +QUnit.test('raiseEvent() should not invoke listeners of a different event', |
| function() { |
| source.raiseEvent('bar'); |
| sinon.assert.notCalled(listener); |
| }); |
| -test('raiseEvent() should assert when undeclared events are raised', |
| +QUnit.test('raiseEvent() should assert when undeclared events are raised', |
| function() { |
| sinon.stub(base.debug, 'assert'); |
| try { |
| @@ -254,7 +256,7 @@ test('raiseEvent() should assert when undeclared events are raised', |
| } |
| }); |
| -test( |
| +QUnit.test( |
| 'removeEventListener() should not invoke the listener in subsequent ' + |
| 'calls to |raiseEvent|', |
| function() { |
| @@ -266,7 +268,7 @@ test( |
| sinon.assert.calledOnce(listener); |
| }); |
| -test('removeEventListener() should work even if the listener ' + |
| +QUnit.test('removeEventListener() should work even if the listener ' + |
| 'is removed during |raiseEvent|', |
| function() { |
| var sink = {}; |
| @@ -282,7 +284,7 @@ test('removeEventListener() should work even if the listener ' + |
| sinon.assert.calledOnce(sink.listener); |
| }); |
| -test('encodeUtf8() can encode UTF8 strings', function() { |
| +QUnit.test('encodeUtf8() can encode UTF8 strings', function() { |
| /** @type {function(ArrayBuffer):Array} */ |
| function toJsArray(arrayBuffer) { |
| var result = []; |
| @@ -306,7 +308,7 @@ test('encodeUtf8() can encode UTF8 strings', function() { |
| [0xF0, 0x9F, 0x98, 0x83]); |
| }); |
| -test('decodeUtf8() can decode UTF8 strings', function() { |
| +QUnit.test('decodeUtf8() can decode UTF8 strings', function() { |
| // ASCII. |
| QUnit.equal(base.decodeUtf8(new Uint8Array([0x41, 0x42, 0x43]).buffer), |
| "ABC"); |