summaryrefslogtreecommitdiff
path: root/unittests
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-04-30 20:50:28 +0000
committerDan Gohman <gohman@apple.com>2010-04-30 20:50:28 +0000
commit3f5e91565273e3f4639d37ee5a5b856699e8c9e5 (patch)
treef5ba807a1f87467d382a9ff038f79937f895bb8c /unittests
parent8fcd418d6e47278658cbab851be25400b1402e9a (diff)
downloadllvm-3f5e91565273e3f4639d37ee5a5b856699e8c9e5.tar.gz
llvm-3f5e91565273e3f4639d37ee5a5b856699e8c9e5.tar.bz2
llvm-3f5e91565273e3f4639d37ee5a5b856699e8c9e5.tar.xz
Update BitVectorTest.cpp to stay in sync with SmallBitVectorTest.cpp,
and fix a bug in BitVector's reference proxy class which this exposed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@102768 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'unittests')
-rw-r--r--unittests/ADT/BitVectorTest.cpp18
-rw-r--r--unittests/ADT/SmallBitVectorTest.cpp1
2 files changed, 16 insertions, 3 deletions
diff --git a/unittests/ADT/BitVectorTest.cpp b/unittests/ADT/BitVectorTest.cpp
index 4fe11c1d17..a9fc133c72 100644
--- a/unittests/ADT/BitVectorTest.cpp
+++ b/unittests/ADT/BitVectorTest.cpp
@@ -7,7 +7,9 @@
//
//===----------------------------------------------------------------------===//
-#ifndef XFAIL
+// Some of these tests fail on PowerPC for unknown reasons.
+#ifndef __ppc__
+
#include "llvm/ADT/BitVector.h"
#include "gtest/gtest.h"
@@ -56,7 +58,7 @@ TEST(BitVectorTest, TrivialOperation) {
Vec.resize(26, true);
Vec.resize(29, false);
Vec.resize(33, true);
- Vec.resize(61, false);
+ Vec.resize(57, false);
unsigned Count = 0;
for (unsigned i = Vec.find_first(); i != -1u; i = Vec.find_next(i)) {
++Count;
@@ -67,7 +69,8 @@ TEST(BitVectorTest, TrivialOperation) {
EXPECT_EQ(Count, 23u);
EXPECT_FALSE(Vec[0]);
EXPECT_TRUE(Vec[32]);
- EXPECT_FALSE(Vec[60]);
+ EXPECT_FALSE(Vec[56]);
+ Vec.resize(61, false);
BitVector Copy = Vec;
BitVector Alt(3, false);
@@ -177,6 +180,15 @@ TEST(BitVectorTest, CompoundAssignment) {
EXPECT_EQ(100U, A.size());
}
+TEST(BitVectorTest, ProxyIndex) {
+ BitVector Vec(3);
+ EXPECT_TRUE(Vec.none());
+ Vec[0] = Vec[1] = Vec[2] = true;
+ EXPECT_EQ(Vec.size(), Vec.count());
+ Vec[2] = Vec[1] = Vec[0] = false;
+ EXPECT_TRUE(Vec.none());
+}
+
}
#endif
diff --git a/unittests/ADT/SmallBitVectorTest.cpp b/unittests/ADT/SmallBitVectorTest.cpp
index e12abfe20d..9c69aad5a9 100644
--- a/unittests/ADT/SmallBitVectorTest.cpp
+++ b/unittests/ADT/SmallBitVectorTest.cpp
@@ -185,4 +185,5 @@ TEST(SmallBitVectorTest, ProxyIndex) {
Vec[2] = Vec[1] = Vec[0] = false;
EXPECT_TRUE(Vec.none());
}
+
}