Chromium Code Reviews| Index: ppapi/proxy/websocket_resource_unittest.cc |
| diff --git a/ppapi/proxy/websocket_resource_unittest.cc b/ppapi/proxy/websocket_resource_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..4237df8c08506d38fc4471ba478be144faf2605f |
| --- /dev/null |
| +++ b/ppapi/proxy/websocket_resource_unittest.cc |
| @@ -0,0 +1,168 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "base/memory/ref_counted.h" |
| +#include "base/message_loop.h" |
| +#include "ppapi/c/pp_errors.h" |
| +#include "ppapi/c/ppb_websocket.h" |
| +#include "ppapi/c/ppb_var.h" |
| +#include "ppapi/proxy/websocket_resource.h" |
| +#include "ppapi/proxy/ppapi_messages.h" |
| +#include "ppapi/proxy/ppapi_proxy_test.h" |
| +#include "ppapi/shared_impl/ppb_var_shared.h" |
| +#include "ppapi/shared_impl/scoped_pp_resource.h" |
| +#include "ppapi/shared_impl/scoped_pp_var.h" |
| +#include "ppapi/shared_impl/tracked_callback.h" |
| +#include "ppapi/shared_impl/var.h" |
| +#include "ppapi/thunk/thunk.h" |
| + |
| +namespace ppapi { |
| +namespace proxy { |
| + |
| +namespace { |
| + |
| +typedef PluginProxyTest WebSocketResourceTest; |
| + |
| +bool g_callback_called; |
| +int32_t g_callback_result; |
| +const PPB_Var* ppb_var_ = NULL; |
| + |
| +void Callback(void* user_data, int32_t result) { |
| + g_callback_called = true; |
| + g_callback_result = result; |
| +} |
| + |
| +PP_CompletionCallback MakeCallback() { |
| + g_callback_called = false; |
| + g_callback_result = PP_OK; |
| + return PP_MakeCompletionCallback(Callback, NULL); |
| +} |
| + |
| +PP_Var MakeStringVar(const std::string& string) { |
| + if (!ppb_var_) |
| + ppb_var_ = ppapi::PPB_Var_Shared::GetVarInterface1_1(); |
| + return ppb_var_->VarFromUtf8(string.c_str(), string.length()); |
| +} |
| + |
| +} |
|
brettw
2012/10/08 21:45:46
Nit: need " // namespace"
Takashi Toyoshima
2012/10/09 01:38:43
Done.
|
| + |
| + |
| +// Does a test of Connect(). |
| +TEST_F(WebSocketResourceTest, Connect) { |
| + const PPB_WebSocket_1_0* websocket_iface = |
| + thunk::GetPPB_WebSocket_1_0_Thunk(); |
| + |
| + std::string url("ws://ws.google.com"); |
| + std::string protocol0("x-foo"); |
| + std::string protocol1("x-bar"); |
| + PP_Var url_var = MakeStringVar(url); |
| + PP_Var protocols[] = { MakeStringVar(protocol0), MakeStringVar(protocol1) }; |
| + |
| + ScopedPPResource res(ScopedPPResource::PassRef(), |
| + websocket_iface->Create(pp_instance())); |
| + |
| + int32_t result = |
| + websocket_iface->Connect(res, url_var, protocols, 2, MakeCallback()); |
| + ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); |
| + |
| + // Should be sent a "Connect" message. |
| + ResourceMessageCallParams params; |
| + IPC::Message msg; |
| + ASSERT_TRUE(sink().GetFirstResourceCallMatching( |
| + PpapiHostMsg_WebSocket_Connect::ID, ¶ms, &msg)); |
| + PpapiHostMsg_WebSocket_Connect::Schema::Param p; |
| + PpapiHostMsg_WebSocket_Connect::Read(&msg, &p); |
| + EXPECT_EQ(url, p.a); |
| + EXPECT_EQ(protocol0, p.b[0]); |
| + EXPECT_EQ(protocol1, p.b[1]); |
| + |
| + // Synthesize a response. |
| + ResourceMessageReplyParams reply_params(params.pp_resource(), |
| + params.sequence()); |
| + reply_params.set_result(PP_OK); |
| + ASSERT_TRUE(plugin_dispatcher()->OnMessageReceived( |
| + PpapiPluginMsg_ResourceReply(reply_params, |
| + PpapiPluginMsg_WebSocket_ConnectReply(url, protocol1)))); |
| + |
| + EXPECT_EQ(PP_OK, g_callback_result); |
| + EXPECT_EQ(true, g_callback_called); |
| +} |
| + |
| +// Does a test for unsolicited replies. |
| +TEST_F(WebSocketResourceTest, UnsolicitedReplies) { |
| + const PPB_WebSocket_1_0* websocket_iface = |
| + thunk::GetPPB_WebSocket_1_0_Thunk(); |
| + |
| + ScopedPPResource res(ScopedPPResource::PassRef(), |
| + websocket_iface->Create(pp_instance())); |
| + |
| + // Check if BufferedAmountReply is handled. |
| + ResourceMessageReplyParams reply_params(res, 0); |
| + reply_params.set_result(PP_OK); |
| + ASSERT_TRUE(plugin_dispatcher()->OnMessageReceived( |
| + PpapiPluginMsg_ResourceReply( |
| + reply_params, |
| + PpapiPluginMsg_WebSocket_BufferedAmountReply(19760227u)))); |
| + |
| + uint64_t amount = websocket_iface->GetBufferedAmount(res); |
| + EXPECT_EQ(19760227u, amount); |
| + |
| + // Check if StateReply is handled. |
| + ASSERT_TRUE(plugin_dispatcher()->OnMessageReceived( |
| + PpapiPluginMsg_ResourceReply( |
| + reply_params, |
| + PpapiPluginMsg_WebSocket_StateReply( |
| + static_cast<int32_t>(PP_WEBSOCKETREADYSTATE_CLOSING))))); |
| + |
| + PP_WebSocketReadyState state = websocket_iface->GetReadyState(res); |
| + EXPECT_EQ(PP_WEBSOCKETREADYSTATE_CLOSING, state); |
| +} |
| + |
| +TEST_F(WebSocketResourceTest, MessageError) { |
| + const PPB_WebSocket_1_0* websocket_iface = |
| + thunk::GetPPB_WebSocket_1_0_Thunk(); |
| + |
| + std::string url("ws://ws.google.com"); |
| + PP_Var url_var = MakeStringVar(url); |
| + |
| + ScopedPPResource res(ScopedPPResource::PassRef(), |
| + websocket_iface->Create(pp_instance())); |
| + |
| + // Establish the connection virtually. |
| + int32_t result = |
| + websocket_iface->Connect(res, url_var, NULL, 0, MakeCallback()); |
| + ASSERT_EQ(PP_OK_COMPLETIONPENDING, result); |
| + |
| + ResourceMessageCallParams params; |
| + IPC::Message msg; |
| + ASSERT_TRUE(sink().GetFirstResourceCallMatching( |
| + PpapiHostMsg_WebSocket_Connect::ID, ¶ms, &msg)); |
| + |
| + ResourceMessageReplyParams connect_reply_params(params.pp_resource(), |
| + params.sequence()); |
| + connect_reply_params.set_result(PP_OK); |
| + ASSERT_TRUE(plugin_dispatcher()->OnMessageReceived( |
| + PpapiPluginMsg_ResourceReply(connect_reply_params, |
| + PpapiPluginMsg_WebSocket_ConnectReply(url, std::string())))); |
| + |
| + EXPECT_EQ(PP_OK, g_callback_result); |
| + EXPECT_EQ(true, g_callback_called); |
| + |
| + PP_Var message; |
| + result = websocket_iface->ReceiveMessage(res, &message, MakeCallback()); |
| + EXPECT_EQ(false, g_callback_called); |
| + |
| + // Synthesize a WebSocket_ErrorReply message. |
| + ResourceMessageReplyParams error_reply_params(res, 0); |
| + error_reply_params.set_result(PP_OK); |
| + ASSERT_TRUE(plugin_dispatcher()->OnMessageReceived( |
| + PpapiPluginMsg_ResourceReply(error_reply_params, |
| + PpapiPluginMsg_WebSocket_ErrorReply()))); |
| + |
| + EXPECT_EQ(PP_ERROR_FAILED, g_callback_result); |
| + EXPECT_EQ(true, g_callback_called); |
| +} |
| + |
| +} // namespace proxy |
| +} // namespace ppapi |