diff options
author | dmikurube@chromium.org <dmikurube@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-11 06:16:57 +0000 |
---|---|---|
committer | dmikurube@chromium.org <dmikurube@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-11 06:16:57 +0000 |
commit | 081ace94bb3e5f46908dda4e6a15d70334666f0d (patch) | |
tree | 9d75a72b60df319f2d0c2c8885766989f3ddd0b7 /ipc/unix_domain_socket_util_unittest.cc | |
parent | 9fe646539615b7ecadaa94d325949567b56d9830 (diff) | |
download | chromium_src-081ace94bb3e5f46908dda4e6a15d70334666f0d.zip chromium_src-081ace94bb3e5f46908dda4e6a15d70334666f0d.tar.gz chromium_src-081ace94bb3e5f46908dda4e6a15d70334666f0d.tar.bz2 |
Revert 187233
> Implement IPC::ChannelFactory, a class that accept()s on a UNIX socket.
>
> IPC::ChannelFactory listens on a UNIX domain socket and notifies its delegate
> when a client connects. The delegate is expected to craft an IPC::Channel from
> the handle it is given.
>
> Committed: https://src.chromium.org/viewvc/chrome?view=rev&revision=186912
>
> Review URL: https://chromiumcodereview.appspot.com/12386010
TBR=jeremya@chromium.org
Review URL: https://codereview.chromium.org/12761003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@187240 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ipc/unix_domain_socket_util_unittest.cc')
-rw-r--r-- | ipc/unix_domain_socket_util_unittest.cc | 178 |
1 files changed, 0 insertions, 178 deletions
diff --git a/ipc/unix_domain_socket_util_unittest.cc b/ipc/unix_domain_socket_util_unittest.cc deleted file mode 100644 index 58744dc..0000000 --- a/ipc/unix_domain_socket_util_unittest.cc +++ /dev/null @@ -1,178 +0,0 @@ -// Copyright 2013 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 <sys/socket.h> - -#include "base/bind.h" -#include "base/file_util.h" -#include "base/files/file_path.h" -#include "base/path_service.h" -#include "base/synchronization/waitable_event.h" -#include "base/threading/thread.h" -#include "base/threading/thread_restrictions.h" -#include "ipc/unix_domain_socket_util.h" -#include "testing/gtest/include/gtest/gtest.h" - -namespace { - -class SocketAcceptor : public MessageLoopForIO::Watcher { - public: - SocketAcceptor(int fd, base::MessageLoopProxy* target_thread) - : server_fd_(-1), - target_thread_(target_thread), - started_watching_event_(false, false), - accepted_event_(false, false) { - target_thread->PostTask(FROM_HERE, - base::Bind(&SocketAcceptor::StartWatching, base::Unretained(this), fd)); - } - - virtual ~SocketAcceptor() { - Close(); - } - - int server_fd() const { return server_fd_; } - - void WaitUntilReady() { - started_watching_event_.Wait(); - } - void WaitForAccept() { - accepted_event_.Wait(); - } - - void Close() { - if (watcher_.get()) { - target_thread_->PostTask(FROM_HERE, - base::Bind(&SocketAcceptor::StopWatching, base::Unretained(this), - watcher_.release())); - } - } - - private: - void StartWatching(int fd) { - watcher_.reset(new MessageLoopForIO::FileDescriptorWatcher); - MessageLoopForIO::current()->WatchFileDescriptor( - fd, - true, - MessageLoopForIO::WATCH_READ, - watcher_.get(), - this); - started_watching_event_.Signal(); - } - void StopWatching(MessageLoopForIO::FileDescriptorWatcher* watcher) { - watcher->StopWatchingFileDescriptor(); - delete watcher; - } - virtual void OnFileCanReadWithoutBlocking(int fd) OVERRIDE { - ASSERT_EQ(-1, server_fd_); - IPC::ServerAcceptConnection(fd, &server_fd_); - watcher_->StopWatchingFileDescriptor(); - accepted_event_.Signal(); - } - virtual void OnFileCanWriteWithoutBlocking(int fd) OVERRIDE {} - - int server_fd_; - base::MessageLoopProxy* target_thread_; - scoped_ptr<MessageLoopForIO::FileDescriptorWatcher> watcher_; - base::WaitableEvent started_watching_event_; - base::WaitableEvent accepted_event_; - - DISALLOW_COPY_AND_ASSIGN(SocketAcceptor); -}; - -const base::FilePath GetChannelDir() { -#if defined(OS_ANDROID) - base::FilePath tmp_dir; - PathService::Get(base::DIR_CACHE, &tmp_dir); - return tmp_dir; -#else - return base::FilePath("/var/tmp"); -#endif -} - -class TestUnixSocketConnection { - public: - TestUnixSocketConnection() - : worker_("WorkerThread"), - server_listen_fd_(-1), - server_fd_(-1), - client_fd_(-1) { - socket_name_ = GetChannelDir().Append("TestSocket"); - base::Thread::Options options; - options.message_loop_type = MessageLoop::TYPE_IO; - worker_.StartWithOptions(options); - } - - bool CreateServerSocket() { - IPC::CreateServerUnixDomainSocket(socket_name_, &server_listen_fd_); - if (server_listen_fd_ < 0) - return false; - struct stat socket_stat; - stat(socket_name_.value().c_str(), &socket_stat); - EXPECT_TRUE(S_ISSOCK(socket_stat.st_mode)); - acceptor_.reset(new SocketAcceptor(server_listen_fd_, - worker_.message_loop_proxy())); - acceptor_->WaitUntilReady(); - return true; - } - - bool CreateClientSocket() { - DCHECK(server_listen_fd_ >= 0); - IPC::CreateClientUnixDomainSocket(socket_name_, &client_fd_); - if (client_fd_ < 0) - return false; - acceptor_->WaitForAccept(); - server_fd_ = acceptor_->server_fd(); - return server_fd_ >= 0; - } - - virtual ~TestUnixSocketConnection() { - if (client_fd_ >= 0) - close(client_fd_); - if (server_fd_ >= 0) - close(server_fd_); - if (server_listen_fd_ >= 0) { - close(server_listen_fd_); - unlink(socket_name_.value().c_str()); - } - } - - int client_fd() const { return client_fd_; } - int server_fd() const { return server_fd_; } - - private: - base::Thread worker_; - base::FilePath socket_name_; - int server_listen_fd_; - int server_fd_; - int client_fd_; - scoped_ptr<SocketAcceptor> acceptor_; -}; - -// Ensure that IPC::CreateServerUnixDomainSocket creates a socket that -// IPC::CreateClientUnixDomainSocket can successfully connect to. -TEST(UnixDomainSocketUtil, Connect) { - TestUnixSocketConnection connection; - ASSERT_TRUE(connection.CreateServerSocket()); - ASSERT_TRUE(connection.CreateClientSocket()); -} - -// Ensure that messages can be sent across the resulting socket. -TEST(UnixDomainSocketUtil, SendReceive) { - TestUnixSocketConnection connection; - ASSERT_TRUE(connection.CreateServerSocket()); - ASSERT_TRUE(connection.CreateClientSocket()); - - const char buffer[] = "Hello, server!"; - size_t buf_len = sizeof(buffer); - size_t sent_bytes = - HANDLE_EINTR(send(connection.client_fd(), buffer, buf_len, 0)); - ASSERT_EQ(buf_len, sent_bytes); - char recv_buf[sizeof(buffer)]; - size_t received_bytes = - HANDLE_EINTR(recv(connection.server_fd(), recv_buf, buf_len, 0)); - ASSERT_EQ(buf_len, received_bytes); - ASSERT_EQ(0, memcmp(recv_buf, buffer, buf_len)); -} - -} // namespace |