mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
589ac5004c
PR-URL: https://github.com/nodejs/node/pull/49730 Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com> Reviewed-By: Zeyu "Alex" Yang <himself65@outlook.com> Reviewed-By: Matthew Aitken <maitken033380023@gmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com> Reviewed-By: Stephen Belanger <admin@stephenbelanger.com>
55 lines
1.3 KiB
JavaScript
55 lines
1.3 KiB
JavaScript
// Flags: --no-warnings
|
|
'use strict';
|
|
|
|
const common = require('../common');
|
|
|
|
// Because registering a Blob URL requires generating a random
|
|
// UUID, it can only be done if crypto support is enabled.
|
|
if (!common.hasCrypto)
|
|
common.skip('missing crypto');
|
|
|
|
const {
|
|
URL,
|
|
} = require('url');
|
|
|
|
const {
|
|
Blob,
|
|
resolveObjectURL,
|
|
} = require('buffer');
|
|
|
|
const assert = require('assert');
|
|
|
|
(async () => {
|
|
const blob = new Blob(['hello']);
|
|
const id = URL.createObjectURL(blob);
|
|
assert.strictEqual(typeof id, 'string');
|
|
const otherBlob = resolveObjectURL(id);
|
|
assert.ok(otherBlob instanceof Blob);
|
|
assert.strictEqual(otherBlob.constructor, Blob);
|
|
assert.strictEqual(otherBlob.size, 5);
|
|
assert.strictEqual(
|
|
Buffer.from(await otherBlob.arrayBuffer()).toString(),
|
|
'hello');
|
|
URL.revokeObjectURL(id);
|
|
|
|
// should do nothing
|
|
URL.revokeObjectURL(id);
|
|
|
|
assert.strictEqual(resolveObjectURL(id), undefined);
|
|
|
|
// Leaving a Blob registered should not cause an assert
|
|
// when Node.js exists
|
|
URL.createObjectURL(new Blob());
|
|
|
|
})().then(common.mustCall());
|
|
|
|
['not a url', undefined, 1, 'blob:nodedata:1:wrong', {}].forEach((i) => {
|
|
assert.strictEqual(resolveObjectURL(i), undefined);
|
|
});
|
|
|
|
[undefined, 1, '', false, {}].forEach((i) => {
|
|
assert.throws(() => URL.createObjectURL(i), {
|
|
code: 'ERR_INVALID_ARG_TYPE',
|
|
});
|
|
});
|