node/test/parallel/test-blob-createobjecturl.js
Xuguang Mei 3d4f3ca5eb
src: skip revoke_data_object if uuid is not found
Fix: https://github.com/nodejs/node/issues/42206

PR-URL: https://github.com/nodejs/node/pull/42212
Fixes: https://github.com/nodejs/node/issues/42206
Reviewed-By: Juan José Arboleda <soyjuanarbol@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
Reviewed-By: Mestery <mestery@protonmail.com>
Reviewed-By: Darshan Sen <raisinten@gmail.com>
2022-03-06 09:24:42 +00:00

53 lines
1.2 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.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',
});
});