| 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);
|
| +}
|
|
|