Index: mojo/android/javatests/src/org/chromium/mojo/bindings/RouterTest.java |
diff --git a/mojo/android/javatests/src/org/chromium/mojo/bindings/RouterTest.java b/mojo/android/javatests/src/org/chromium/mojo/bindings/RouterTest.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..58d3c719e06205bf10c48f6547e760ac526d1662 |
--- /dev/null |
+++ b/mojo/android/javatests/src/org/chromium/mojo/bindings/RouterTest.java |
@@ -0,0 +1,134 @@ |
+// Copyright 2014 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. |
+ |
+package org.chromium.mojo.bindings; |
+ |
+import android.test.suitebuilder.annotation.SmallTest; |
+ |
+import org.chromium.mojo.MojoTestCase; |
+import org.chromium.mojo.bindings.BindingsTestUtils.CapturingErrorHandler; |
+import org.chromium.mojo.bindings.BindingsTestUtils.RecordingMessageReceiverWithResponder; |
+import org.chromium.mojo.system.Core; |
+import org.chromium.mojo.system.Handle; |
+import org.chromium.mojo.system.MessagePipeHandle; |
+import org.chromium.mojo.system.MojoResult; |
+import org.chromium.mojo.system.Pair; |
+import org.chromium.mojo.system.impl.CoreImpl; |
+ |
+import java.nio.ByteBuffer; |
+import java.util.ArrayList; |
+ |
+/** |
+ * Testing {@link Router} |
+ */ |
+public class RouterTest extends MojoTestCase { |
+ |
+ private static final long RUN_LOOP_TIMEOUT_MS = 25; |
+ |
+ private MessagePipeHandle mHandle; |
+ private Router mRouter; |
+ private RecordingMessageReceiverWithResponder mReceiver; |
+ private CapturingErrorHandler mErrorHandler; |
+ |
+ /** |
+ * @see MojoTestCase#setUp() |
+ */ |
+ @Override |
+ protected void setUp() throws Exception { |
+ super.setUp(); |
+ Core core = CoreImpl.getInstance(); |
+ Pair<MessagePipeHandle, MessagePipeHandle> handles = core.createMessagePipe(null); |
+ mHandle = handles.first; |
+ mRouter = new RouterImpl(handles.second); |
+ mReceiver = new RecordingMessageReceiverWithResponder(); |
+ mRouter.setIncomingMessageReceiver(mReceiver); |
+ mErrorHandler = new CapturingErrorHandler(); |
+ mRouter.setErrorHandler(mErrorHandler); |
+ mRouter.start(); |
+ } |
+ |
+ /** |
+ * Testing sending a message via the router that expected a response. |
+ */ |
+ @SmallTest |
+ public void testSendingToRouterWithResponse() { |
+ final int requestMessageType = 0xdead; |
+ final int responseMessageType = 0xbeaf; |
+ |
+ // Sending a message expecting a response. |
+ MessageHeader header = new MessageHeader(requestMessageType, |
+ MessageHeader.MESSAGE_EXPECTS_RESPONSE_FLAG, 0); |
+ Encoder encoder = new Encoder(CoreImpl.getInstance(), header.getSize()); |
+ header.encode(encoder); |
+ MessageWithHeader headerMessage = new MessageWithHeader(encoder.getMessage()); |
+ mRouter.acceptWithResponder(headerMessage, mReceiver); |
+ ByteBuffer receiveBuffer = ByteBuffer.allocateDirect(header.getSize()); |
+ MessagePipeHandle.ReadMessageResult result = mHandle.readMessage(receiveBuffer, 0, |
+ MessagePipeHandle.ReadFlags.NONE); |
+ |
+ assertEquals(MojoResult.OK, result.getMojoResult()); |
+ MessageHeader receivedHeader = new MessageWithHeader( |
+ new Message(receiveBuffer, new ArrayList<Handle>())) |
+ .getHeader(); |
+ |
+ assertEquals(header.getType(), receivedHeader.getType()); |
+ assertEquals(header.getFlags(), receivedHeader.getFlags()); |
+ assertTrue(receivedHeader.getRequestId() != 0); |
+ |
+ // Sending the response. |
+ MessageHeader responseHeader = new MessageHeader(responseMessageType, |
+ MessageHeader.MESSAGE_IS_RESPONSE_FLAG, receivedHeader.getRequestId()); |
+ encoder = new Encoder(CoreImpl.getInstance(), header.getSize()); |
+ responseHeader.encode(encoder); |
+ Message responseMessage = encoder.getMessage(); |
+ mHandle.writeMessage(responseMessage.buffer, new ArrayList<Handle>(), |
+ MessagePipeHandle.WriteFlags.NONE); |
+ nativeRunLoop(RUN_LOOP_TIMEOUT_MS); |
+ |
+ assertEquals(1, mReceiver.messages.size()); |
+ MessageWithHeader receivedResponseMessage = mReceiver.messages.get(0); |
+ assertEquals(MessageHeader.MESSAGE_IS_RESPONSE_FLAG, |
+ receivedResponseMessage.getHeader().getFlags()); |
+ assertEquals(responseMessage.buffer, receivedResponseMessage.getMessage().buffer); |
+ } |
+ |
+ /** |
+ * Testing receiving a message via the router that expected a response. |
+ */ |
+ @SmallTest |
+ public void testReceivingViaRouterWithResponse() { |
+ final int requestMessageType = 0xdead; |
+ final int responseMessageType = 0xbeef; |
+ final int requestId = 0xdeadbeaf; |
+ |
+ // Sending a message expecting a response. |
+ MessageHeader header = new MessageHeader(requestMessageType, |
+ MessageHeader.MESSAGE_EXPECTS_RESPONSE_FLAG, requestId); |
+ Encoder encoder = new Encoder(CoreImpl.getInstance(), header.getSize()); |
+ header.encode(encoder); |
+ Message headerMessage = encoder.getMessage(); |
+ mHandle.writeMessage(headerMessage.buffer, new ArrayList<Handle>(), |
+ MessagePipeHandle.WriteFlags.NONE); |
+ nativeRunLoop(RUN_LOOP_TIMEOUT_MS); |
+ |
+ assertEquals(1, mReceiver.messagesWithReceivers.size()); |
+ Pair<MessageWithHeader, MessageReceiver> receivedMessage = |
+ mReceiver.messagesWithReceivers.get(0); |
+ assertEquals(headerMessage.buffer, receivedMessage.first.getMessage().buffer); |
+ |
+ // Sending the response. |
+ MessageHeader responseHeader = new MessageHeader(responseMessageType, |
+ MessageHeader.MESSAGE_EXPECTS_RESPONSE_FLAG, requestId); |
+ encoder = new Encoder(CoreImpl.getInstance(), header.getSize()); |
+ responseHeader.encode(encoder); |
+ MessageWithHeader responseHeaderMessage = new MessageWithHeader(encoder.getMessage()); |
+ receivedMessage.second.accept(responseHeaderMessage); |
+ ByteBuffer receivedResponseMessage = ByteBuffer.allocateDirect(responseHeader.getSize()); |
+ MessagePipeHandle.ReadMessageResult result = mHandle.readMessage(receivedResponseMessage, 0, |
+ MessagePipeHandle.ReadFlags.NONE); |
+ |
+ assertEquals(MojoResult.OK, result.getMojoResult()); |
+ assertEquals(responseHeaderMessage.getMessage().buffer, receivedResponseMessage); |
+ } |
+} |