| 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..61e892520fee19687e7c136a9b7127a4a289796f
|
| --- /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());
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +
|
| +// 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
|
|
|