LibJS: Fix Object::delete_property() with numeric string property

- We have to check if the property name is a string before calling
  as_string() on it
- We can't as_number() the same property name but have to use the parsed
  index number

Fixes #3950.
This commit is contained in:
Linus Groh 2020-11-04 23:31:47 +00:00 committed by Andreas Kling
parent 8d96f428ef
commit 0bb66890c8
Notes: sideshowbarker 2024-07-19 01:32:50 +09:00
2 changed files with 9 additions and 3 deletions

View file

@ -46,6 +46,9 @@ test("deleting array indices", () => {
expect(a.hasOwnProperty(1)).toBeFalse();
expect(a.hasOwnProperty(2)).toBeFalse();
expect(Object.getOwnPropertyNames(a)).toHaveLength(1);
expect(delete a["42"]).toBeTrue();
expect(Object.getOwnPropertyNames(a)).toHaveLength(1);
});
test("deleting non-configurable property", () => {