test262/test/built-ins/Uint8Array/fromBase64/last-chunk-handling.js

65 lines
2.9 KiB
JavaScript
Raw Normal View History

2024-01-22 02:09:11 +01:00
// 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]
2024-01-22 02:09:11 +01:00
---*/
// 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' });
});
2024-03-12 06:51:35 +01:00
// partial padding
2024-01-22 02:09:11 +01:00
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' });
});
2024-03-12 06:51:35 +01:00
// 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' });
});