node/test/parallel/test-blob-createobjecturl.js
Vinícius Lourenço 589ac5004c lib: faster internal createBlob
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>
2023-10-04 01:05:41 +00:00

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',
});
});