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

Unified Diff: mojo/public/tests/bindings_connector_unittest.cc

Issue 134823005: Mojo: re-organize public tests (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 11 months 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
« no previous file with comments | « mojo/public/tests/bindings_array_unittest.cc ('k') | mojo/public/tests/bindings_handle_passing_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mojo/public/tests/bindings_connector_unittest.cc
diff --git a/mojo/public/tests/bindings_connector_unittest.cc b/mojo/public/tests/bindings_connector_unittest.cc
deleted file mode 100644
index a20190e8a3c835006dec257805fd68a1d2010297..0000000000000000000000000000000000000000
--- a/mojo/public/tests/bindings_connector_unittest.cc
+++ /dev/null
@@ -1,234 +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 <stdlib.h>
-#include <string.h>
-
-#include "mojo/public/bindings/lib/bindings_support.h"
-#include "mojo/public/bindings/lib/connector.h"
-#include "mojo/public/bindings/lib/message_queue.h"
-#include "mojo/public/system/macros.h"
-#include "mojo/public/tests/simple_bindings_support.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace mojo {
-namespace test {
-
-class MessageAccumulator : public MessageReceiver {
- public:
- MessageAccumulator() {
- }
-
- virtual bool Accept(Message* message) MOJO_OVERRIDE {
- queue_.Push(message);
- return true;
- }
-
- bool IsEmpty() const {
- return queue_.IsEmpty();
- }
-
- void Pop(Message* message) {
- queue_.Pop(message);
- }
-
- private:
- MessageQueue queue_;
-};
-
-class BindingsConnectorTest : public testing::Test {
- public:
- BindingsConnectorTest() {
- }
-
- virtual void SetUp() MOJO_OVERRIDE {
- CreateMessagePipe(&handle0_, &handle1_);
- }
-
- virtual void TearDown() MOJO_OVERRIDE {
- }
-
- void AllocMessage(const char* text, Message* message) {
- size_t payload_size = strlen(text) + 1; // Plus null terminator.
- size_t num_bytes = sizeof(MessageHeader) + payload_size;
- message->data = static_cast<MessageData*>(malloc(num_bytes));
- message->data->header.num_bytes = static_cast<uint32_t>(num_bytes);
- message->data->header.name = 1;
- memcpy(message->data->payload, text, payload_size);
- }
-
- void PumpMessages() {
- bindings_support_.Process();
- }
-
- protected:
- ScopedMessagePipeHandle handle0_;
- ScopedMessagePipeHandle handle1_;
-
- private:
- SimpleBindingsSupport bindings_support_;
-};
-
-TEST_F(BindingsConnectorTest, Basic) {
- internal::Connector connector0(handle0_.Pass());
- internal::Connector connector1(handle1_.Pass());
-
- const char kText[] = "hello world";
-
- Message message;
- AllocMessage(kText, &message);
-
- connector0.Accept(&message);
-
- MessageAccumulator accumulator;
- connector1.SetIncomingReceiver(&accumulator);
-
- PumpMessages();
-
- ASSERT_FALSE(accumulator.IsEmpty());
-
- Message message_received;
- accumulator.Pop(&message_received);
-
- EXPECT_EQ(std::string(kText),
- std::string(
- reinterpret_cast<char*>(message_received.data->payload)));
-}
-
-TEST_F(BindingsConnectorTest, Basic_EarlyIncomingReceiver) {
- internal::Connector connector0(handle0_.Pass());
- internal::Connector connector1(handle1_.Pass());
-
- MessageAccumulator accumulator;
- connector1.SetIncomingReceiver(&accumulator);
-
- const char kText[] = "hello world";
-
- Message message;
- AllocMessage(kText, &message);
-
- connector0.Accept(&message);
-
- PumpMessages();
-
- ASSERT_FALSE(accumulator.IsEmpty());
-
- Message message_received;
- accumulator.Pop(&message_received);
-
- EXPECT_EQ(std::string(kText),
- std::string(
- reinterpret_cast<char*>(message_received.data->payload)));
-}
-
-TEST_F(BindingsConnectorTest, Basic_TwoMessages) {
- internal::Connector connector0(handle0_.Pass());
- internal::Connector connector1(handle1_.Pass());
-
- const char* kText[] = { "hello", "world" };
-
- for (size_t i = 0; i < MOJO_ARRAYSIZE(kText); ++i) {
- Message message;
- AllocMessage(kText[i], &message);
-
- connector0.Accept(&message);
- }
-
- MessageAccumulator accumulator;
- connector1.SetIncomingReceiver(&accumulator);
-
- PumpMessages();
-
- for (size_t i = 0; i < MOJO_ARRAYSIZE(kText); ++i) {
- ASSERT_FALSE(accumulator.IsEmpty());
-
- Message message_received;
- accumulator.Pop(&message_received);
-
- EXPECT_EQ(std::string(kText[i]),
- std::string(
- reinterpret_cast<char*>(message_received.data->payload)));
- }
-}
-
-TEST_F(BindingsConnectorTest, WriteToClosedPipe) {
- // Leak this, so the closed handle isn't closed again.
- MojoHandle mojo_handle = handle0_.get().value();
- internal::Connector* connector0 = new internal::Connector(handle0_.Pass());
-
- const char kText[] = "hello world";
-
- Message message;
- AllocMessage(kText, &message);
-
- // Close handle out from under the connection
- MojoClose(mojo_handle);
-
- bool ok = connector0->Accept(&message);
- EXPECT_FALSE(ok);
-
- EXPECT_TRUE(connector0->encountered_error());
-}
-
-// Enable this test once MojoWriteMessage supports passing handles.
-TEST_F(BindingsConnectorTest, MessageWithHandles) {
- internal::Connector connector0(handle0_.Pass());
- internal::Connector connector1(handle1_.Pass());
-
- const char kText[] = "hello world";
-
- Message message;
- AllocMessage(kText, &message);
-
- ScopedMessagePipeHandle handles[2];
- CreateMessagePipe(&handles[0], &handles[1]);
- message.handles.push_back(handles[0].release());
-
- connector0.Accept(&message);
-
- // The message should have been transferred, releasing the handles.
- EXPECT_TRUE(message.handles.empty());
-
- MessageAccumulator accumulator;
- connector1.SetIncomingReceiver(&accumulator);
-
- PumpMessages();
-
- ASSERT_FALSE(accumulator.IsEmpty());
-
- Message message_received;
- accumulator.Pop(&message_received);
-
- EXPECT_EQ(std::string(kText),
- std::string(
- reinterpret_cast<char*>(message_received.data->payload)));
- ASSERT_EQ(1U, message_received.handles.size());
-
- // Now send a message to the transferred handle and confirm it's sent through
- // to the orginal pipe.
- // TODO(vtl): Do we need a better way of "downcasting" the handle types?
- ScopedMessagePipeHandle smph;
- smph.reset(MessagePipeHandle(message_received.handles[0].value()));
- message_received.handles[0] = Handle(); // |smph| now owns this handle.
-
- internal::Connector connector_received(smph.Pass());
- internal::Connector connector_original(handles[1].Pass());
-
- AllocMessage(kText, &message);
-
- connector_received.Accept(&message);
- connector_original.SetIncomingReceiver(&accumulator);
- PumpMessages();
-
- ASSERT_FALSE(accumulator.IsEmpty());
-
- accumulator.Pop(&message_received);
-
- EXPECT_EQ(std::string(kText),
- std::string(
- reinterpret_cast<char*>(message_received.data->payload)));
-}
-
-} // namespace test
-} // namespace mojo
« no previous file with comments | « mojo/public/tests/bindings_array_unittest.cc ('k') | mojo/public/tests/bindings_handle_passing_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698