//===- unittests/ErrorOrTest.cpp - ErrorOr.h tests ------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "llvm/Support/ErrorOr.h" #include "gtest/gtest.h" #include using namespace llvm; namespace { ErrorOr t1() {return 1;} ErrorOr t2() { return errc::invalid_argument; } TEST(ErrorOr, SimpleValue) { ErrorOr a = t1(); EXPECT_TRUE(a); EXPECT_EQ(1, *a); a = t2(); EXPECT_FALSE(a); EXPECT_EQ(errc::invalid_argument, a); #ifdef EXPECT_DEBUG_DEATH EXPECT_DEBUG_DEATH(*a, "Cannot get value when an error exists"); #endif } #if LLVM_HAS_CXX11_STDLIB ErrorOr > t3() { return std::unique_ptr(new int(3)); } #endif TEST(ErrorOr, Types) { int x; ErrorOr a(x); *a = 42; EXPECT_EQ(42, x); EXPECT_FALSE(ErrorOr(errc::broken_pipe)); EXPECT_TRUE(ErrorOr(errc::success)); #if LLVM_HAS_CXX11_STDLIB // Move only types. EXPECT_EQ(3, **t3()); #endif } struct B {}; struct D : B {}; TEST(ErrorOr, Covariant) { ErrorOr b(ErrorOr(0)); b = ErrorOr(0); #if LLVM_HAS_CXX11_STDLIB ErrorOr > b1(ErrorOr >(0)); b1 = ErrorOr >(0); #endif } } // end anon namespace struct InvalidArgError { InvalidArgError() {} InvalidArgError(std::string S) : ArgName(S) {} std::string ArgName; }; namespace llvm { template<> struct ErrorOrUserDataTraits : true_type { static error_code error() { return make_error_code(errc::invalid_argument); } }; } // end namespace llvm ErrorOr t4() { return InvalidArgError("adena"); } ErrorOr t5() { return InvalidArgError("pie"); } namespace { TEST(ErrorOr, UserErrorData) { ErrorOr a = t4(); EXPECT_EQ(errc::invalid_argument, a); EXPECT_EQ("adena", t4().getError().ArgName); ErrorOr b = t5(); EXPECT_EQ(errc::invalid_argument, b); EXPECT_EQ("pie", b.getError().ArgName); } } // end anon namespace