diff options
author | toyoshim@chromium.org <toyoshim@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-14 09:31:37 +0000 |
---|---|---|
committer | toyoshim@chromium.org <toyoshim@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-05-14 09:31:37 +0000 |
commit | 69d223830c3f768e0447f41ab90945978774e69a (patch) | |
tree | 430799f77a63871981cde235aafb5e290a1bcb3c | |
parent | 78a316d6b7340f978556481ee11ca22343b79a5c (diff) | |
download | chromium_src-69d223830c3f768e0447f41ab90945978774e69a.zip chromium_src-69d223830c3f768e0447f41ab90945978774e69a.tar.gz chromium_src-69d223830c3f768e0447f41ab90945978774e69a.tar.bz2 |
Use new TestCompletionCallback scheme to simplify tests implementation.
BUG=
TEST=browser_tests --gtest_filter='PPAPI*WebSocket*'
Review URL: https://chromiumcodereview.appspot.com/10386041
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@136842 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | ppapi/tests/test_websocket.cc | 351 |
1 files changed, 169 insertions, 182 deletions
diff --git a/ppapi/tests/test_websocket.cc b/ppapi/tests/test_websocket.cc index 93ce956..3092655 100644 --- a/ppapi/tests/test_websocket.cc +++ b/ppapi/tests/test_websocket.cc @@ -280,20 +280,19 @@ PP_Resource TestWebSocket::Connect(const std::string& url, if (!ws) return 0; PP_Var url_var = CreateVarString(url); - TestCompletionCallback callback(instance_->pp_instance(), force_async_); + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); uint32_t protocol_count = 0U; if (protocol.size()) { protocols[0] = CreateVarString(protocol); protocol_count = 1U; } - *result = websocket_interface_->Connect( + callback.WaitForResult(websocket_interface_->Connect( ws, url_var, protocols, protocol_count, - callback.GetCallback().pp_completion_callback()); + callback.GetCallback().pp_completion_callback())); ReleaseVar(url_var); if (protocol.size()) ReleaseVar(protocols[0]); - if (*result == PP_OK_COMPLETIONPENDING) - *result = callback.WaitForResult(); + *result = callback.result(); return ws; } @@ -359,20 +358,21 @@ std::string TestWebSocket::TestInvalidConnect() { PP_Resource ws = websocket_interface_->Create(instance_->pp_instance()); ASSERT_TRUE(ws); - TestCompletionCallback callback(instance_->pp_instance(), force_async_); - int32_t result = websocket_interface_->Connect( + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); + callback.WaitForResult(websocket_interface_->Connect( ws, PP_MakeUndefined(), protocols, 1U, - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_BADARGUMENT, result); + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_BADARGUMENT, callback.result()); - result = websocket_interface_->Connect( + callback.WaitForResult(websocket_interface_->Connect( ws, PP_MakeUndefined(), protocols, 1U, - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_INPROGRESS, result); + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_INPROGRESS, callback.result()); core_interface_->ReleaseResource(ws); for (int i = 0; kInvalidURLs[i]; ++i) { + int32_t result; ws = Connect(kInvalidURLs[i], &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_ERROR_BADARGUMENT, result); @@ -396,18 +396,16 @@ std::string TestWebSocket::TestProtocols() { PP_Resource ws = websocket_interface_->Create(instance_->pp_instance()); ASSERT_TRUE(ws); - TestCompletionCallback callback(instance_->pp_instance(), force_async_); - int32_t result = websocket_interface_->Connect( + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); + callback.WaitForResult(websocket_interface_->Connect( ws, url, bad_protocols, 2U, - callback.GetCallback().pp_completion_callback()); - if (result == PP_OK_COMPLETIONPENDING) - result = callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_BADARGUMENT, result); + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_BADARGUMENT, callback.result()); core_interface_->ReleaseResource(ws); ws = websocket_interface_->Create(instance_->pp_instance()); ASSERT_TRUE(ws); - result = websocket_interface_->Connect( + int32_t result = websocket_interface_->Connect( ws, url, good_protocols, 2U, PP_BlockUntilComplete()); ASSERT_EQ(PP_ERROR_BLOCKS_MAIN_THREAD, result); core_interface_->ReleaseResource(ws); @@ -452,34 +450,35 @@ std::string TestWebSocket::TestValidConnect() { std::string TestWebSocket::TestInvalidClose() { PP_Var reason = CreateVarString("close for test"); - TestCompletionCallback callback(instance_->pp_instance()); - TestCompletionCallback another_callback(instance_->pp_instance()); + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); + TestCompletionCallback async_callback(instance_->pp_instance(), PP_REQUIRED); // Close before connect. PP_Resource ws = websocket_interface_->Create(instance_->pp_instance()); - int32_t result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_FAILED, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_FAILED, callback.result()); core_interface_->ReleaseResource(ws); // Close with bad arguments. + int32_t result; ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, 1U, reason, - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_NOACCESS, result); + callback.WaitForResult(websocket_interface_->Close( + ws, 1U, reason, callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_NOACCESS, callback.result()); core_interface_->ReleaseResource(ws); // Close with PP_VARTYPE_NULL. ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeNull(), - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_BADARGUMENT, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeNull(), + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_BADARGUMENT, callback.result()); core_interface_->ReleaseResource(ws); // Close with PP_VARTYPE_NULL and ongoing receive message. @@ -487,20 +486,21 @@ std::string TestWebSocket::TestInvalidClose() { ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); PP_Var receive_message_var; - result = websocket_interface_->ReceiveMessage(ws, &receive_message_var, - callback.GetCallback().pp_completion_callback()); + result = websocket_interface_->ReceiveMessage( + ws, &receive_message_var, + async_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeNull(), - another_callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_ERROR_BADARGUMENT, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeNull(), + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_ERROR_BADARGUMENT, callback.result()); const char* send_message = "hi"; PP_Var send_message_var = CreateVarString(send_message); result = websocket_interface_->SendMessage(ws, send_message_var); ReleaseVar(send_message_var); ASSERT_EQ(PP_OK, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + async_callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, async_callback.result()); ASSERT_TRUE(AreEqualWithString(receive_message_var, send_message)); ReleaseVar(receive_message_var); core_interface_->ReleaseResource(ws); @@ -509,25 +509,23 @@ std::string TestWebSocket::TestInvalidClose() { ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, - callback.GetCallback().pp_completion_callback()); + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + async_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); // Call another Close() before previous one is in progress. - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, - another_callback.GetCallback().pp_completion_callback()); + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_ERROR_INPROGRESS, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + async_callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, async_callback.result()); // Call another Close() after previous one is completed. // This Close() must do nothing and reports no error. - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, - callback.GetCallback().pp_completion_callback()); - if (result == PP_OK_COMPLETIONPENDING) - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); core_interface_->ReleaseResource(ws); ReleaseVar(reason); @@ -539,49 +537,48 @@ std::string TestWebSocket::TestValidClose() { PP_Var reason = CreateVarString("close for test"); PP_Var url = CreateVarString(GetFullURL(kEchoServerURL).c_str()); PP_Var protocols[] = { PP_MakeUndefined() }; - TestCompletionCallback callback(instance_->pp_instance()); - TestCompletionCallback another_callback(instance_->pp_instance()); + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); + TestCompletionCallback another_callback( + instance_->pp_instance(), callback_type()); // Close. int32_t result; PP_Resource ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + callback.GetCallback().pp_completion_callback())); + CHECK_CALLBACK_BEHAVIOR(callback); + ASSERT_EQ(PP_OK, callback.result()); core_interface_->ReleaseResource(ws); // Close with PP_VARTYPE_UNDEFINED. ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeUndefined(), - callback.GetCallback().pp_completion_callback()); - ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeUndefined(), + callback.GetCallback().pp_completion_callback())); + CHECK_CALLBACK_BEHAVIOR(callback); + ASSERT_EQ(PP_OK, callback.result()); core_interface_->ReleaseResource(ws); // Close in connecting. // The ongoing connect failed with PP_ERROR_ABORTED, then the close is done // successfully. ws = websocket_interface_->Create(instance_->pp_instance()); - result = websocket_interface_->Connect(ws, url, protocols, 0U, - callback.GetCallback().pp_completion_callback()); + result = websocket_interface_->Connect( + ws, url, protocols, 0U, callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, another_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); - result = another_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_ERROR_ABORTED, callback.result()); + another_callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, another_callback.result()); core_interface_->ReleaseResource(ws); // Close in closing. @@ -590,16 +587,16 @@ std::string TestWebSocket::TestValidClose() { ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, another_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_ERROR_INPROGRESS, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, callback.result()); core_interface_->ReleaseResource(ws); // Close with ongoing receive message. @@ -607,34 +604,36 @@ std::string TestWebSocket::TestValidClose() { ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); PP_Var receive_message_var; - result = websocket_interface_->ReceiveMessage(ws, &receive_message_var, + result = websocket_interface_->ReceiveMessage( + ws, &receive_message_var, callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, another_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); - result = another_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_ERROR_ABORTED, callback.result()); + another_callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, another_callback.result()); core_interface_->ReleaseResource(ws); // Close with PP_VARTYPE_UNDEFINED and ongoing receive message. ws = Connect(GetFullURL(kEchoServerURL), &result, ""); ASSERT_TRUE(ws); ASSERT_EQ(PP_OK, result); - result = websocket_interface_->ReceiveMessage(ws, &receive_message_var, + result = websocket_interface_->ReceiveMessage( + ws, &receive_message_var, callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeUndefined(), + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, PP_MakeUndefined(), another_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); - result = another_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_ERROR_ABORTED, callback.result()); + another_callback.WaitForResult(PP_OK_COMPLETIONPENDING); + ASSERT_EQ(PP_OK, another_callback.result()); core_interface_->ReleaseResource(ws); // Server initiated closing handshake. @@ -697,14 +696,11 @@ std::string TestWebSocket::TestTextSendReceive() { ASSERT_EQ(PP_OK, result); // Receive echoed 'hello pepper'. - TestCompletionCallback callback(instance_->pp_instance(), force_async_); + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); PP_Var received_message; - result = websocket_interface_->ReceiveMessage(ws, &received_message, - callback.GetCallback().pp_completion_callback()); - ASSERT_FALSE(result != PP_OK && result != PP_OK_COMPLETIONPENDING); - if (result == PP_OK_COMPLETIONPENDING) - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->ReceiveMessage( + ws, &received_message, callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); ASSERT_TRUE(AreEqualWithString(received_message, message)); ReleaseVar(received_message); core_interface_->ReleaseResource(ws); @@ -729,14 +725,11 @@ std::string TestWebSocket::TestBinarySendReceive() { ASSERT_EQ(PP_OK, result); // Receive echoed binary. - TestCompletionCallback callback(instance_->pp_instance(), force_async_); + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); PP_Var received_message; - result = websocket_interface_->ReceiveMessage(ws, &received_message, - callback.GetCallback().pp_completion_callback()); - ASSERT_TRUE(result == PP_OK || result == PP_OK_COMPLETIONPENDING); - if (result == PP_OK_COMPLETIONPENDING) - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->ReceiveMessage( + ws, &received_message, callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); ASSERT_TRUE(AreEqualWithBinary(received_message, binary)); ReleaseVar(received_message); core_interface_->ReleaseResource(ws); @@ -783,15 +776,13 @@ std::string TestWebSocket::TestStressedSendReceive() { ReleaseVar(large_binary_var); // Receive echoed data. + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); for (int i = 0; i <= 512; ++i) { - TestCompletionCallback callback(instance_->pp_instance(), force_async_); PP_Var received_message; - result = websocket_interface_->ReceiveMessage( - ws, &received_message, callback.GetCallback().pp_completion_callback()); - ASSERT_TRUE(result == PP_OK || result == PP_OK_COMPLETIONPENDING); - if (result == PP_OK_COMPLETIONPENDING) - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->ReceiveMessage( + ws, &received_message, + callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); if (i == 512) { ASSERT_TRUE(AreEqualWithBinary(received_message, large_binary)); } else if (i & 1) { @@ -832,16 +823,16 @@ std::string TestWebSocket::TestBufferedAmount() { // Close connection. std::string reason_str = "close while busy"; PP_Var reason = CreateVarString(reason_str.c_str()); - TestCompletionCallback callback(instance_->pp_instance()); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason, callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); ASSERT_EQ(PP_WEBSOCKETREADYSTATE_CLOSING, websocket_interface_->GetReadyState(ws)); - result = callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(result); + ASSERT_EQ(PP_OK, callback.result()); ASSERT_EQ(PP_WEBSOCKETREADYSTATE_CLOSED, websocket_interface_->GetReadyState(ws)); @@ -895,13 +886,14 @@ std::string TestWebSocket::TestAbortCalls() { ASSERT_TRUE(ws); PP_Var url_var = CreateVarString(url); TestCompletionCallback connect_callback( - instance_->pp_instance(), force_async_); - result = websocket_interface_->Connect(ws, url_var, NULL, 0, + instance_->pp_instance(), callback_type()); + result = websocket_interface_->Connect( + ws, url_var, NULL, 0, connect_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); core_interface_->ReleaseResource(ws); - result = connect_callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); + connect_callback.WaitForResult(result); + ASSERT_EQ(PP_ERROR_ABORTED, connect_callback.result()); ReleaseVar(url_var); // Test the behavior for Close(). @@ -910,14 +902,14 @@ std::string TestWebSocket::TestAbortCalls() { ASSERT_EQ(PP_OK, result); PP_Var reason_var = CreateVarString("abort"); TestCompletionCallback close_callback( - instance_->pp_instance(), force_async_); - result = websocket_interface_->Close(ws, - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason_var, + instance_->pp_instance(), callback_type()); + result = websocket_interface_->Close( + ws, PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, reason_var, close_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); core_interface_->ReleaseResource(ws); - result = close_callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); + close_callback.WaitForResult(result); + ASSERT_EQ(PP_ERROR_ABORTED, close_callback.result()); ReleaseVar(reason_var); // Test the behavior for ReceiveMessage(). @@ -927,13 +919,14 @@ std::string TestWebSocket::TestAbortCalls() { ASSERT_EQ(PP_OK, result); PP_Var receive_var; TestCompletionCallback receive_callback( - instance_->pp_instance(), force_async_); - result = websocket_interface_->ReceiveMessage(ws, &receive_var, + instance_->pp_instance(), callback_type()); + result = websocket_interface_->ReceiveMessage( + ws, &receive_var, receive_callback.GetCallback().pp_completion_callback()); ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); core_interface_->ReleaseResource(ws); - result = receive_callback.WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); + receive_callback.WaitForResult(result); + ASSERT_EQ(PP_ERROR_ABORTED, receive_callback.result()); // Test the behavior where receive process might be in-flight. const char* text = "yukarin"; @@ -950,25 +943,21 @@ std::string TestWebSocket::TestAbortCalls() { result = websocket_interface_->SendMessage(ws, text_var); ASSERT_EQ(PP_OK, result); } - std::auto_ptr<TestCompletionCallback> callback; + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); PP_Var var; for (int i = 0; i < trial; ++i) { - callback.reset( - new TestCompletionCallback(instance_->pp_instance(), force_async_)); - result = websocket_interface_->ReceiveMessage( - ws, &var, callback->GetCallback().pp_completion_callback()); - if (result == PP_OK_COMPLETIONPENDING) - result = callback->WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->ReceiveMessage( + ws, &var, callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); ASSERT_TRUE(AreEqualWithString(var, text)); ReleaseVar(var); } result = websocket_interface_->ReceiveMessage( - ws, &var, callback->GetCallback().pp_completion_callback()); + ws, &var, callback.GetCallback().pp_completion_callback()); core_interface_->ReleaseResource(ws); if (result != PP_OK) { - result = callback->WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); + callback.WaitForResult(result); + ASSERT_EQ(PP_ERROR_ABORTED, callback.result()); } } // Same test, but the last receiving message is large message over 64KiB. @@ -983,25 +972,21 @@ std::string TestWebSocket::TestAbortCalls() { result = websocket_interface_->SendMessage(ws, text_var); ASSERT_EQ(PP_OK, result); } - std::auto_ptr<TestCompletionCallback> callback; + TestCompletionCallback callback(instance_->pp_instance(), callback_type()); PP_Var var; for (int i = 0; i < trial; ++i) { - callback.reset( - new TestCompletionCallback(instance_->pp_instance(), force_async_)); - result = websocket_interface_->ReceiveMessage( - ws, &var, callback->GetCallback().pp_completion_callback()); - if (result == PP_OK_COMPLETIONPENDING) - result = callback->WaitForResult(); - ASSERT_EQ(PP_OK, result); + callback.WaitForResult(websocket_interface_->ReceiveMessage( + ws, &var, callback.GetCallback().pp_completion_callback())); + ASSERT_EQ(PP_OK, callback.result()); ASSERT_TRUE(AreEqualWithString(var, text)); ReleaseVar(var); } result = websocket_interface_->ReceiveMessage( - ws, &var, callback->GetCallback().pp_completion_callback()); + ws, &var, callback.GetCallback().pp_completion_callback()); core_interface_->ReleaseResource(ws); if (result != PP_OK) { - result = callback->WaitForResult(); - ASSERT_EQ(PP_ERROR_ABORTED, result); + callback.WaitForResult(result); + ASSERT_EQ(PP_ERROR_ABORTED, callback.result()); } } @@ -1027,15 +1012,15 @@ std::string TestWebSocket::TestCcInterfaces() { ASSERT_TRUE(AreEqualWithString(ws.GetURL().pp_var(), "")); // Check communication interfaces (connect, send, receive, and close). - TestCompletionCallback connect_callback(instance_->pp_instance()); - int32_t result = ws.Connect(pp::Var(GetFullURL(kCloseServerURL)), NULL, 0U, - connect_callback); - ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = connect_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + TestCompletionCallback connect_callback( + instance_->pp_instance(), callback_type()); + connect_callback.WaitForResult(ws.Connect( + pp::Var(GetFullURL(kCloseServerURL)), NULL, 0U, connect_callback)); + CHECK_CALLBACK_BEHAVIOR(connect_callback); + ASSERT_EQ(PP_OK, connect_callback.result()); std::string text_message("hello C++"); - result = ws.SendMessage(pp::Var(text_message)); + int32_t result = ws.SendMessage(pp::Var(text_message)); ASSERT_EQ(PP_OK, result); std::vector<uint8_t> binary(256); @@ -1046,38 +1031,40 @@ std::string TestWebSocket::TestCcInterfaces() { ASSERT_EQ(PP_OK, result); pp::Var text_receive_var; - TestCompletionCallback text_receive_callback(instance_->pp_instance()); - result = ws.ReceiveMessage(&text_receive_var, text_receive_callback); - if (result == PP_OK_COMPLETIONPENDING) - result = text_receive_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + TestCompletionCallback text_receive_callback( + instance_->pp_instance(), callback_type()); + text_receive_callback.WaitForResult( + ws.ReceiveMessage(&text_receive_var, text_receive_callback)); + ASSERT_EQ(PP_OK, text_receive_callback.result()); ASSERT_TRUE( AreEqualWithString(text_receive_var.pp_var(), text_message.c_str())); pp::Var binary_receive_var; - TestCompletionCallback binary_receive_callback(instance_->pp_instance()); - result = ws.ReceiveMessage(&binary_receive_var, binary_receive_callback); - if (result == PP_OK_COMPLETIONPENDING) - result = binary_receive_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + TestCompletionCallback binary_receive_callback( + instance_->pp_instance(), callback_type()); + binary_receive_callback.WaitForResult( + ws.ReceiveMessage(&binary_receive_var, binary_receive_callback)); + ASSERT_EQ(PP_OK, binary_receive_callback.result()); ASSERT_TRUE(AreEqualWithBinary(binary_receive_var.pp_var(), binary)); - TestCompletionCallback close_callback(instance_->pp_instance()); + TestCompletionCallback close_callback( + instance_->pp_instance(), callback_type()); std::string reason("bye"); - result = ws.Close( - PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, pp::Var(reason), close_callback); - ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); - result = close_callback.WaitForResult(); - ASSERT_EQ(PP_OK, result); + close_callback.WaitForResult(ws.Close( + PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, pp::Var(reason), close_callback)); + CHECK_CALLBACK_BEHAVIOR(close_callback); + ASSERT_EQ(PP_OK, close_callback.result()); // Check initialized properties access. ASSERT_EQ(0, ws.GetBufferedAmount()); ASSERT_EQ(PP_WEBSOCKETSTATUSCODE_NORMAL_CLOSURE, ws.GetCloseCode()); - ASSERT_TRUE(AreEqualWithString(ws.GetCloseReason().pp_var(), reason.c_str())); + ASSERT_TRUE( + AreEqualWithString(ws.GetCloseReason().pp_var(), reason.c_str())); ASSERT_EQ(true, ws.GetCloseWasClean()); ASSERT_TRUE(AreEqualWithString(ws.GetProtocol().pp_var(), "")); ASSERT_EQ(PP_WEBSOCKETREADYSTATE_CLOSED, ws.GetReadyState()); - ASSERT_TRUE(AreEqualWithString(ws.GetURL().pp_var(), GetFullURL(kCloseServerURL).c_str())); + ASSERT_TRUE(AreEqualWithString( + ws.GetURL().pp_var(), GetFullURL(kCloseServerURL).c_str())); PASS(); } |