Index: mojo/services/network/udp_socket_unittest.cc |
diff --git a/mojo/services/network/udp_socket_unittest.cc b/mojo/services/network/udp_socket_unittest.cc |
index 46c443a7ee7806d1f1cf1ae874ad3dd7c0f3580f..5aae6145278ade7745b34648a4c5d64daa85a85d 100644 |
--- a/mojo/services/network/udp_socket_unittest.cc |
+++ b/mojo/services/network/udp_socket_unittest.cc |
@@ -6,6 +6,7 @@ |
#include "base/macros.h" |
#include "base/memory/scoped_ptr.h" |
#include "mojo/public/cpp/bindings/callback.h" |
+#include "mojo/services/public/cpp/network/udp_socket_wrapper.h" |
#include "mojo/services/public/interfaces/network/network_service.mojom.h" |
#include "mojo/services/public/interfaces/network/udp_socket.mojom.h" |
#include "mojo/shell/shell_test_helper.h" |
@@ -38,24 +39,6 @@ Array<uint8_t> CreateTestMessage(uint8_t initial, size_t size) { |
return array.Pass(); |
} |
-bool AreEqualArrays(const Array<uint8_t>& array_1, |
- const Array<uint8_t>& array_2) { |
- if (array_1.is_null() != array_2.is_null()) |
- return false; |
- else if (array_1.is_null()) |
- return true; |
- |
- if (array_1.size() != array_2.size()) |
- return false; |
- |
- for (size_t i = 0; i < array_1.size(); ++i) { |
- if (array_1[i] != array_2[i]) |
- return false; |
- } |
- |
- return true; |
-} |
- |
template <typename CallbackType> |
class TestCallbackBase { |
public: |
@@ -80,7 +63,7 @@ class TestCallbackBase { |
protected: |
struct StateBase : public CallbackType::Runnable { |
StateBase() : test_callback_(nullptr) {} |
- virtual ~StateBase() {} |
+ ~StateBase() override {} |
void set_test_callback(TestCallbackBase* test_callback) { |
test_callback_ = test_callback; |
@@ -131,9 +114,9 @@ class TestCallback : public TestCallbackBase<Callback<void(NetworkErrorPtr)>> { |
private: |
struct State: public StateBase { |
- virtual ~State() {} |
+ ~State() override {} |
- virtual void Run(NetworkErrorPtr result) const override { |
+ void Run(NetworkErrorPtr result) const override { |
if (test_callback_) { |
TestCallback* callback = static_cast<TestCallback*>(test_callback_); |
callback->result_ = result.Pass(); |
@@ -158,10 +141,9 @@ class TestCallbackWithAddress |
private: |
struct State : public StateBase { |
- virtual ~State() {} |
+ ~State() override {} |
- virtual void Run(NetworkErrorPtr result, |
- NetAddressPtr net_address) const override { |
+ void Run(NetworkErrorPtr result, NetAddressPtr net_address) const override { |
if (test_callback_) { |
TestCallbackWithAddress* callback = |
static_cast<TestCallbackWithAddress*>(test_callback_); |
@@ -188,9 +170,9 @@ class TestCallbackWithUint32 |
private: |
struct State : public StateBase { |
- virtual ~State() {} |
+ ~State() override {} |
- virtual void Run(uint32_t result) const override { |
+ void Run(uint32_t result) const override { |
if (test_callback_) { |
TestCallbackWithUint32* callback = |
static_cast<TestCallbackWithUint32*>(test_callback_); |
@@ -203,12 +185,48 @@ class TestCallbackWithUint32 |
uint32_t result_; |
}; |
+class TestReceiveCallback |
+ : public TestCallbackBase< |
+ Callback<void(NetworkErrorPtr, NetAddressPtr, Array<uint8_t>)>> { |
+ public: |
+ TestReceiveCallback() { |
+ Initialize(new State()); |
+ } |
+ ~TestReceiveCallback() {} |
+ |
+ const NetworkErrorPtr& result() const { return result_; } |
+ const NetAddressPtr& src_addr() const { return src_addr_; } |
+ const Array<uint8_t>& data() const { return data_; } |
+ |
+ private: |
+ struct State : public StateBase { |
+ ~State() override {} |
+ |
+ void Run(NetworkErrorPtr result, |
+ NetAddressPtr src_addr, |
+ Array<uint8_t> data) const override { |
+ if (test_callback_) { |
+ TestReceiveCallback* callback = |
+ static_cast<TestReceiveCallback*>(test_callback_); |
+ callback->result_ = result.Pass(); |
+ callback->src_addr_ = src_addr.Pass(); |
+ callback->data_ = data.Pass(); |
+ } |
+ NotifyRun(); |
+ } |
+ }; |
+ |
+ NetworkErrorPtr result_; |
+ NetAddressPtr src_addr_; |
+ Array<uint8_t> data_; |
+}; |
+ |
class UDPSocketTest : public testing::Test { |
public: |
UDPSocketTest() {} |
- virtual ~UDPSocketTest() {} |
+ ~UDPSocketTest() override {} |
- virtual void SetUp() override { |
+ void SetUp() override { |
test_helper_.Init(); |
test_helper_.application_manager()->ConnectToService( |
@@ -230,16 +248,16 @@ class UDPSocketTest : public testing::Test { |
UDPSocketClientImpl() : run_loop_(nullptr), expected_receive_count_(0) {} |
- virtual ~UDPSocketClientImpl() { |
+ ~UDPSocketClientImpl() override { |
while (!results_.empty()) { |
delete results_.front(); |
results_.pop(); |
} |
} |
- virtual void OnReceived(NetworkErrorPtr result, |
- NetAddressPtr src_addr, |
- Array<uint8_t> data) override { |
+ void OnReceived(NetworkErrorPtr result, |
+ NetAddressPtr src_addr, |
+ Array<uint8_t> data) override { |
ReceiveResult* entry = new ReceiveResult(); |
entry->result = result.Pass(); |
entry->addr = src_addr.Pass(); |
@@ -356,6 +374,8 @@ TEST_F(UDPSocketTest, TestReadWrite) { |
ASSERT_EQ(net::OK, callback2.result()->code); |
ASSERT_NE(0u, callback2.net_address()->ipv4->port); |
+ NetAddressPtr client_addr = callback2.net_address().Clone(); |
+ |
const size_t kDatagramCount = 6; |
const size_t kDatagramSize = 255; |
udp_socket_->ReceiveMore(kDatagramCount); |
@@ -376,9 +396,61 @@ TEST_F(UDPSocketTest, TestReadWrite) { |
GetReceiveResults()->pop(); |
EXPECT_EQ(static_cast<int>(kDatagramSize), result->result->code); |
- EXPECT_TRUE(AreEqualArrays( |
- CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize), |
- result->data)); |
+ EXPECT_TRUE(result->addr.Equals(client_addr)); |
+ EXPECT_TRUE(result->data.Equals( |
+ CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize))); |
+ } |
+} |
+ |
+TEST_F(UDPSocketTest, TestUDPSocketWrapper) { |
+ UDPSocketWrapper udp_socket(udp_socket_.Pass(), 4, 4); |
+ |
+ TestCallbackWithAddress callback1; |
+ udp_socket.Bind(GetLocalHostWithAnyPort(), callback1.callback()); |
+ callback1.WaitForResult(); |
+ ASSERT_EQ(net::OK, callback1.result()->code); |
+ ASSERT_NE(0u, callback1.net_address()->ipv4->port); |
+ |
+ NetAddressPtr server_addr = callback1.net_address().Clone(); |
+ |
+ UDPSocketPtr raw_client_socket; |
+ network_service_->CreateUDPSocket(GetProxy(&raw_client_socket)); |
+ UDPSocketWrapper client_socket(raw_client_socket.Pass(), 4, 4); |
+ |
+ TestCallbackWithAddress callback2; |
+ client_socket.Bind(GetLocalHostWithAnyPort(), callback2.callback()); |
+ callback2.WaitForResult(); |
+ ASSERT_EQ(net::OK, callback2.result()->code); |
+ ASSERT_NE(0u, callback2.net_address()->ipv4->port); |
+ |
+ NetAddressPtr client_addr = callback2.net_address().Clone(); |
+ |
+ const size_t kDatagramCount = 16; |
+ const size_t kDatagramSize = 255; |
+ |
+ for (size_t i = 1; i < kDatagramCount; ++i) { |
+ scoped_ptr<TestCallback[]> send_callbacks(new TestCallback[i]); |
+ scoped_ptr<TestReceiveCallback[]> receive_callbacks( |
+ new TestReceiveCallback[i]); |
+ |
+ for (size_t j = 0; j < i; ++j) { |
+ client_socket.SendTo( |
+ server_addr.Clone(), |
+ CreateTestMessage(static_cast<uint8_t>(j), kDatagramSize), |
+ send_callbacks[j].callback()); |
+ |
+ udp_socket.ReceiveFrom(receive_callbacks[j].callback()); |
+ } |
+ |
+ receive_callbacks[i - 1].WaitForResult(); |
+ |
+ for (size_t j = 0; j < i; ++j) { |
+ EXPECT_EQ(static_cast<int>(kDatagramSize), |
+ receive_callbacks[j].result()->code); |
+ EXPECT_TRUE(receive_callbacks[j].src_addr().Equals(client_addr)); |
+ EXPECT_TRUE(receive_callbacks[j].data().Equals( |
+ CreateTestMessage(static_cast<uint8_t>(j), kDatagramSize))); |
+ } |
} |
} |