summaryrefslogtreecommitdiffstats
path: root/chrome/common/ipc_sync_channel_unittest.cc
diff options
context:
space:
mode:
authordarin@google.com <darin@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-26 07:28:34 +0000
committerdarin@google.com <darin@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-26 07:28:34 +0000
commitdd3eac25b4b1600058cfb88a45fdc3be5dbf52a6 (patch)
treecc7b3346263a97fc3edc901b8a4cfd552a5e7fb2 /chrome/common/ipc_sync_channel_unittest.cc
parent036284dcd16ca460fac90dd9d26b80c32e879b05 (diff)
downloadchromium_src-dd3eac25b4b1600058cfb88a45fdc3be5dbf52a6.zip
chromium_src-dd3eac25b4b1600058cfb88a45fdc3be5dbf52a6.tar.gz
chromium_src-dd3eac25b4b1600058cfb88a45fdc3be5dbf52a6.tar.bz2
fix unit tests
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@1371 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/ipc_sync_channel_unittest.cc')
-rw-r--r--chrome/common/ipc_sync_channel_unittest.cc79
1 files changed, 66 insertions, 13 deletions
diff --git a/chrome/common/ipc_sync_channel_unittest.cc b/chrome/common/ipc_sync_channel_unittest.cc
index 3899204..11ba159 100644
--- a/chrome/common/ipc_sync_channel_unittest.cc
+++ b/chrome/common/ipc_sync_channel_unittest.cc
@@ -28,6 +28,13 @@
using namespace IPC;
+namespace {
+
+class IPCSyncChannelTest : public testing::Test {
+ private:
+ MessageLoop message_loop_;
+};
+
// SyncChannel should only be used in child processes as we don't want to hang
// the browser. So in the unit test we need to have a ChildProcess object.
class TestProcess : public ChildProcess {
@@ -202,8 +209,13 @@ void RunTest(std::vector<Worker*> workers) {
TestProcess::GlobalCleanup();
}
+} // namespace
+
//-----------------------------------------------------------------------------
+
+namespace {
+
class SimpleServer : public Worker {
public:
SimpleServer() : Worker(Channel::MODE_SERVER, "simpler_server") { }
@@ -226,8 +238,10 @@ class SimpleClient : public Worker {
}
};
+} // namespace
+
// Tests basic synchronous call
-TEST(IPCSyncChannelTest, Simple) {
+TEST_F(IPCSyncChannelTest, Simple) {
std::vector<Worker*> workers;
workers.push_back(new SimpleServer());
workers.push_back(new SimpleClient());
@@ -236,6 +250,9 @@ TEST(IPCSyncChannelTest, Simple) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class DelayClient : public Worker {
public:
DelayClient() : Worker(Channel::MODE_CLIENT, "delay_client") { }
@@ -247,8 +264,10 @@ class DelayClient : public Worker {
}
};
+} // namespace
+
// Tests that asynchronous replies work
-TEST(IPCSyncChannelTest, DelayReply) {
+TEST_F(IPCSyncChannelTest, DelayReply) {
std::vector<Worker*> workers;
workers.push_back(new SimpleServer());
workers.push_back(new DelayClient());
@@ -257,6 +276,9 @@ TEST(IPCSyncChannelTest, DelayReply) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class NoHangServer : public Worker {
public:
explicit NoHangServer(Event* got_first_reply)
@@ -296,8 +318,10 @@ class NoHangClient : public Worker {
Event* got_first_reply_;
};
+} // namespace
+
// Tests that caller doesn't hang if receiver dies
-TEST(IPCSyncChannelTest, NoHang) {
+TEST_F(IPCSyncChannelTest, NoHang) {
Event got_first_reply;
std::vector<Worker*> workers;
@@ -308,6 +332,9 @@ TEST(IPCSyncChannelTest, NoHang) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class RecursiveServer : public Worker {
public:
RecursiveServer() : Worker(Channel::MODE_SERVER, "recursive_server") { }
@@ -335,8 +362,10 @@ class RecursiveClient : public Worker {
}
};
+} // namespace
+
// Tests that the caller unblocks to answer a sync message from the receiver.
-TEST(IPCSyncChannelTest, Recursive) {
+TEST_F(IPCSyncChannelTest, Recursive) {
std::vector<Worker*> workers;
workers.push_back(new RecursiveServer());
workers.push_back(new RecursiveClient());
@@ -345,6 +374,9 @@ TEST(IPCSyncChannelTest, Recursive) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class MultipleServer1 : public Worker {
public:
MultipleServer1() : Worker(L"test_channel1", Channel::MODE_SERVER) { }
@@ -406,9 +438,11 @@ class MultipleClient2 : public Worker {
Event *client1_msg_received_, *client1_can_reply_;
};
+} // namespace
+
// Tests that multiple SyncObjects on the same listener thread can unblock each
// other.
-TEST(IPCSyncChannelTest, Multiple) {
+TEST_F(IPCSyncChannelTest, Multiple) {
std::vector<Worker*> workers;
// A shared worker thread so that server1 and server2 run on one thread.
@@ -443,6 +477,9 @@ TEST(IPCSyncChannelTest, Multiple) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class QueuedReplyServer1 : public Worker {
public:
QueuedReplyServer1() : Worker(L"test_channel1", Channel::MODE_SERVER) { }
@@ -511,11 +548,13 @@ class QueuedReplyClient2 : public Worker {
Event *client1_msg_received_;
};
+} // namespace
+
// While a blocking send is in progress, the listener thread might answer other
// synchronous messages. This tests that if during the response to another
// message the reply to the original messages comes, it is queued up correctly
// and the original Send is unblocked later.
-TEST(IPCSyncChannelTest, QueuedReply) {
+TEST_F(IPCSyncChannelTest, QueuedReply) {
std::vector<Worker*> workers;
// A shared worker thread so that server1 and server2 run on one thread.
@@ -546,6 +585,9 @@ TEST(IPCSyncChannelTest, QueuedReply) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class BadServer : public Worker {
public:
BadServer() : Worker(Channel::MODE_SERVER, "simpler_server") { }
@@ -573,8 +615,10 @@ class BadServer : public Worker {
}
};
+} // namespace
+
// Tests that if a message is not serialized correctly, the Send() will fail.
-TEST(IPCSyncChannelTest, BadMessage) {
+TEST_F(IPCSyncChannelTest, BadMessage) {
std::vector<Worker*> workers;
workers.push_back(new BadServer());
workers.push_back(new SimpleClient());
@@ -583,6 +627,9 @@ TEST(IPCSyncChannelTest, BadMessage) {
//-----------------------------------------------------------------------------
+
+namespace {
+
class ChattyRecursiveClient : public Worker {
public:
ChattyRecursiveClient() :
@@ -602,10 +649,12 @@ class ChattyRecursiveClient : public Worker {
}
};
+} // namespace
+
// Tests http://b/issue?id=1093251 - that sending lots of sync messages while
// the receiver is waiting for a sync reply does not overflow the PostMessage
// queue.
-TEST(IPCSyncChannelTest, ChattyServer) {
+TEST_F(IPCSyncChannelTest, ChattyServer) {
std::vector<Worker*> workers;
workers.push_back(new RecursiveServer());
workers.push_back(new ChattyRecursiveClient());
@@ -614,6 +663,9 @@ TEST(IPCSyncChannelTest, ChattyServer) {
//------------------------------------------------------------------------------
+
+namespace {
+
class TimeoutServer : public Worker {
public:
TimeoutServer(int timeout_ms,
@@ -673,9 +725,11 @@ class UnresponsiveClient : public Worker {
std::vector<bool> timeout_seq_;
};
+} // namespace
+
// Tests that SendWithTimeout does not time-out if the response comes back fast
// enough.
-TEST(IPCSyncChannelTest, SendWithTimeoutOK) {
+TEST_F(IPCSyncChannelTest, SendWithTimeoutOK) {
std::vector<Worker*> workers;
std::vector<bool> timeout_seq;
timeout_seq.push_back(false);
@@ -687,7 +741,7 @@ TEST(IPCSyncChannelTest, SendWithTimeoutOK) {
}
// Tests that SendWithTimeout does time-out.
-TEST(IPCSyncChannelTest, SendWithTimeoutTimeout) {
+TEST_F(IPCSyncChannelTest, SendWithTimeoutTimeout) {
std::vector<Worker*> workers;
std::vector<bool> timeout_seq;
timeout_seq.push_back(true);
@@ -699,7 +753,7 @@ TEST(IPCSyncChannelTest, SendWithTimeoutTimeout) {
}
// Sends some message that time-out and some that succeed.
-TEST(IPCSyncChannelTest, SendWithTimeoutMixedOKAndTimeout) {
+TEST_F(IPCSyncChannelTest, SendWithTimeoutMixedOKAndTimeout) {
std::vector<Worker*> workers;
std::vector<bool> timeout_seq;
timeout_seq.push_back(true);
@@ -710,5 +764,4 @@ TEST(IPCSyncChannelTest, SendWithTimeoutMixedOKAndTimeout) {
workers.push_back(new TimeoutServer(100, timeout_seq));
workers.push_back(new UnresponsiveClient(timeout_seq));
RunTest(workers);
-}
-
+} \ No newline at end of file