Commit b151cd2f authored by Z Duong Nguyen-Huu's avatar Z Duong Nguyen-Huu Committed by Commit Bot

Fix array.includes undefined for sealed/frozen object

For slow-path of array.includes, it should be able to handle if arguments is undefined for sealed/frozen object

Bug: chromium:951780
Change-Id: I42dcf1e23ab07bfcd87e7a5d27b52e66b2d1d2ae
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1565031Reviewed-by: 's avatarSimon Zünd <szuend@chromium.org>
Reviewed-by: 's avatarToon Verwaest <verwaest@chromium.org>
Commit-Queue: Z Nguyen-Huu <duongn@microsoft.com>
Cr-Commit-Position: refs/heads/master@{#60829}
parent d7fb4a64
...@@ -2307,7 +2307,8 @@ class FastElementsAccessor : public ElementsAccessorBase<Subclass, KindTraits> { ...@@ -2307,7 +2307,8 @@ class FastElementsAccessor : public ElementsAccessorBase<Subclass, KindTraits> {
// PACKED_DOUBLE_ELEMENTS or PACKED_SMI_ELEMENTS, we might encounter The // PACKED_DOUBLE_ELEMENTS or PACKED_SMI_ELEMENTS, we might encounter The
// Hole here, since the {length} used here can be larger than // Hole here, since the {length} used here can be larger than
// JSArray::length. // JSArray::length.
if (IsSmiOrObjectElementsKind(Subclass::kind())) { if (IsSmiOrObjectElementsKind(Subclass::kind()) ||
IsFrozenOrSealedElementsKind(Subclass::kind())) {
auto elements = FixedArray::cast(receiver->elements()); auto elements = FixedArray::cast(receiver->elements());
for (uint32_t k = start_from; k < length; ++k) { for (uint32_t k = start_from; k < length; ++k) {
......
...@@ -426,7 +426,9 @@ function testPackedFrozenArray1(obj) { ...@@ -426,7 +426,9 @@ function testPackedFrozenArray1(obj) {
// Verify search, filter, iterator // Verify search, filter, iterator
assertEquals(obj.lastIndexOf(1), 2); assertEquals(obj.lastIndexOf(1), 2);
assertEquals(obj.indexOf('a'), 4); assertEquals(obj.indexOf('a'), 4);
assertEquals(obj.indexOf(undefined), 0);
assertFalse(obj.includes(Symbol("test"))); assertFalse(obj.includes(Symbol("test")));
assertTrue(obj.includes(undefined));
assertEquals(obj.find(x => x==0), undefined); assertEquals(obj.find(x => x==0), undefined);
assertEquals(obj.findIndex(x => x=='a'), 4); assertEquals(obj.findIndex(x => x=='a'), 4);
assertTrue(obj.some(x => typeof x == 'symbol')); assertTrue(obj.some(x => typeof x == 'symbol'));
......
...@@ -186,7 +186,9 @@ assertFalse(Object.isExtensible(obj)); ...@@ -186,7 +186,9 @@ assertFalse(Object.isExtensible(obj));
assertTrue(Array.isArray(obj)); assertTrue(Array.isArray(obj));
assertEquals(obj.lastIndexOf(1), 2); assertEquals(obj.lastIndexOf(1), 2);
assertEquals(obj.indexOf('a'), 4); assertEquals(obj.indexOf('a'), 4);
assertEquals(obj.indexOf(undefined), 0);
assertFalse(obj.includes(Symbol("test"))); assertFalse(obj.includes(Symbol("test")));
assertTrue(obj.includes(undefined));
assertEquals(obj.find(x => x==0), undefined); assertEquals(obj.find(x => x==0), undefined);
assertEquals(obj.findIndex(x => x=='a'), 4); assertEquals(obj.findIndex(x => x=='a'), 4);
assertTrue(obj.some(x => typeof x == 'symbol')); assertTrue(obj.some(x => typeof x == 'symbol'));
......
...@@ -415,7 +415,9 @@ function testPackedSealedArray1(obj) { ...@@ -415,7 +415,9 @@ function testPackedSealedArray1(obj) {
assertTrue(Array.isArray(obj)); assertTrue(Array.isArray(obj));
assertEquals(obj.lastIndexOf(1), 2); assertEquals(obj.lastIndexOf(1), 2);
assertEquals(obj.indexOf('a'), 4); assertEquals(obj.indexOf('a'), 4);
assertEquals(obj.indexOf(undefined), 0);
assertFalse(obj.includes(Symbol("test"))); assertFalse(obj.includes(Symbol("test")));
assertTrue(obj.includes(undefined));
assertEquals(obj.find(x => x==0), undefined); assertEquals(obj.find(x => x==0), undefined);
assertEquals(obj.findIndex(x => x=='a'), 4); assertEquals(obj.findIndex(x => x=='a'), 4);
assertTrue(obj.some(x => typeof x == 'symbol')); assertTrue(obj.some(x => typeof x == 'symbol'));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment