Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6602)

Unified Diff: chrome/test/chromedriver/net/sync_websocket.cc

Issue 11316115: [chromedriver] Write websocket client and sync websocket client. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/test/chromedriver/net/sync_websocket.cc
diff --git a/chrome/test/chromedriver/net/sync_websocket.cc b/chrome/test/chromedriver/net/sync_websocket.cc
new file mode 100644
index 0000000000000000000000000000000000000000..dadf16c8c30f8cd7089fcd4436a5e721d314f18a
--- /dev/null
+++ b/chrome/test/chromedriver/net/sync_websocket.cc
@@ -0,0 +1,118 @@
+// 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 "chrome/test/chromedriver/net/sync_websocket.h"
+
+#include "base/bind.h"
+#include "base/callback.h"
+#include "base/location.h"
+#include "base/single_thread_task_runner.h"
+#include "base/synchronization/waitable_event.h"
+#include "googleurl/src/gurl.h"
+#include "net/base/net_errors.h"
+#include "net/url_request/url_request_context_getter.h"
+
+SyncWebSocket::SyncWebSocket(
+ net::URLRequestContextGetter* context_getter)
+ : core_(new Core(context_getter)) {}
+
+SyncWebSocket::~SyncWebSocket() {}
+
+bool SyncWebSocket::Connect(const GURL& url) {
+ return core_->Connect(url);
+}
+
+bool SyncWebSocket::Send(const std::string& message) {
+ return core_->Send(message);
+}
+
+bool SyncWebSocket::ReceiveNextMessage(std::string* message) {
+ return core_->ReceiveNextMessage(message);
+}
+
+SyncWebSocket::Core::Core(net::URLRequestContextGetter* context_getter)
+ : context_getter_(context_getter),
+ closed_(false),
+ on_update_event_(&lock_) {}
+
+bool SyncWebSocket::Core::Connect(const GURL& url) {
+ bool success = false;
+ base::WaitableEvent event(false, false);
+ context_getter_->GetNetworkTaskRunner()->PostTask(
+ FROM_HERE,
+ base::Bind(&SyncWebSocket::Core::ConnectOnIO,
+ this, url, &success, &event));
+ event.Wait();
+ return success;
+}
+
+bool SyncWebSocket::Core::Send(const std::string& message) {
+ bool success = false;
+ base::WaitableEvent event(false, false);
+ context_getter_->GetNetworkTaskRunner()->PostTask(
+ FROM_HERE,
+ base::Bind(&SyncWebSocket::Core::SendOnIO,
+ this, message, &success, &event));
+ event.Wait();
+ return success;
+}
+
+bool SyncWebSocket::Core::ReceiveNextMessage(std::string* message) {
+ base::AutoLock lock(lock_);
+ while (received_queue_.empty() && !closed_) on_update_event_.Wait();
+ if (closed_)
+ return false;
+ *message = received_queue_.front();
+ received_queue_.pop_front();
+ return true;
+}
+
+void SyncWebSocket::Core::OnMessageReceived(const std::string& message) {
+ base::AutoLock lock(lock_);
+ received_queue_.push_back(message);
+ on_update_event_.Signal();
+}
+
+void SyncWebSocket::Core::OnClose() {
+ base::AutoLock lock(lock_);
+ closed_ = true;
+ on_update_event_.Signal();
+}
+
+SyncWebSocket::Core::~Core() { }
+
+void SyncWebSocket::Core::ConnectOnIO(
+ const GURL& url,
+ bool* success,
+ base::WaitableEvent* event) {
+ socket_.reset(new WebSocket(context_getter_, url, this));
+ socket_->Connect(base::Bind(
+ &SyncWebSocket::Core::OnConnectCompletedOnIO,
+ this, success, event));
+}
+
+void SyncWebSocket::Core::OnConnectCompletedOnIO(
+ bool* success,
+ base::WaitableEvent* event,
+ int error) {
+ *success = (error == net::OK);
+ event->Signal();
+}
+
+void SyncWebSocket::Core::SendOnIO(
+ const std::string& message,
+ bool* success,
+ base::WaitableEvent* event) {
+ *success = socket_->Send(message);
+ event->Signal();
+}
+
+void SyncWebSocket::Core::OnDestruct() const {
+ scoped_refptr<base::SingleThreadTaskRunner> network_task_runner =
+ context_getter_->GetNetworkTaskRunner();
+ if (network_task_runner->BelongsToCurrentThread())
+ delete this;
+ else
+ network_task_runner->DeleteSoon(FROM_HERE, this);
+}
« no previous file with comments | « chrome/test/chromedriver/net/sync_websocket.h ('k') | chrome/test/chromedriver/net/sync_websocket_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698