Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 'use strict'; | |
| 2 | |
| 3 if (self.importScripts) { | |
| 4 self.importScripts('/resources/testharness.js'); | |
| 5 } | |
| 6 | |
| 7 test(() => { | |
| 8 | |
| 9 const strategy = new ByteLengthQueuingStrategy({ highWaterMark: 4 }); | |
| 10 | |
| 11 }, 'Can construct a ByteLengthQueuingStrategy with a valid high water mark'); | |
| 12 | |
| 13 test(() => { | |
| 14 | |
| 15 for (const highWaterMark of [-Infinity, NaN, 'foo', {}, () => {}]) { | |
| 16 const strategy = new ByteLengthQueuingStrategy({ highWaterMark }); | |
| 17 assert_equals(strategy.highWaterMark, highWaterMark, `${highWaterMark} gets set correctly`); | |
| 18 } | |
| 19 | |
| 20 }, 'Can construct a ByteLengthQueuingStrategy with any value as its high water m ark'); | |
| 21 | |
| 22 test(() => { | |
| 23 | |
| 24 const highWaterMark = 1; | |
| 25 const highWaterMarkObjectGetter = { | |
| 26 get highWaterMark() { return highWaterMark; }, | |
| 27 }; | |
| 28 const error = new Error('wow!'); | |
| 29 const highWaterMarkObjectGetterThrowing = { | |
| 30 get highWaterMark() { throw error; }, | |
| 31 }; | |
| 32 | |
| 33 assert_throws({ name: 'TypeError' }, () => new ByteLengthQueuingStrategy(), 'c onstruction fails with undefined'); | |
| 34 assert_throws({ name: 'TypeError' }, () => new ByteLengthQueuingStrategy(null) , 'construction fails with null'); | |
| 35 assert_throws({ name: 'Error' }, () => new ByteLengthQueuingStrategy(highWater MarkObjectGetterThrowing), | |
| 36 'construction fails with an object with a throwing highWaterMark getter'); | |
| 37 | |
| 38 // Should not fail: | |
| 39 new ByteLengthQueuingStrategy('potato'); | |
| 40 new ByteLengthQueuingStrategy({}); | |
| 41 new ByteLengthQueuingStrategy(highWaterMarkObjectGetter); | |
| 42 | |
| 43 }, 'ByteLengthQueuingStrategy constructor behaves as expected with wrong argumen ts'); | |
|
tyoshino (SeeGerritForStatus)
2015/10/02 11:33:28
nitpick: is the first test case considered to be u
domenic
2015/10/02 22:32:14
Yeah. (The wrong argument is undefined.)
tyoshino (SeeGerritForStatus)
2015/10/05 07:55:45
Ahh, sorry. By "first case", I meant highWaterMark
| |
| 44 | |
|
yhirano
2015/10/02 07:27:16
It would be good to have a test checking that "hig
domenic
2015/10/02 22:32:14
Added. Kind of redundant with the property descrip
| |
| 45 test(() => { | |
| 46 | |
| 47 const size = 1024; | |
| 48 const chunk = { byteLength: size }; | |
| 49 const chunkGetter = { | |
| 50 get byteLength() { return size; }, | |
| 51 } | |
| 52 const error = new Error('wow!'); | |
| 53 const chunkGetterThrowing = { | |
| 54 get byteLength() { throw error; }, | |
| 55 } | |
| 56 assert_throws({ name: 'TypeError' }, () => ByteLengthQueuingStrategy.prototype .size(), 'size fails with undefined'); | |
| 57 assert_throws({ name: 'TypeError' }, () => ByteLengthQueuingStrategy.prototype .size(null), 'size fails with null'); | |
| 58 assert_equals(ByteLengthQueuingStrategy.prototype.size('potato'), undefined, | |
| 59 'size succeeds with undefined with a random non-object type'); | |
| 60 assert_equals(ByteLengthQueuingStrategy.prototype.size({}), undefined, | |
| 61 'size succeeds with undefined with an object without hwm property'); | |
| 62 assert_equals(ByteLengthQueuingStrategy.prototype.size(chunk), size, | |
| 63 'size succeeds with the right amount with an object with a hwm'); | |
| 64 assert_equals(ByteLengthQueuingStrategy.prototype.size(chunkGetter), size, | |
| 65 'size succeeds with the right amount with an object with a hwm getter'); | |
| 66 assert_throws({ name: 'Error' }, () => ByteLengthQueuingStrategy.prototype.siz e(chunkGetterThrowing), | |
| 67 'size fails with the error thrown by the getter'); | |
| 68 | |
| 69 }, 'ByteLengthQueuingStrategy size behaves as expected with wrong arguments'); | |
| 70 | |
| 71 test(() => { | |
| 72 | |
| 73 const strategy = new ByteLengthQueuingStrategy({ highWaterMark: 4 }); | |
| 74 | |
| 75 assert_object_equals(Object.getOwnPropertyDescriptor(strategy, 'highWaterMark' ), | |
| 76 { value: 4, writable: true, enumerable: true, configurable: true }, | |
| 77 'highWaterMark property should be a data property with the value passed the constructor'); | |
| 78 assert_equals(typeof strategy.size, 'function'); | |
| 79 | |
| 80 }, 'ByteLengthQueuingStrategy instances have the correct properties'); | |
| 81 | |
| 82 done(); | |
| OLD | NEW |