blob: c962f303d7b433c67c99fbcc1b1f9d8135fb835e [file] [log] [blame]
David Pursellc3a46692016-01-29 08:10:50 -08001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28
29#include "socket_mock.h"
30
31#include <gtest/gtest.h>
32
33SocketMock::SocketMock() : Socket(INVALID_SOCKET) {}
34
35SocketMock::~SocketMock() {
36 if (!events_.empty()) {
37 ADD_FAILURE() << events_.size() << " event(s) were not handled";
38 }
39}
40
David Pursellb34e4a02016-02-01 09:42:09 -080041bool SocketMock::Send(const void* data, size_t length) {
David Pursellc3a46692016-01-29 08:10:50 -080042 if (events_.empty()) {
43 ADD_FAILURE() << "Send() was called when no message was expected";
David Pursellb34e4a02016-02-01 09:42:09 -080044 return false;
David Pursellc3a46692016-01-29 08:10:50 -080045 }
46
47 if (events_.front().type != EventType::kSend) {
48 ADD_FAILURE() << "Send() was called out-of-order";
David Pursellb34e4a02016-02-01 09:42:09 -080049 return false;
David Pursellc3a46692016-01-29 08:10:50 -080050 }
51
52 std::string message(reinterpret_cast<const char*>(data), length);
53 if (events_.front().message != message) {
54 ADD_FAILURE() << "Send() expected " << events_.front().message << ", but got " << message;
David Pursellb34e4a02016-02-01 09:42:09 -080055 return false;
David Pursellc3a46692016-01-29 08:10:50 -080056 }
57
David Pursell2c094f72016-02-03 10:23:05 -080058 bool return_value = events_.front().return_value;
David Pursellc3a46692016-01-29 08:10:50 -080059 events_.pop();
David Pursell2c094f72016-02-03 10:23:05 -080060 return return_value;
David Pursellb34e4a02016-02-01 09:42:09 -080061}
62
63// Mock out multi-buffer send to be one large send, since that's what it should looks like from
64// the user's perspective.
65bool SocketMock::Send(std::vector<cutils_socket_buffer_t> buffers) {
66 std::string data;
67 for (const auto& buffer : buffers) {
68 data.append(reinterpret_cast<const char*>(buffer.data), buffer.length);
69 }
70 return Send(data.data(), data.size());
David Pursellc3a46692016-01-29 08:10:50 -080071}
72
73ssize_t SocketMock::Receive(void* data, size_t length, int /*timeout_ms*/) {
74 if (events_.empty()) {
75 ADD_FAILURE() << "Receive() was called when no message was ready";
76 return -1;
77 }
78
79 if (events_.front().type != EventType::kReceive) {
80 ADD_FAILURE() << "Receive() was called out-of-order";
81 return -1;
82 }
83
84 if (events_.front().return_value > static_cast<ssize_t>(length)) {
85 ADD_FAILURE() << "Receive(): not enough bytes (" << length << ") for "
86 << events_.front().message;
87 return -1;
88 }
89
90 ssize_t return_value = events_.front().return_value;
91 if (return_value > 0) {
92 memcpy(data, events_.front().message.data(), return_value);
93 }
94 events_.pop();
95 return return_value;
96}
97
98int SocketMock::Close() {
99 return 0;
100}
101
102std::unique_ptr<Socket> SocketMock::Accept() {
103 if (events_.empty()) {
104 ADD_FAILURE() << "Accept() was called when no socket was ready";
105 return nullptr;
106 }
107
108 if (events_.front().type != EventType::kAccept) {
109 ADD_FAILURE() << "Accept() was called out-of-order";
110 return nullptr;
111 }
112
113 std::unique_ptr<Socket> sock = std::move(events_.front().sock);
114 events_.pop();
115 return sock;
116}
117
118void SocketMock::ExpectSend(std::string message) {
David Pursell2c094f72016-02-03 10:23:05 -0800119 events_.push(Event(EventType::kSend, std::move(message), true, nullptr));
David Pursellc3a46692016-01-29 08:10:50 -0800120}
121
David Pursell2c094f72016-02-03 10:23:05 -0800122void SocketMock::ExpectSendFailure(std::string message) {
123 events_.push(Event(EventType::kSend, std::move(message), false, nullptr));
124}
David Pursellc3a46692016-01-29 08:10:50 -0800125
126void SocketMock::AddReceive(std::string message) {
127 ssize_t return_value = message.length();
128 events_.push(Event(EventType::kReceive, std::move(message), return_value, nullptr));
129}
130
131void SocketMock::AddReceiveFailure() {
132 events_.push(Event(EventType::kReceive, "", -1, nullptr));
133}
134
135void SocketMock::AddAccept(std::unique_ptr<Socket> sock) {
136 events_.push(Event(EventType::kAccept, "", 0, std::move(sock)));
137}
138
139SocketMock::Event::Event(EventType _type, std::string _message, ssize_t _return_value,
140 std::unique_ptr<Socket> _sock)
141 : type(_type), message(_message), return_value(_return_value), sock(std::move(_sock)) {}