mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 09:48:11 +00:00
LibJS: Throw TypeError on write to non-writable property in strict mode
This commit is contained in:
parent
31534055e4
commit
2a8f4f097c
3 changed files with 15 additions and 0 deletions
|
@ -23,6 +23,7 @@
|
||||||
M(Convert, "Cannot convert {} to {}") \
|
M(Convert, "Cannot convert {} to {}") \
|
||||||
M(ConvertUndefinedToObject, "Cannot convert undefined to object") \
|
M(ConvertUndefinedToObject, "Cannot convert undefined to object") \
|
||||||
M(DescChangeNonConfigurable, "Cannot change attributes of non-configurable property '{}'") \
|
M(DescChangeNonConfigurable, "Cannot change attributes of non-configurable property '{}'") \
|
||||||
|
M(DescWriteNonWritable, "Cannot write to non-writable property '{}'") \
|
||||||
M(DivisionByZero, "Division by zero") \
|
M(DivisionByZero, "Division by zero") \
|
||||||
M(FunctionArgsNotObject, "Argument array must be an object") \
|
M(FunctionArgsNotObject, "Argument array must be an object") \
|
||||||
M(GetCapabilitiesExecutorCalledMultipleTimes, "GetCapabilitiesExecutor was called multiple times") \
|
M(GetCapabilitiesExecutorCalledMultipleTimes, "GetCapabilitiesExecutor was called multiple times") \
|
||||||
|
|
|
@ -637,6 +637,8 @@ bool Object::put_own_property(const StringOrSymbol& property_name, Value value,
|
||||||
auto value_here = m_storage[metadata.value().offset];
|
auto value_here = m_storage[metadata.value().offset];
|
||||||
if (!new_property && mode == PutOwnPropertyMode::Put && !value_here.is_accessor() && !metadata.value().attributes.is_writable()) {
|
if (!new_property && mode == PutOwnPropertyMode::Put && !value_here.is_accessor() && !metadata.value().attributes.is_writable()) {
|
||||||
dbgln_if(OBJECT_DEBUG, "Disallow write to non-writable property");
|
dbgln_if(OBJECT_DEBUG, "Disallow write to non-writable property");
|
||||||
|
if (throw_exceptions && vm().in_strict_mode())
|
||||||
|
vm().throw_exception<TypeError>(global_object(), ErrorType::DescWriteNonWritable, property_name.to_display_string());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
12
Userland/Libraries/LibJS/Tests/non-writable-assignment.js
Normal file
12
Userland/Libraries/LibJS/Tests/non-writable-assignment.js
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
test("normal mode", () => {
|
||||||
|
expect(() => {
|
||||||
|
NaN = 5; // NaN is a non-writable global variable
|
||||||
|
}).not.toThrow();
|
||||||
|
});
|
||||||
|
|
||||||
|
test("strict mode", () => {
|
||||||
|
expect(() => {
|
||||||
|
"use strict";
|
||||||
|
NaN = 5; // NaN is a non-writable global variable
|
||||||
|
}).toThrowWithMessage(TypeError, "Cannot write to non-writable property 'NaN'");
|
||||||
|
});
|
Loading…
Add table
Add a link
Reference in a new issue