mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:37:43 +00:00
LibJS: Implement missing checks for SharedArrayBuffer values
This commit is contained in:
parent
299c86db20
commit
526a74f2f1
6 changed files with 46 additions and 6 deletions
|
@ -201,7 +201,7 @@ size_t array_buffer_byte_length(ArrayBuffer const& array_buffer, ArrayBuffer::Or
|
||||||
ThrowCompletionOr<void> detach_array_buffer(VM& vm, ArrayBuffer& array_buffer, Optional<Value> key)
|
ThrowCompletionOr<void> detach_array_buffer(VM& vm, ArrayBuffer& array_buffer, Optional<Value> key)
|
||||||
{
|
{
|
||||||
// 1. Assert: IsSharedArrayBuffer(arrayBuffer) is false.
|
// 1. Assert: IsSharedArrayBuffer(arrayBuffer) is false.
|
||||||
// FIXME: Check for shared buffer
|
VERIFY(!array_buffer.is_shared_array_buffer());
|
||||||
|
|
||||||
// 2. If key is not present, set key to undefined.
|
// 2. If key is not present, set key to undefined.
|
||||||
if (!key.has_value())
|
if (!key.has_value())
|
||||||
|
|
|
@ -174,7 +174,8 @@ JS_DEFINE_NATIVE_FUNCTION(ArrayBufferPrototype::slice)
|
||||||
auto array_buffer_object = TRY(typed_this_value(vm));
|
auto array_buffer_object = TRY(typed_this_value(vm));
|
||||||
|
|
||||||
// 3. If IsSharedArrayBuffer(O) is true, throw a TypeError exception.
|
// 3. If IsSharedArrayBuffer(O) is true, throw a TypeError exception.
|
||||||
// FIXME: Check for shared buffer
|
if (array_buffer_object->is_shared_array_buffer())
|
||||||
|
return vm.throw_completion<TypeError>(ErrorType::SharedArrayBuffer);
|
||||||
|
|
||||||
// 4. If IsDetachedBuffer(O) is true, throw a TypeError exception.
|
// 4. If IsDetachedBuffer(O) is true, throw a TypeError exception.
|
||||||
if (array_buffer_object->is_detached())
|
if (array_buffer_object->is_detached())
|
||||||
|
@ -226,7 +227,8 @@ JS_DEFINE_NATIVE_FUNCTION(ArrayBufferPrototype::slice)
|
||||||
auto* new_array_buffer_object = static_cast<ArrayBuffer*>(new_array_buffer.ptr());
|
auto* new_array_buffer_object = static_cast<ArrayBuffer*>(new_array_buffer.ptr());
|
||||||
|
|
||||||
// 18. If IsSharedArrayBuffer(new) is true, throw a TypeError exception.
|
// 18. If IsSharedArrayBuffer(new) is true, throw a TypeError exception.
|
||||||
// FIXME: Check for shared buffer
|
if (new_array_buffer_object->is_shared_array_buffer())
|
||||||
|
return vm.throw_completion<TypeError>(ErrorType::SharedArrayBuffer);
|
||||||
|
|
||||||
// 19. If IsDetachedBuffer(new) is true, throw a TypeError exception.
|
// 19. If IsDetachedBuffer(new) is true, throw a TypeError exception.
|
||||||
if (new_array_buffer_object->is_detached())
|
if (new_array_buffer_object->is_detached())
|
||||||
|
|
|
@ -40,7 +40,8 @@ JS_DEFINE_NATIVE_FUNCTION(SharedArrayBufferPrototype::byte_length_getter)
|
||||||
auto array_buffer_object = TRY(typed_this_value(vm));
|
auto array_buffer_object = TRY(typed_this_value(vm));
|
||||||
|
|
||||||
// 3. If IsSharedArrayBuffer(O) is false, throw a TypeError exception.
|
// 3. If IsSharedArrayBuffer(O) is false, throw a TypeError exception.
|
||||||
// FIXME: Check for shared buffer
|
if (!array_buffer_object->is_shared_array_buffer())
|
||||||
|
return vm.throw_completion<TypeError>(ErrorType::NotASharedArrayBuffer);
|
||||||
|
|
||||||
// 4. Let length be O.[[ArrayBufferByteLength]].
|
// 4. Let length be O.[[ArrayBufferByteLength]].
|
||||||
// 5. Return 𝔽(length).
|
// 5. Return 𝔽(length).
|
||||||
|
@ -60,7 +61,8 @@ JS_DEFINE_NATIVE_FUNCTION(SharedArrayBufferPrototype::slice)
|
||||||
auto array_buffer_object = TRY(typed_this_value(vm));
|
auto array_buffer_object = TRY(typed_this_value(vm));
|
||||||
|
|
||||||
// 3. If IsSharedArrayBuffer(O) is false, throw a TypeError exception.
|
// 3. If IsSharedArrayBuffer(O) is false, throw a TypeError exception.
|
||||||
// FIXME: Check for shared buffer
|
if (!array_buffer_object->is_shared_array_buffer())
|
||||||
|
return vm.throw_completion<TypeError>(ErrorType::NotASharedArrayBuffer);
|
||||||
|
|
||||||
// 4. Let len be O.[[ArrayBufferByteLength]].
|
// 4. Let len be O.[[ArrayBufferByteLength]].
|
||||||
auto length = array_buffer_object->byte_length();
|
auto length = array_buffer_object->byte_length();
|
||||||
|
@ -108,7 +110,8 @@ JS_DEFINE_NATIVE_FUNCTION(SharedArrayBufferPrototype::slice)
|
||||||
auto* new_array_buffer_object = static_cast<ArrayBuffer*>(new_array_buffer.ptr());
|
auto* new_array_buffer_object = static_cast<ArrayBuffer*>(new_array_buffer.ptr());
|
||||||
|
|
||||||
// 17. If IsSharedArrayBuffer(new) is true, throw a TypeError exception.
|
// 17. If IsSharedArrayBuffer(new) is true, throw a TypeError exception.
|
||||||
// FIXME: Check for shared buffer
|
if (!new_array_buffer_object->is_shared_array_buffer())
|
||||||
|
return vm.throw_completion<TypeError>(ErrorType::NotASharedArrayBuffer);
|
||||||
|
|
||||||
// 18. If new.[[ArrayBufferData]] is O.[[ArrayBufferData]], throw a TypeError exception.
|
// 18. If new.[[ArrayBufferData]] is O.[[ArrayBufferData]], throw a TypeError exception.
|
||||||
if (new_array_buffer == array_buffer_object)
|
if (new_array_buffer == array_buffer_object)
|
||||||
|
|
|
@ -1,3 +1,11 @@
|
||||||
|
describe("errors", () => {
|
||||||
|
test("called on SharedArrayBuffer object", () => {
|
||||||
|
expect(() => {
|
||||||
|
ArrayBuffer.prototype.slice.call(new SharedArrayBuffer());
|
||||||
|
}).toThrowWithMessage(TypeError, "The array buffer object cannot be a SharedArrayBuffer");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
test("single parameter", () => {
|
test("single parameter", () => {
|
||||||
const buffer = new ArrayBuffer(16);
|
const buffer = new ArrayBuffer(16);
|
||||||
const fullView = new Int32Array(buffer);
|
const fullView = new Int32Array(buffer);
|
||||||
|
|
|
@ -1,3 +1,18 @@
|
||||||
|
describe("errors", () => {
|
||||||
|
test("called on non-SharedArrayBuffer object", () => {
|
||||||
|
expect(() => {
|
||||||
|
SharedArrayBuffer.prototype.byteLength;
|
||||||
|
}).toThrowWithMessage(TypeError, "Not an object of type SharedArrayBuffer");
|
||||||
|
|
||||||
|
let byteLength = Object.getOwnPropertyDescriptor(SharedArrayBuffer.prototype, "byteLength");
|
||||||
|
let getter = byteLength.get;
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
getter.call(new ArrayBuffer());
|
||||||
|
}).toThrowWithMessage(TypeError, "The array buffer object must be a SharedArrayBuffer");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
test("basic functionality", () => {
|
test("basic functionality", () => {
|
||||||
expect(new SharedArrayBuffer().byteLength).toBe(0);
|
expect(new SharedArrayBuffer().byteLength).toBe(0);
|
||||||
expect(new SharedArrayBuffer(1).byteLength).toBe(1);
|
expect(new SharedArrayBuffer(1).byteLength).toBe(1);
|
||||||
|
|
|
@ -1,3 +1,15 @@
|
||||||
|
describe("errors", () => {
|
||||||
|
test("called on non-SharedArrayBuffer object", () => {
|
||||||
|
expect(() => {
|
||||||
|
SharedArrayBuffer.prototype.slice(Symbol.hasInstance);
|
||||||
|
}).toThrowWithMessage(TypeError, "Not an object of type SharedArrayBuffer");
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
SharedArrayBuffer.prototype.slice.call(new ArrayBuffer());
|
||||||
|
}).toThrowWithMessage(TypeError, "The array buffer object must be a SharedArrayBuffer");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
test("single parameter", () => {
|
test("single parameter", () => {
|
||||||
const buffer = new SharedArrayBuffer(16);
|
const buffer = new SharedArrayBuffer(16);
|
||||||
const fullView = new Int32Array(buffer);
|
const fullView = new Int32Array(buffer);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue