diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2014-11-24 09:08:18 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2014-11-24 09:08:18 +0000 | 
| commit | 5ca98fd98791947eba83a1ed3f2c8191ef7afa6c (patch) | |
| tree | f5944309621cee4fe0976be6f9ac619b7ebfc4c2 /unittests/Support/ErrorOrTest.cpp | |
| parent | 68bcb7db193e4bc81430063148253d30a791023e (diff) | |
Notes
Diffstat (limited to 'unittests/Support/ErrorOrTest.cpp')
| -rw-r--r-- | unittests/Support/ErrorOrTest.cpp | 26 | 
1 files changed, 12 insertions, 14 deletions
| diff --git a/unittests/Support/ErrorOrTest.cpp b/unittests/Support/ErrorOrTest.cpp index feb6a086e194..d76e7d62421f 100644 --- a/unittests/Support/ErrorOrTest.cpp +++ b/unittests/Support/ErrorOrTest.cpp @@ -8,9 +8,8 @@  //===----------------------------------------------------------------------===//  #include "llvm/Support/ErrorOr.h" - +#include "llvm/Support/Errc.h"  #include "gtest/gtest.h" -  #include <memory>  using namespace llvm; @@ -22,22 +21,25 @@ ErrorOr<int> t2() { return errc::invalid_argument; }  TEST(ErrorOr, SimpleValue) {    ErrorOr<int> a = t1(); -  EXPECT_TRUE(a); +  // FIXME: This is probably a bug in gtest. EXPECT_TRUE should expand to +  // include the !! to make it friendly to explicit bool operators. +  EXPECT_TRUE(!!a);    EXPECT_EQ(1, *a); +  ErrorOr<int> b = a; +  EXPECT_EQ(1, *b); +    a = t2();    EXPECT_FALSE(a); -  EXPECT_EQ(errc::invalid_argument, a); +  EXPECT_EQ(a.getError(), errc::invalid_argument);  #ifdef EXPECT_DEBUG_DEATH    EXPECT_DEBUG_DEATH(*a, "Cannot get value when an error exists");  #endif  } -#if LLVM_HAS_CXX11_STDLIB  ErrorOr<std::unique_ptr<int> > t3() {    return std::unique_ptr<int>(new int(3));  } -#endif  TEST(ErrorOr, Types) {    int x; @@ -45,22 +47,18 @@ TEST(ErrorOr, Types) {    *a = 42;    EXPECT_EQ(42, x); -#if LLVM_HAS_CXX11_STDLIB    // Move only types.    EXPECT_EQ(3, **t3()); -#endif  }  struct B {};  struct D : B {};  TEST(ErrorOr, Covariant) { -  ErrorOr<B*> b(ErrorOr<D*>(0)); -  b = ErrorOr<D*>(0); +  ErrorOr<B*> b(ErrorOr<D*>(nullptr)); +  b = ErrorOr<D*>(nullptr); -#if LLVM_HAS_CXX11_STDLIB -  ErrorOr<std::unique_ptr<B> > b1(ErrorOr<std::unique_ptr<D> >(0)); -  b1 = ErrorOr<std::unique_ptr<D> >(0); -#endif +  ErrorOr<std::unique_ptr<B> > b1(ErrorOr<std::unique_ptr<D> >(nullptr)); +  b1 = ErrorOr<std::unique_ptr<D> >(nullptr);  }  } // end anon namespace | 
