mirror of https://github.com/tc39/test262.git
Merge pull request #3994 from tc39/base64-tests
add tests for base64 proposal
This commit is contained in:
commit
b8cb40b66a
|
@ -131,6 +131,10 @@ source-phase-imports
|
|||
## test262 special specifier
|
||||
source-phase-imports-module-source
|
||||
|
||||
# Uint8Array Base64
|
||||
# https://github.com/tc39/proposal-arraybuffer-base64
|
||||
uint8array-base64
|
||||
|
||||
## Standard language features
|
||||
#
|
||||
# Language features that have been included in a published version of the
|
||||
|
|
|
@ -0,0 +1,22 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Conversion of base64 strings to Uint8Arrays exercising the alphabet option
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.compareArray(Uint8Array.fromBase64('x+/y'), [199, 239, 242]);
|
||||
assert.compareArray(Uint8Array.fromBase64('x+/y', { alphabet: 'base64' }), [199, 239, 242]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('x+/y', { alphabet: 'base64url' });
|
||||
});
|
||||
|
||||
assert.compareArray(Uint8Array.fromBase64('x-_y', { alphabet: 'base64url' }), [199, 239, 242]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('x-_y');
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('x-_y', { alphabet: 'base64' });
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: >
|
||||
Uint8Array.fromBase64 has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array, 'fromBase64', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Uint8Array.fromBase64 ignores its receiver
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var fromBase64 = Uint8Array.fromBase64;
|
||||
var noReceiver = fromBase64("Zg==");
|
||||
assert.sameValue(Object.getPrototypeOf(noReceiver), Uint8Array.prototype);
|
||||
|
||||
class Subclass extends Uint8Array {
|
||||
constructor() {
|
||||
throw new Test262Error("subclass constructor called");
|
||||
}
|
||||
}
|
||||
var fromSubclass = Subclass.fromBase64("Zg==");
|
||||
assert.sameValue(Object.getPrototypeOf(fromSubclass), Uint8Array.prototype);
|
|
@ -0,0 +1,23 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Uint8Array.fromBase64 throws a SyntaxError when input has non-base64, non-ascii-whitespace characters
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var illegal = [
|
||||
'Zm.9v',
|
||||
'Zm9v^',
|
||||
'Zg==&',
|
||||
'Z−==', // U+2212 'Minus Sign'
|
||||
'Z+==', // U+FF0B 'Fullwidth Plus Sign'
|
||||
'Zg\u00A0==', // nbsp
|
||||
'Zg\u2009==', // thin space
|
||||
'Zg\u2028==', // line separator
|
||||
];
|
||||
illegal.forEach(function(value) {
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64(value)
|
||||
});
|
||||
});
|
|
@ -0,0 +1,64 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Handling of final chunks in Uint8Array.fromBase64
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// padding
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg=='), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg==', { lastChunkHandling: 'loose' }), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg==', { lastChunkHandling: 'stop-before-partial' }), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg==', { lastChunkHandling: 'strict' }), [101, 120, 97, 102]);
|
||||
|
||||
// no padding
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg'), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg', { lastChunkHandling: 'loose' }), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg', { lastChunkHandling: 'stop-before-partial' }), [101, 120, 97]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
// non-zero padding bits
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh=='), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh==', { lastChunkHandling: 'loose' }), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh==', { lastChunkHandling: 'stop-before-partial' }), [101, 120, 97, 102]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZh==', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
// non-zero padding bits, no padding
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh'), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh', { lastChunkHandling: 'loose' }), [101, 120, 97, 102]);
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZh', { lastChunkHandling: 'stop-before-partial' }), [101, 120, 97]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZh', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
// partial padding
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg=');
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg=', { lastChunkHandling: 'loose' });
|
||||
});
|
||||
assert.compareArray(Uint8Array.fromBase64('ZXhhZg=', { lastChunkHandling: 'stop-before-partial' }), [101, 120, 97]);
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg=', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
// excess padding
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg===');
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg===', { lastChunkHandling: 'loose' });
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg===', { lastChunkHandling: 'stop-before-partial' });
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromBase64('ZXhhZg===', { lastChunkHandling: 'strict' });
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: >
|
||||
Uint8Array.fromBase64.length is 1.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.fromBase64, 'length', {
|
||||
value: 1,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: >
|
||||
Uint8Array.fromBase64.name is "fromBase64".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.fromBase64, 'name', {
|
||||
value: 'fromBase64',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: >
|
||||
Uint8Array.fromBase64 is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.fromBase64), "Uint8Array.fromBase64 is not a constructor");
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
new Uint8Array.fromBase64('');
|
||||
});
|
|
@ -0,0 +1,59 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Uint8Array.fromBase64 triggers effects of the "alphabet" and "lastChunkHandling" getters, but does not perform toString on the results
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64("Zg==", { alphabet: Object("base64") });
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64("Zg==", { lastChunkHandling: Object("loose") });
|
||||
});
|
||||
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64("Zg==", { alphabet: throwyToString });
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64("Zg==", { lastChunkHandling: throwyToString });
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
|
||||
var alphabetAccesses = 0;
|
||||
var base64UrlOptions = {};
|
||||
Object.defineProperty(base64UrlOptions, "alphabet", {
|
||||
get: function() {
|
||||
alphabetAccesses += 1;
|
||||
return "base64url";
|
||||
}
|
||||
});
|
||||
var arr = Uint8Array.fromBase64("x-_y", base64UrlOptions);
|
||||
assert.compareArray(arr, [199, 239, 242]);
|
||||
assert.sameValue(alphabetAccesses, 1);
|
||||
|
||||
var lastChunkHandlingAccesses = 0;
|
||||
var strictOptions = {};
|
||||
Object.defineProperty(strictOptions, "lastChunkHandling", {
|
||||
get: function() {
|
||||
lastChunkHandlingAccesses += 1;
|
||||
return "strict";
|
||||
}
|
||||
});
|
||||
var arr = Uint8Array.fromBase64("Zg==", strictOptions);
|
||||
assert.compareArray(arr, [102]);
|
||||
assert.sameValue(lastChunkHandlingAccesses, 1);
|
|
@ -0,0 +1,27 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Conversion of base64 strings to Uint8Arrays
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// standard test vectors from https://datatracker.ietf.org/doc/html/rfc4648#section-10
|
||||
var standardBase64Vectors = [
|
||||
["", []],
|
||||
["Zg==", [102]],
|
||||
["Zm8=", [102, 111]],
|
||||
["Zm9v", [102, 111, 111]],
|
||||
["Zm9vYg==", [102, 111, 111, 98]],
|
||||
["Zm9vYmE=", [102, 111, 111, 98, 97]],
|
||||
["Zm9vYmFy", [102, 111, 111, 98, 97, 114]],
|
||||
];
|
||||
|
||||
standardBase64Vectors.forEach(function (pair) {
|
||||
var arr = Uint8Array.fromBase64(pair[0]);
|
||||
assert.sameValue(Object.getPrototypeOf(arr), Uint8Array.prototype, "decoding " + pair[0]);
|
||||
assert.sameValue(arr.length, pair[1].length, "decoding " + pair[0]);
|
||||
assert.sameValue(arr.buffer.byteLength, pair[1].length, "decoding " + pair[0]);
|
||||
assert.compareArray(arr, pair[1], "decoding " + pair[0]);
|
||||
});
|
|
@ -0,0 +1,41 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Uint8Array.fromBase64 throws if its argument is not a string
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64(throwyToString);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
|
||||
var optionAccesses = 0;
|
||||
var touchyOptions = {};
|
||||
Object.defineProperty(touchyOptions, "alphabet", {
|
||||
get: function() {
|
||||
optionAccesses += 1;
|
||||
throw new Test262Error("alphabet accessed");
|
||||
}
|
||||
});
|
||||
Object.defineProperty(touchyOptions, "lastChunkHandling", {
|
||||
get: function() {
|
||||
optionAccesses += 1;
|
||||
throw new Test262Error("lastChunkHandling accessed");
|
||||
}
|
||||
});
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromBase64(throwyToString, touchyOptions);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
assert.sameValue(optionAccesses, 0);
|
|
@ -0,0 +1,22 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.frombase64
|
||||
description: Uint8Array.fromBase64 ignores ASCII whitespace in the input
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var whitespaceKinds = [
|
||||
["Z g==", "space"],
|
||||
["Z\tg==", "tab"],
|
||||
["Z\x0Ag==", "LF"],
|
||||
["Z\x0Cg==", "FF"],
|
||||
["Z\x0Dg==", "CR"],
|
||||
];
|
||||
whitespaceKinds.forEach(function(pair) {
|
||||
var arr = Uint8Array.fromBase64(pair[0]);
|
||||
assert.sameValue(arr.length, 1);
|
||||
assert.sameValue(arr.buffer.byteLength, 1);
|
||||
assert.compareArray(arr, [102], "ascii whitespace: " + pair[1]);
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: >
|
||||
Uint8Array.fromHex has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array, 'fromHex', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: Uint8Array.fromHex ignores its receiver
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var fromHex = Uint8Array.fromHex;
|
||||
var noReceiver = fromHex("aa");
|
||||
assert.sameValue(Object.getPrototypeOf(noReceiver), Uint8Array.prototype);
|
||||
|
||||
class Subclass extends Uint8Array {
|
||||
constructor() {
|
||||
throw new Test262Error("subclass constructor called");
|
||||
}
|
||||
}
|
||||
var fromSubclass = Subclass.fromHex("aa");
|
||||
assert.sameValue(Object.getPrototypeOf(fromSubclass), Uint8Array.prototype);
|
|
@ -0,0 +1,25 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: Uint8Array.fromHex throws a SyntaxError when input has non-hex characters
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var illegal = [
|
||||
'a.a',
|
||||
'aa^',
|
||||
'a a',
|
||||
'a\ta',
|
||||
'a\x0Aa',
|
||||
'a\x0Ca',
|
||||
'a\x0Da',
|
||||
'a\u00A0a', // nbsp
|
||||
'a\u2009a', // thin space
|
||||
'a\u2028a', // line separator
|
||||
];
|
||||
illegal.forEach(function(value) {
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromHex(value)
|
||||
});
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: >
|
||||
Uint8Array.fromHex.length is 1.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.fromHex, 'length', {
|
||||
value: 1,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: >
|
||||
Uint8Array.fromHex.name is "fromHex".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.fromHex, 'name', {
|
||||
value: 'fromHex',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: >
|
||||
Uint8Array.fromHex is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.fromHex), "Uint8Array.fromHex is not a constructor");
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
new Uint8Array.fromHex('');
|
||||
});
|
|
@ -0,0 +1,11 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: Uint8Array.fromHex throws if given an odd number of input hex characters
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
Uint8Array.fromHex('a');
|
||||
});
|
|
@ -0,0 +1,28 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: Conversion of hex strings to Uint8Arrays
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var cases = [
|
||||
["", []],
|
||||
["66", [102]],
|
||||
["666f", [102, 111]],
|
||||
["666F", [102, 111]],
|
||||
["666f6f", [102, 111, 111]],
|
||||
["666F6f", [102, 111, 111]],
|
||||
["666f6f62", [102, 111, 111, 98]],
|
||||
["666f6f6261", [102, 111, 111, 98, 97]],
|
||||
["666f6f626172", [102, 111, 111, 98, 97, 114]],
|
||||
];
|
||||
|
||||
cases.forEach(function (pair) {
|
||||
var arr = Uint8Array.fromHex(pair[0]);
|
||||
assert.sameValue(Object.getPrototypeOf(arr), Uint8Array.prototype, "decoding " + pair[0]);
|
||||
assert.sameValue(arr.length, pair[1].length, "decoding " + pair[0]);
|
||||
assert.sameValue(arr.buffer.byteLength, pair[1].length, "decoding " + pair[0]);
|
||||
assert.compareArray(arr, pair[1], "decoding " + pair[0]);
|
||||
});
|
|
@ -0,0 +1,20 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.fromhex
|
||||
description: Uint8Array.fromHex throws if its argument is not a string
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.fromHex(throwyToString);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
|
@ -0,0 +1,41 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Conversion of base64 strings to Uint8Arrays exercising the alphabet option
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('x+/y');
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [199, 239, 242, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('x+/y', { alphabet: 'base64' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [199, 239, 242, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
target.setFromBase64('x+/y', { alphabet: 'base64url' });
|
||||
});
|
||||
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('x-_y', { alphabet: 'base64url' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [199, 239, 242, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
target.setFromBase64('x-_y');
|
||||
});
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
target.setFromBase64('x-_y', { alphabet: 'base64' });
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: >
|
||||
Uint8Array.prototype.setFromBase64 has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype, 'setFromBase64', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,29 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 throws on detatched buffers
|
||||
includes: [detachArrayBuffer.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
$DETACHBUFFER(target.buffer);
|
||||
assert.throws(TypeError, function() {
|
||||
target.setFromBase64('Zg==');
|
||||
});
|
||||
|
||||
var getterCalls = 0;
|
||||
var targetDetachingOptions = {};
|
||||
Object.defineProperty(targetDetachingOptions, 'alphabet', {
|
||||
get: function() {
|
||||
getterCalls += 1;
|
||||
$DETACHBUFFER(target.buffer);
|
||||
return "base64";
|
||||
}
|
||||
});
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
assert.throws(TypeError, function() {
|
||||
target.setFromBase64('Zg==', targetDetachingOptions);
|
||||
});
|
||||
assert.sameValue(getterCalls, 1);
|
|
@ -0,0 +1,24 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 throws a SyntaxError when input has non-base64, non-ascii-whitespace characters
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var illegal = [
|
||||
'Zm.9v',
|
||||
'Zm9v^',
|
||||
'Zg==&',
|
||||
'Z−==', // U+2212 'Minus Sign'
|
||||
'Z+==', // U+FF0B 'Fullwidth Plus Sign'
|
||||
'Zg\u00A0==', // nbsp
|
||||
'Zg\u2009==', // thin space
|
||||
'Zg\u2028==', // line separator
|
||||
];
|
||||
illegal.forEach(function(value) {
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
target.setFromBase64(value);
|
||||
});
|
||||
});
|
|
@ -0,0 +1,153 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Handling of final chunks in target.setFromBase64
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// padding
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg==');
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg==', { lastChunkHandling: 'loose' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg==', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg==', { lastChunkHandling: 'strict' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
|
||||
// no padding
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg');
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg', { lastChunkHandling: 'loose' });
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [101, 120, 97, 255, 255, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
|
||||
// non-zero padding bits
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh==');
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh==', { lastChunkHandling: 'loose' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh==', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZh==', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
|
||||
// non-zero padding bits, no padding
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh');
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh', { lastChunkHandling: 'loose' });
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 4);
|
||||
assert.compareArray(target, [101, 120, 97, 102, 255, 255]);
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZh', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [101, 120, 97, 255, 255, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZh', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
|
||||
// partial padding
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg=');
|
||||
});
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg=', { lastChunkHandling: 'loose' });
|
||||
});
|
||||
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('ZXhhZg=', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [101, 120, 97, 255, 255, 255]);
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg=', { lastChunkHandling: 'strict' });
|
||||
});
|
||||
|
||||
|
||||
// excess padding
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg===');
|
||||
});
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg===', { lastChunkHandling: 'loose' });
|
||||
});
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg===', { lastChunkHandling: 'stop-before-partial' });
|
||||
});
|
||||
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
target.setFromBase64('ZXhhZg===', { lastChunkHandling: 'strict' });
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: >
|
||||
Uint8Array.prototype.setFromBase64.length is 1.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.setFromBase64, 'length', {
|
||||
value: 1,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: >
|
||||
Uint8Array.prototype.setFromBase64.name is "setFromBase64".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.setFromBase64, 'name', {
|
||||
value: 'setFromBase64',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: >
|
||||
Uint8Array.prototype.setFromBase64 is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.prototype.setFromBase64), "Uint8Array.prototype.setFromBase64 is not a constructor");
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array(10);
|
||||
new target.setFromBase64('');
|
||||
});
|
|
@ -0,0 +1,69 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 triggers effects of the "alphabet" and "lastChunkHandling" getters, but does not perform toString on the results
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
target.setFromBase64("Zg==", { alphabet: Object("base64") });
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
target.setFromBase64("Zg==", { lastChunkHandling: Object("strict") });
|
||||
});
|
||||
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
target.setFromBase64("Zg==", { alphabet: throwyToString });
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
target.setFromBase64("Zg==", { lastChunkHandling: throwyToString });
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
|
||||
var alphabetAccesses = 0;
|
||||
var base64UrlOptions = {};
|
||||
Object.defineProperty(base64UrlOptions, "alphabet", {
|
||||
get: function() {
|
||||
alphabetAccesses += 1;
|
||||
return "base64url";
|
||||
}
|
||||
});
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64("x-_y", base64UrlOptions);
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [199, 239, 242, 255]);
|
||||
assert.sameValue(alphabetAccesses, 1);
|
||||
|
||||
var lastChunkHandlingAccesses = 0;
|
||||
var strictOptions = {};
|
||||
Object.defineProperty(strictOptions, "lastChunkHandling", {
|
||||
get: function() {
|
||||
lastChunkHandlingAccesses += 1;
|
||||
return "strict";
|
||||
}
|
||||
});
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64("Zg==", strictOptions);
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 1);
|
||||
assert.compareArray(target, [102, 255, 255, 255]);
|
||||
assert.sameValue(lastChunkHandlingAccesses, 1);
|
|
@ -0,0 +1,30 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Conversion of base64 strings to Uint8Arrays
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// standard test vectors from https://datatracker.ietf.org/doc/html/rfc4648#section-10
|
||||
var standardBase64Vectors = [
|
||||
["", []],
|
||||
["Zg==", [102]],
|
||||
["Zm8=", [102, 111]],
|
||||
["Zm9v", [102, 111, 111]],
|
||||
["Zm9vYg==", [102, 111, 111, 98]],
|
||||
["Zm9vYmE=", [102, 111, 111, 98, 97]],
|
||||
["Zm9vYmFy", [102, 111, 111, 98, 97, 114]],
|
||||
];
|
||||
|
||||
standardBase64Vectors.forEach(function (pair) {
|
||||
var allFF = [255, 255, 255, 255, 255, 255, 255, 255];
|
||||
var target = new Uint8Array(allFF);
|
||||
var result = target.setFromBase64(pair[0]);
|
||||
assert.sameValue(result.read, pair[0].length);
|
||||
assert.sameValue(result.written, pair[1].length);
|
||||
|
||||
var expected = pair[1].concat(allFF.slice(pair[1].length))
|
||||
assert.compareArray(target, expected, "decoding " + pair[0]);
|
||||
});
|
|
@ -0,0 +1,43 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 throws if its first argument is not a string
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array(10);
|
||||
target.setFromBase64(throwyToString);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
|
||||
var optionAccesses = 0;
|
||||
var touchyOptions = {};
|
||||
Object.defineProperty(touchyOptions, "alphabet", {
|
||||
get: function() {
|
||||
optionAccesses += 1;
|
||||
throw new Test262Error("alphabet accessed");
|
||||
}
|
||||
});
|
||||
Object.defineProperty(touchyOptions, "lastChunkHandling", {
|
||||
get: function() {
|
||||
optionAccesses += 1;
|
||||
throw new Test262Error("lastChunkHandling accessed");
|
||||
}
|
||||
});
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array(10);
|
||||
target.setFromBase64(throwyToString, touchyOptions);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
assert.sameValue(optionAccesses, 0);
|
|
@ -0,0 +1,17 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 takes into account the offset of the target Uint8Array
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var base = new Uint8Array([255, 255, 255, 255, 255, 255, 255]);
|
||||
var subarray = base.subarray(2, 5);
|
||||
|
||||
var result = subarray.setFromBase64('Zm9vYmFy');
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(subarray, [102, 111, 111]);
|
||||
assert.compareArray(base, [255, 255, 102, 111, 111, 255, 255]);
|
|
@ -0,0 +1,64 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 behavior when target buffer is small
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// buffer too small
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmFy');
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [102, 111, 111, 255, 255]);
|
||||
|
||||
// buffer too small, padded
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmE=');
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [102, 111, 111, 255]);
|
||||
|
||||
// buffer exact
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmFy');
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 6);
|
||||
assert.compareArray(target, [102, 111, 111, 98, 97, 114]);
|
||||
|
||||
// buffer exact, padded
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmE=');
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 5);
|
||||
assert.compareArray(target, [102, 111, 111, 98, 97]);
|
||||
|
||||
// buffer exact, not padded
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmE');
|
||||
assert.sameValue(result.read, 7);
|
||||
assert.sameValue(result.written, 5);
|
||||
assert.compareArray(target, [102, 111, 111, 98, 97]);
|
||||
|
||||
// buffer exact, padded, stop-before-partial
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmE=', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 5);
|
||||
assert.compareArray(target, [102, 111, 111, 98, 97]);
|
||||
|
||||
// buffer exact, not padded, stop-before-partial
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmE', { lastChunkHandling: 'stop-before-partial' });
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [102, 111, 111, 255, 255]);
|
||||
|
||||
// buffer too large
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255, 255, 255]);
|
||||
var result = target.setFromBase64('Zm9vYmFy');
|
||||
assert.sameValue(result.read, 8);
|
||||
assert.sameValue(result.written, 6);
|
||||
assert.compareArray(target, [102, 111, 111, 98, 97, 114, 255]);
|
|
@ -0,0 +1,23 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfrombase64
|
||||
description: Uint8Array.prototype.setFromBase64 ignores ASCII whitespace in the input
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var whitespaceKinds = [
|
||||
["Z g==", "space"],
|
||||
["Z\tg==", "tab"],
|
||||
["Z\x0Ag==", "LF"],
|
||||
["Z\x0Cg==", "FF"],
|
||||
["Z\x0Dg==", "CR"],
|
||||
];
|
||||
whitespaceKinds.forEach(function(pair) {
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
var result = target.setFromBase64(pair[0]);
|
||||
assert.sameValue(result.read, 5);
|
||||
assert.sameValue(result.written, 1);
|
||||
assert.compareArray(target, [102, 255, 255], "ascii whitespace: " + pair[1]);
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: >
|
||||
Uint8Array.prototype.setFromHex has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype, 'setFromHex', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,14 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Uint8Array.prototype.setFromHex throws on detatched buffers
|
||||
includes: [detachArrayBuffer.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
$DETACHBUFFER(target.buffer);
|
||||
assert.throws(TypeError, function() {
|
||||
target.setFromHex('aa');
|
||||
});
|
|
@ -0,0 +1,26 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Uint8Array.prototype.setFromHex throws a SyntaxError when input has non-hex characters
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var illegal = [
|
||||
'a.a',
|
||||
'aa^',
|
||||
'a a',
|
||||
'a\ta',
|
||||
'a\x0Aa',
|
||||
'a\x0Ca',
|
||||
'a\x0Da',
|
||||
'a\u00A0a', // nbsp
|
||||
'a\u2009a', // thin space
|
||||
'a\u2028a', // line separator
|
||||
];
|
||||
illegal.forEach(function(value) {
|
||||
assert.throws(SyntaxError, function() {
|
||||
var target = new Uint8Array([255, 255, 255, 255, 255]);
|
||||
target.setFromHex(value);
|
||||
});
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: >
|
||||
Uint8Array.prototype.setFromHex.length is 1.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.setFromHex, 'length', {
|
||||
value: 1,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: >
|
||||
Uint8Array.prototype.setFromHex.name is "setFromHex".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.setFromHex, 'name', {
|
||||
value: 'setFromHex',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: >
|
||||
Uint8Array.prototype.setFromHex is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.prototype.setFromHex), "target.setFromHex is not a constructor");
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array(10);
|
||||
new target.setFromHex('');
|
||||
});
|
|
@ -0,0 +1,31 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Conversion of hex strings to Uint8Arrays
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var cases = [
|
||||
["", []],
|
||||
["66", [102]],
|
||||
["666f", [102, 111]],
|
||||
["666F", [102, 111]],
|
||||
["666f6f", [102, 111, 111]],
|
||||
["666F6f", [102, 111, 111]],
|
||||
["666f6f62", [102, 111, 111, 98]],
|
||||
["666f6f6261", [102, 111, 111, 98, 97]],
|
||||
["666f6f626172", [102, 111, 111, 98, 97, 114]],
|
||||
];
|
||||
|
||||
cases.forEach(function (pair) {
|
||||
var allFF = [255, 255, 255, 255, 255, 255, 255, 255];
|
||||
var target = new Uint8Array(allFF);
|
||||
var result = target.setFromHex(pair[0]);
|
||||
assert.sameValue(result.read, pair[0].length);
|
||||
assert.sameValue(result.written, pair[1].length);
|
||||
|
||||
var expected = pair[1].concat(allFF.slice(pair[1].length))
|
||||
assert.compareArray(target, expected, "decoding " + pair[0]);
|
||||
});
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Uint8Array.prototype.setFromHex throws if its first argument is not a string
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called");
|
||||
}
|
||||
};
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
var target = new Uint8Array(10);
|
||||
target.setFromHex(throwyToString);
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
|
@ -0,0 +1,17 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Uint8Array.prototype.setFromHex takes into account the offset of the target Uint8Array
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var base = new Uint8Array([255, 255, 255, 255, 255, 255, 255]);
|
||||
var subarray = base.subarray(2, 5);
|
||||
|
||||
var result = subarray.setFromHex('aabbcc');
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(subarray, [170, 187, 204]);
|
||||
assert.compareArray(base, [255, 255, 170, 187, 204, 255, 255]);
|
|
@ -0,0 +1,29 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.setfromhex
|
||||
description: Uint8Array.prototype.setFromHex behavior when target buffer is small
|
||||
includes: [compareArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// buffer too small
|
||||
var target = new Uint8Array([255, 255]);
|
||||
var result = target.setFromHex('aabbcc');
|
||||
assert.sameValue(result.read, 4);
|
||||
assert.sameValue(result.written, 2);
|
||||
assert.compareArray(target, [170, 187]);
|
||||
|
||||
// buffer exact
|
||||
var target = new Uint8Array([255, 255, 255]);
|
||||
var result = target.setFromHex('aabbcc');
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [170, 187, 204]);
|
||||
|
||||
// buffer too large
|
||||
var target = new Uint8Array([255, 255, 255, 255]);
|
||||
var result = target.setFromHex('aabbcc');
|
||||
assert.sameValue(result.read, 6);
|
||||
assert.sameValue(result.written, 3);
|
||||
assert.compareArray(target, [170, 187, 204, 255]);
|
|
@ -0,0 +1,17 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: Conversion of Uint8Arrays to base64 strings exercising the alphabet option
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.sameValue((new Uint8Array([199, 239, 242])).toBase64(), "x+/y");
|
||||
|
||||
assert.sameValue((new Uint8Array([199, 239, 242])).toBase64({ alphabet: 'base64' }), "x+/y");
|
||||
|
||||
assert.sameValue((new Uint8Array([199, 239, 242])).toBase64({ alphabet: 'base64url' }), "x-_y");
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
(new Uint8Array([199, 239, 242])).toBase64({ alphabet: 'other' });
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: >
|
||||
Uint8Array.prototype.toBase64 has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype, 'toBase64', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,39 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: Uint8Array.prototype.toBase64 checks for detachedness after side-effects are finished
|
||||
includes: [detachArrayBuffer.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var array = new Uint8Array(2);
|
||||
var getterCalls = 0;
|
||||
var receiverDetachingOptions = {};
|
||||
Object.defineProperty(receiverDetachingOptions, "alphabet", {
|
||||
get: function() {
|
||||
getterCalls += 1;
|
||||
$DETACHBUFFER(array.buffer);
|
||||
return "base64";
|
||||
}
|
||||
});
|
||||
assert.throws(TypeError, function() {
|
||||
array.toBase64(receiverDetachingOptions);
|
||||
});
|
||||
assert.sameValue(getterCalls, 1);
|
||||
|
||||
|
||||
var detached = new Uint8Array(2);
|
||||
$DETACHBUFFER(detached.buffer);
|
||||
var getterCalls = 0;
|
||||
var sideEffectingOptions = {};
|
||||
Object.defineProperty(sideEffectingOptions, "alphabet", {
|
||||
get: function() {
|
||||
getterCalls += 1;
|
||||
return "base64";
|
||||
}
|
||||
});
|
||||
assert.throws(TypeError, function() {
|
||||
detached.toBase64(sideEffectingOptions);
|
||||
});
|
||||
assert.sameValue(getterCalls, 1);
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: >
|
||||
Uint8Array.prototype.toBase64.length is 0.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.toBase64, 'length', {
|
||||
value: 0,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: >
|
||||
Uint8Array.prototype.toBase64.name is "toBase64".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.toBase64, 'name', {
|
||||
value: 'toBase64',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: >
|
||||
Uint8Array.prototype.toBase64 is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.prototype.toBase64), "Uint8Array.prototype.toBase64 is not a constructor");
|
||||
|
||||
var uint8Array = new Uint8Array(8);
|
||||
assert.throws(TypeError, function() {
|
||||
new uint8Array.toBase64();
|
||||
});
|
|
@ -0,0 +1,48 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: Uint8Array.prototype.toBase64 triggers effects of the "alphabet" getter, but does not perform toString on the result
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
(new Uint8Array(2)).toBase64({ alphabet: Object("base64") });
|
||||
});
|
||||
|
||||
|
||||
var toStringCalls = 0;
|
||||
var throwyToString = {
|
||||
toString: function() {
|
||||
toStringCalls += 1;
|
||||
throw new Test262Error("toString called on alphabet value");
|
||||
}
|
||||
};
|
||||
assert.throws(TypeError, function() {
|
||||
(new Uint8Array(2)).toBase64({ alphabet: throwyToString });
|
||||
});
|
||||
assert.sameValue(toStringCalls, 0);
|
||||
|
||||
var alphabetAccesses = 0;
|
||||
var base64UrlOptions = {};
|
||||
Object.defineProperty(base64UrlOptions, "alphabet", {
|
||||
get: function() {
|
||||
alphabetAccesses += 1;
|
||||
return "base64url";
|
||||
}
|
||||
});
|
||||
assert.sameValue((new Uint8Array([199, 239, 242])).toBase64(base64UrlOptions), "x-_y");
|
||||
assert.sameValue(alphabetAccesses, 1);
|
||||
|
||||
// side-effects from the getter on the receiver are reflected in the result
|
||||
var array = new Uint8Array([0]);
|
||||
var receiverMutatingOptions = {};
|
||||
Object.defineProperty(receiverMutatingOptions, "alphabet", {
|
||||
get: function() {
|
||||
array[0] = 255;
|
||||
return "base64";
|
||||
}
|
||||
});
|
||||
var result = array.toBase64(receiverMutatingOptions);
|
||||
assert.sameValue(result, "/w==");
|
||||
assert.sameValue(array[0], 255);
|
|
@ -0,0 +1,33 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: Uint8Array.prototype.toBase64 throws if the receiver is not a Uint8Array
|
||||
includes: [testTypedArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toBase64 = Uint8Array.prototype.toBase64;
|
||||
|
||||
var options = {};
|
||||
Object.defineProperty(options, "alphabet", {
|
||||
get: function() {
|
||||
throw new Test262Error("options.alphabet accessed despite incompatible receiver");
|
||||
}
|
||||
});
|
||||
|
||||
testWithTypedArrayConstructors(function(TA) {
|
||||
if (TA === Uint8Array) return;
|
||||
var sample = new TA(2);
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.prototype.toBase64.call(sample, options);
|
||||
});
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.prototype.toBase64.call([], options);
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
toBase64(options);
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tobase64
|
||||
description: Conversion of Uint8Arrays to base64 strings
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
// standard test vectors from https://datatracker.ietf.org/doc/html/rfc4648#section-10
|
||||
assert.sameValue((new Uint8Array([])).toBase64(), "");
|
||||
assert.sameValue((new Uint8Array([102])).toBase64(), "Zg==");
|
||||
assert.sameValue((new Uint8Array([102, 111])).toBase64(), "Zm8=");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111])).toBase64(), "Zm9v");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98])).toBase64(), "Zm9vYg==");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98, 97])).toBase64(), "Zm9vYmE=");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98, 97, 114])).toBase64(), "Zm9vYmFy");
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: >
|
||||
Uint8Array.prototype.toHex has default data property attributes.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype, 'toHex', {
|
||||
enumerable: false,
|
||||
writable: true,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: Uint8Array.prototype.toHex throws if called on a detached buffer
|
||||
includes: [detachArrayBuffer.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var array = new Uint8Array(2);
|
||||
$DETACHBUFFER(array.buffer);
|
||||
assert.throws(TypeError, function() {
|
||||
array.toHex();
|
||||
});
|
||||
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: >
|
||||
Uint8Array.prototype.toHex.length is 0.
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.toHex, 'length', {
|
||||
value: 0,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: >
|
||||
Uint8Array.prototype.toHex.name is "toHex".
|
||||
includes: [propertyHelper.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
verifyProperty(Uint8Array.prototype.toHex, 'name', {
|
||||
value: 'toHex',
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
configurable: true
|
||||
});
|
|
@ -0,0 +1,16 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: >
|
||||
Uint8Array.prototype.toHex is not a constructor function.
|
||||
includes: [isConstructor.js]
|
||||
features: [uint8array-base64, TypedArray, Reflect.construct]
|
||||
---*/
|
||||
|
||||
assert(!isConstructor(Uint8Array.prototype.toHex), "Uint8Array.prototype.toHex is not a constructor");
|
||||
|
||||
var uint8Array = new Uint8Array(8);
|
||||
assert.throws(TypeError, function() {
|
||||
new uint8Array.toHex();
|
||||
});
|
|
@ -0,0 +1,26 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: Uint8Array.prototype.toHex throws if the receiver is not a Uint8Array
|
||||
includes: [testTypedArray.js]
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
var toHex = Uint8Array.prototype.toHex;
|
||||
|
||||
testWithTypedArrayConstructors(function(TA) {
|
||||
if (TA === Uint8Array) return;
|
||||
var sample = new TA(2);
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.prototype.toHex.call(sample);
|
||||
});
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
Uint8Array.prototype.toHex.call([]);
|
||||
});
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
toHex();
|
||||
});
|
|
@ -0,0 +1,15 @@
|
|||
// Copyright (C) 2024 Kevin Gibbons. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
esid: sec-uint8array.prototype.tohex
|
||||
description: Conversion of Uint8Arrays to hex strings
|
||||
features: [uint8array-base64, TypedArray]
|
||||
---*/
|
||||
|
||||
assert.sameValue((new Uint8Array([])).toHex(), "");
|
||||
assert.sameValue((new Uint8Array([102])).toHex(), "66");
|
||||
assert.sameValue((new Uint8Array([102, 111])).toHex(), "666f");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111])).toHex(), "666f6f");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98])).toHex(), "666f6f62");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98, 97])).toHex(), "666f6f6261");
|
||||
assert.sameValue((new Uint8Array([102, 111, 111, 98, 97, 114])).toHex(), "666f6f626172");
|
Loading…
Reference in New Issue