From 3fde652e1864f0e4273352c185cd14f80afbe064 Mon Sep 17 00:00:00 2001 From: Lang Hames Date: Mon, 18 Apr 2016 19:55:43 +0000 Subject: [Orc] Re-commit r266581 with fixes for MSVC, and format cleanups. Fixes: (1) Removes constexpr (unsupported in MSVC) (2) Move constructors (remove explicitly defaulted ones) (3) - Add warning suppression for MSVC. llvm-svn: 266663 --- .../unittests/ExecutionEngine/Orc/RPCUtilsTest.cpp | 103 +++++++++++++++------ 1 file changed, 76 insertions(+), 27 deletions(-) (limited to 'llvm/unittests/ExecutionEngine') diff --git a/llvm/unittests/ExecutionEngine/Orc/RPCUtilsTest.cpp b/llvm/unittests/ExecutionEngine/Orc/RPCUtilsTest.cpp index 3b01c3828b6..77632e35eb1 100644 --- a/llvm/unittests/ExecutionEngine/Orc/RPCUtilsTest.cpp +++ b/llvm/unittests/ExecutionEngine/Orc/RPCUtilsTest.cpp @@ -44,26 +44,25 @@ private: class DummyRPC : public testing::Test, public RPC { public: - typedef Procedure<1, void(bool)> Proc1; - typedef Procedure<2, void(int8_t, uint8_t, int16_t, uint16_t, - int32_t, uint32_t, int64_t, uint64_t, - bool, std::string, std::vector)> AllTheTypes; + typedef Function<2, void(bool)> BasicVoid; + typedef Function<3, int32_t(bool)> BasicInt; + typedef Function<4, void(int8_t, uint8_t, int16_t, uint16_t, + int32_t, uint32_t, int64_t, uint64_t, + bool, std::string, std::vector)> AllTheTypes; }; -TEST_F(DummyRPC, TestBasic) { +TEST_F(DummyRPC, TestAsyncBasicVoid) { std::queue Queue; QueueChannel C(Queue); - { - // Make a call to Proc1. - auto EC = call(C, true); - EXPECT_FALSE(EC) << "Simple call over queue failed"; - } + // Make an async call. + auto ResOrErr = callAsync(C, true); + EXPECT_TRUE(!!ResOrErr) << "Simple call over queue failed"; { // Expect a call to Proc1. - auto EC = expect(C, + auto EC = expect(C, [&](bool &B) { EXPECT_EQ(B, true) << "Bool serialization broken"; @@ -71,30 +70,70 @@ TEST_F(DummyRPC, TestBasic) { }); EXPECT_FALSE(EC) << "Simple expect over queue failed"; } + + { + // Wait for the result. + auto EC = waitForResult(C, ResOrErr->second, handleNone); + EXPECT_FALSE(EC) << "Could not read result."; + } + + // Verify that the function returned ok. + auto Val = ResOrErr->first.get(); + EXPECT_TRUE(Val) << "Remote void function failed to execute."; } -TEST_F(DummyRPC, TestSerialization) { +TEST_F(DummyRPC, TestAsyncBasicInt) { std::queue Queue; QueueChannel C(Queue); + // Make an async call. + auto ResOrErr = callAsync(C, false); + EXPECT_TRUE(!!ResOrErr) << "Simple call over queue failed"; + { - // Make a call to Proc1. - std::vector v({42, 7}); - auto EC = call(C, - -101, - 250, - -10000, - 10000, - -1000000000, - 1000000000, - -10000000000, - 10000000000, - true, - "foo", - v); - EXPECT_FALSE(EC) << "Big (serialization test) call over queue failed"; + // Expect a call to Proc1. + auto EC = expect(C, + [&](bool &B) { + EXPECT_EQ(B, false) + << "Bool serialization broken"; + return 42; + }); + EXPECT_FALSE(EC) << "Simple expect over queue failed"; } + { + // Wait for the result. + auto EC = waitForResult(C, ResOrErr->second, handleNone); + EXPECT_FALSE(EC) << "Could not read result."; + } + + // Verify that the function returned ok. + auto Val = ResOrErr->first.get(); + EXPECT_TRUE(!!Val) << "Remote int function failed to execute."; + EXPECT_EQ(*Val, 42) << "Remote int function return wrong value."; +} + +TEST_F(DummyRPC, TestSerialization) { + std::queue Queue; + QueueChannel C(Queue); + + // Make a call to Proc1. + std::vector v({42, 7}); + auto ResOrErr = callAsync(C, + -101, + 250, + -10000, + 10000, + -1000000000, + 1000000000, + -10000000000, + 10000000000, + true, + "foo", + v); + EXPECT_TRUE(!!ResOrErr) + << "Big (serialization test) call over queue failed"; + { // Expect a call to Proc1. auto EC = expect(C, @@ -136,4 +175,14 @@ TEST_F(DummyRPC, TestSerialization) { }); EXPECT_FALSE(EC) << "Big (serialization test) call over queue failed"; } + + { + // Wait for the result. + auto EC = waitForResult(C, ResOrErr->second, handleNone); + EXPECT_FALSE(EC) << "Could not read result."; + } + + // Verify that the function returned ok. + auto Val = ResOrErr->first.get(); + EXPECT_TRUE(Val) << "Remote void function failed to execute."; } -- cgit v1.2.3