Commit 85852ee2 authored by tqcq's avatar tqcq
Browse files

Merge remote-tracking branch 'origin/master'

parents ed9e57c5 6d15ae73
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -267,7 +267,7 @@ public:
                result.FillFailure(future_detail::ExceptionFailure<FailureT>());
            }
        });
        OnFailure([result](const FailureT &failure) noexcept { result.FillFailure(failure); });
        OnFailure([result](const FailureT &failure) mutable noexcept { result.FillFailure(failure); });
        return result;
    }

+17 −3
Original line number Diff line number Diff line
@@ -14,10 +14,24 @@ TEST_SUITE("future")
        CHECK_EQ(f.Result(), 42);
    }

    TEST_CASE("base failed")
    TEST_CASE("base success 1")
    {
        sled::Promise<int, std::string> p;
        auto f = p.GetFuture();
        auto f = p.GetFuture().OnSuccess([](int i) { CHECK_EQ(i, 42); }).OnFailure([](const std::string &) {
            REQUIRE(false);
        });
        p.Success(42);
        CHECK(f.Wait(-1));
        CHECK(f.IsValid());
        CHECK_EQ(f.Result(), 42);
    }

    TEST_CASE("base failed 1")
    {
        sled::Promise<int, std::string> p;
        auto f = p.GetFuture().OnFailure([](const std::string &str) { CHECK_EQ(str, "error"); }).OnSuccess([](int) {
            REQUIRE(false);
        });
        p.Failure("error");
        REQUIRE(p.IsFilled());
        REQUIRE(f.IsCompleted());
@@ -39,7 +53,7 @@ TEST_SUITE("future")
        REQUIRE(f.IsFailed());
        CHECK_EQ(f.FailureReason(), "test");
    }

    //
    TEST_CASE("base failed")
    {
        sled::Promise<int, std::string> p;
+15 −0
Original line number Diff line number Diff line
@@ -54,6 +54,21 @@ FailureFromString<DefaultException>(const std::string &str)
    return DefaultException(str);
}

// template<>
// inline std::string
// FailureFromString<std::string>(std::string &&str)
// {
//     return std::move(str);
// }

// template<typename FailureT,
//          typename = typename std::enable_if<std::is_constructible<FailureT, std::string>::value>::type>
// inline FailureT
// FailureFromString(std::string &&str)
// {
//     return FailureT(std::move(str));
// }

}// namespace failure

namespace future_detail {