PR-URL: https://github.com/nodejs/node/pull/52293 Reviewed-By: Moshe Atlow <moshe@atlow.co.il> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com> Reviewed-By: Richard Lau <rlau@redhat.com>
269 lines
6.5 KiB
C++
269 lines
6.5 KiB
C++
// Copyright 2022 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "src/utils/bit-vector.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "src/init/v8.h"
|
|
#include "test/unittests/test-utils.h"
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
|
|
using BitVectorTest = TestWithZone;
|
|
|
|
TEST_F(BitVectorTest, SmallBitVector) {
|
|
BitVector v(15, zone());
|
|
v.Add(1);
|
|
EXPECT_TRUE(v.Contains(1));
|
|
v.Remove(0);
|
|
EXPECT_FALSE(v.Contains(0));
|
|
v.Add(0);
|
|
v.Add(1);
|
|
BitVector w(15, zone());
|
|
w.Add(1);
|
|
v.Intersect(w);
|
|
EXPECT_FALSE(v.Contains(0));
|
|
EXPECT_TRUE(v.Contains(1));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, SmallBitVectorIterator) {
|
|
BitVector v(64, zone());
|
|
v.Add(27);
|
|
v.Add(30);
|
|
v.Add(31);
|
|
v.Add(33);
|
|
BitVector::Iterator iter = v.begin();
|
|
BitVector::Iterator end = v.end();
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(27, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(30, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(31, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(33, *iter);
|
|
++iter;
|
|
EXPECT_TRUE(iter == end);
|
|
EXPECT_FALSE(iter != end);
|
|
}
|
|
|
|
TEST_F(BitVectorTest, Union) {
|
|
BitVector v(15, zone());
|
|
v.Add(0);
|
|
BitVector w(15, zone());
|
|
w.Add(1);
|
|
v.Union(w);
|
|
EXPECT_TRUE(v.Contains(0));
|
|
EXPECT_TRUE(v.Contains(1));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, CopyFrom) {
|
|
BitVector v(15, zone());
|
|
v.Add(0);
|
|
BitVector w(15, zone());
|
|
w.CopyFrom(v);
|
|
EXPECT_TRUE(w.Contains(0));
|
|
w.Add(1);
|
|
BitVector u(w, zone());
|
|
EXPECT_TRUE(u.Contains(0));
|
|
EXPECT_TRUE(u.Contains(1));
|
|
v.Union(w);
|
|
EXPECT_TRUE(v.Contains(0));
|
|
EXPECT_TRUE(v.Contains(1));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, Union2) {
|
|
BitVector v(35, zone());
|
|
v.Add(0);
|
|
BitVector w(35, zone());
|
|
w.Add(33);
|
|
v.Union(w);
|
|
EXPECT_TRUE(v.Contains(0));
|
|
EXPECT_TRUE(v.Contains(33));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, Intersect) {
|
|
BitVector v(35, zone());
|
|
v.Add(32);
|
|
v.Add(33);
|
|
BitVector w(35, zone());
|
|
w.Add(33);
|
|
v.Intersect(w);
|
|
EXPECT_FALSE(v.Contains(32));
|
|
EXPECT_TRUE(v.Contains(33));
|
|
BitVector r(35, zone());
|
|
r.CopyFrom(v);
|
|
EXPECT_FALSE(r.Contains(32));
|
|
EXPECT_TRUE(r.Contains(33));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, Resize) {
|
|
BitVector v(35, zone());
|
|
v.Add(32);
|
|
v.Add(33);
|
|
EXPECT_TRUE(v.Contains(32));
|
|
EXPECT_TRUE(v.Contains(33));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(34));
|
|
v.Resize(50, zone());
|
|
EXPECT_TRUE(v.Contains(32));
|
|
EXPECT_TRUE(v.Contains(33));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(34));
|
|
EXPECT_FALSE(v.Contains(43));
|
|
v.Resize(300, zone());
|
|
EXPECT_TRUE(v.Contains(32));
|
|
EXPECT_TRUE(v.Contains(33));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(34));
|
|
EXPECT_FALSE(v.Contains(43));
|
|
EXPECT_FALSE(v.Contains(243));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, BigBitVectorIterator) {
|
|
// Big BitVector with big and small entries.
|
|
BitVector v(500, zone());
|
|
v.Add(27);
|
|
v.Add(300);
|
|
v.Add(499);
|
|
auto iter = v.begin();
|
|
auto end = v.end();
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(27, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(300, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(499, *iter);
|
|
++iter;
|
|
EXPECT_EQ(iter, end);
|
|
|
|
// Remove small entries, add another big one.
|
|
v.Resize(1000, zone());
|
|
v.Remove(27);
|
|
v.Remove(300);
|
|
v.Add(500);
|
|
iter = v.begin();
|
|
end = v.end();
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(499, *iter);
|
|
++iter;
|
|
EXPECT_NE(iter, end);
|
|
EXPECT_EQ(500, *iter);
|
|
++iter;
|
|
EXPECT_EQ(iter, end);
|
|
}
|
|
|
|
TEST_F(BitVectorTest, MoveConstructorInline) {
|
|
BitVector v(30, zone());
|
|
v.Add(12);
|
|
v.Add(29);
|
|
EXPECT_TRUE(v.Contains(12));
|
|
EXPECT_TRUE(v.Contains(29));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(28));
|
|
BitVector a(std::move(v));
|
|
EXPECT_TRUE(a.Contains(12));
|
|
EXPECT_TRUE(a.Contains(29));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(28));
|
|
// Check the data from `v` was properly moved out and doesn't affect `a`.
|
|
// As moving out doesn't provide a clear state of the moved out object,
|
|
// explicitly set it to a well-known state.
|
|
v = BitVector(31, zone());
|
|
v.Add(22);
|
|
v.Add(28);
|
|
EXPECT_TRUE(a.Contains(12));
|
|
EXPECT_TRUE(a.Contains(29));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(28));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, MoveAssignInline) {
|
|
BitVector v(30, zone());
|
|
v.Add(12);
|
|
v.Add(29);
|
|
EXPECT_TRUE(v.Contains(12));
|
|
EXPECT_TRUE(v.Contains(29));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(28));
|
|
BitVector a;
|
|
a = std::move(v);
|
|
EXPECT_TRUE(a.Contains(12));
|
|
EXPECT_TRUE(a.Contains(29));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(28));
|
|
// Check the data from `v` was properly moved out and doesn't affect `a`.
|
|
// As moving out doesn't provide a clear state of the moved out object,
|
|
// explicitly set it to a well-known state.
|
|
v = BitVector(31, zone());
|
|
v.Add(22);
|
|
v.Add(28);
|
|
EXPECT_TRUE(a.Contains(12));
|
|
EXPECT_TRUE(a.Contains(29));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(28));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, MoveConstructorLarge) {
|
|
BitVector v(200, zone());
|
|
v.Add(31);
|
|
v.Add(133);
|
|
EXPECT_TRUE(v.Contains(31));
|
|
EXPECT_TRUE(v.Contains(133));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(134));
|
|
BitVector a(std::move(v));
|
|
EXPECT_TRUE(a.Contains(31));
|
|
EXPECT_TRUE(a.Contains(133));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(134));
|
|
// Check the data from `v` was properly moved out and doesn't affect `a`.
|
|
// As moving out doesn't provide a clear state of the moved out object,
|
|
// explicitly set it to a well-known state.
|
|
v = BitVector(205, zone());
|
|
v.Add(22);
|
|
v.Add(134);
|
|
EXPECT_TRUE(a.Contains(31));
|
|
EXPECT_TRUE(a.Contains(133));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(134));
|
|
}
|
|
|
|
TEST_F(BitVectorTest, MoveAssignLarge) {
|
|
BitVector v(200, zone());
|
|
v.Add(31);
|
|
v.Add(133);
|
|
EXPECT_TRUE(v.Contains(31));
|
|
EXPECT_TRUE(v.Contains(133));
|
|
EXPECT_FALSE(v.Contains(22));
|
|
EXPECT_FALSE(v.Contains(134));
|
|
BitVector a;
|
|
a = std::move(v);
|
|
EXPECT_TRUE(a.Contains(31));
|
|
EXPECT_TRUE(a.Contains(133));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(134));
|
|
// Check the data from `v` was properly moved out and doesn't affect `a`.
|
|
// As moving out doesn't provide a clear state of the moved out object,
|
|
// explicitly set it to a well-known state.
|
|
v = BitVector(205, zone());
|
|
v.Add(22);
|
|
v.Add(134);
|
|
EXPECT_TRUE(a.Contains(31));
|
|
EXPECT_TRUE(a.Contains(133));
|
|
EXPECT_FALSE(a.Contains(22));
|
|
EXPECT_FALSE(a.Contains(134));
|
|
}
|
|
|
|
} // namespace internal
|
|
} // namespace v8
|