mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 10:57:35 +00:00
LibJS: Fix Object.prototype.valueOf() behavior
No idea why it was implemented like this, but a value_of() call on the coerced object is not part of the spec. Also added some tests.
This commit is contained in:
parent
1253a3d038
commit
33eea1f722
2 changed files with 9 additions and 4 deletions
|
@ -106,10 +106,7 @@ JS_DEFINE_NATIVE_FUNCTION(ObjectPrototype::to_locale_string)
|
||||||
// 20.1.3.7 Object.prototype.valueOf ( ), https://tc39.es/ecma262/#sec-object.prototype.valueof
|
// 20.1.3.7 Object.prototype.valueOf ( ), https://tc39.es/ecma262/#sec-object.prototype.valueof
|
||||||
JS_DEFINE_NATIVE_FUNCTION(ObjectPrototype::value_of)
|
JS_DEFINE_NATIVE_FUNCTION(ObjectPrototype::value_of)
|
||||||
{
|
{
|
||||||
auto* this_object = vm.this_value(global_object).to_object(global_object);
|
return vm.this_value(global_object).to_object(global_object);
|
||||||
if (!this_object)
|
|
||||||
return {};
|
|
||||||
return this_object->value_of();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 20.1.3.4 Object.prototype.propertyIsEnumerable ( V ), https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable
|
// 20.1.3.4 Object.prototype.propertyIsEnumerable ( V ), https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
test("basic functionality", () => {
|
||||||
|
expect(Object.prototype.valueOf).toHaveLength(0);
|
||||||
|
|
||||||
|
const o = {};
|
||||||
|
expect(o.valueOf()).toBe(o);
|
||||||
|
|
||||||
|
expect(Object.prototype.valueOf.call(42)).toEqual(new Number(42));
|
||||||
|
});
|
Loading…
Add table
Add a link
Reference in a new issue