diff options
| author | Jeffrey Yasskin <jyasskin@google.com> | 2009-08-07 19:54:29 +0000 | 
|---|---|---|
| committer | Jeffrey Yasskin <jyasskin@google.com> | 2009-08-07 19:54:29 +0000 | 
| commit | 0d5bd59553375dc85ac04c81ef48ef74c9e7193e (patch) | |
| tree | f9cf8660342725fc1e0008b31e2929145180dde9 /unittests/Support/ValueHandleTest.cpp | |
| parent | f12288e8aa27a7cb1e48e1fceccd5cf49876104e (diff) | |
To catch bugs like the one fixed in
http://llvm.org/viewvc/llvm-project?view=rev&revision=78127, I'm changing the
ExecutionEngine's global mappings to hold AssertingVH<const GlobalValue>. That
way, if unregistering a mapping fails to actually unregister it, we'll get an
assert. Running the jit nightly tests didn't uncover any actual instances of
the problem.
This also uncovered the fact that AssertingVH<const X> didn't work, so I fixed
that too.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78400 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'unittests/Support/ValueHandleTest.cpp')
| -rw-r--r-- | unittests/Support/ValueHandleTest.cpp | 7 | 
1 files changed, 7 insertions, 0 deletions
| diff --git a/unittests/Support/ValueHandleTest.cpp b/unittests/Support/ValueHandleTest.cpp index d9a5515f78..5e6cd61035 100644 --- a/unittests/Support/ValueHandleTest.cpp +++ b/unittests/Support/ValueHandleTest.cpp @@ -120,6 +120,13 @@ TEST_F(ValueHandle, AssertingVH_BasicOperation) {    EXPECT_FALSE((*AVH).mayWriteToMemory());  } +TEST_F(ValueHandle, AssertingVH_Const) { +  const CastInst *ConstBitcast = BitcastV.get(); +  AssertingVH<const CastInst> AVH(ConstBitcast); +  const CastInst *implicit_to_exact_type = AVH; +  implicit_to_exact_type = implicit_to_exact_type;  // Avoid warning. +} +  TEST_F(ValueHandle, AssertingVH_Comparisons) {    AssertingVH<Value> BitcastAVH(BitcastV.get());    AssertingVH<Value> ConstantAVH(ConstantV); | 
