2013-07-16 19:02:30 +00:00
|
|
|
/*
|
|
|
|
* synergy -- mouse and keyboard sharing utility
|
2014-11-02 12:12:05 +00:00
|
|
|
* Copyright (C) 2013 Synergy Si Ltd.
|
2013-07-16 19:02:30 +00:00
|
|
|
*
|
|
|
|
* This package is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* found in the file COPYING that should have accompanied this file.
|
|
|
|
*
|
|
|
|
* This package is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2013-09-18 06:52:18 +00:00
|
|
|
// TODO: fix, tests failing intermittently on mac.
|
|
|
|
#ifndef WINAPI_CARBON
|
|
|
|
|
2014-02-28 12:36:45 +00:00
|
|
|
#define TEST_ENV
|
|
|
|
|
|
|
|
#include "test/mock/server/MockConfig.h"
|
|
|
|
#include "test/mock/server/MockPrimaryClient.h"
|
|
|
|
#include "test/mock/synergy/MockScreen.h"
|
|
|
|
#include "test/mock/server/MockInputFilter.h"
|
|
|
|
#include "test/global/TestEventQueue.h"
|
|
|
|
#include "server/Server.h"
|
|
|
|
#include "server/ClientListener.h"
|
|
|
|
#include "client/Client.h"
|
|
|
|
#include "synergy/FileChunker.h"
|
|
|
|
#include "net/SocketMultiplexer.h"
|
|
|
|
#include "net/NetworkAddress.h"
|
|
|
|
#include "net/TCPSocketFactory.h"
|
|
|
|
#include "io/CryptoOptions.h"
|
|
|
|
#include "mt/Thread.h"
|
|
|
|
#include "base/TMethodEventJob.h"
|
|
|
|
#include "base/TMethodJob.h"
|
|
|
|
#include "base/Log.h"
|
2014-03-14 20:33:18 +00:00
|
|
|
#include "common/stdexcept.h"
|
2014-02-28 12:36:45 +00:00
|
|
|
|
2014-02-28 15:04:49 +00:00
|
|
|
#include "test/global/gtest.h"
|
2013-07-24 16:41:12 +00:00
|
|
|
#include <sstream>
|
2013-07-16 19:02:30 +00:00
|
|
|
#include <fstream>
|
2013-07-24 16:41:12 +00:00
|
|
|
#include <iostream>
|
|
|
|
#include <stdio.h>
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
using namespace std;
|
2013-07-16 19:02:30 +00:00
|
|
|
using ::testing::_;
|
2013-07-24 16:41:12 +00:00
|
|
|
using ::testing::NiceMock;
|
2013-07-16 19:02:30 +00:00
|
|
|
using ::testing::Return;
|
|
|
|
using ::testing::Invoke;
|
|
|
|
|
|
|
|
#define TEST_PORT 24803
|
|
|
|
#define TEST_HOST "localhost"
|
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
const size_t kMockDataSize = 1024 * 1024 * 10; // 10MB
|
|
|
|
const UInt16 kMockDataChunkIncrement = 1024; // 1KB
|
|
|
|
const char* kMockFilename = "NetworkTests.mock";
|
|
|
|
const size_t kMockFileSize = 1024 * 1024 * 10; // 10MB
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
void getScreenShape(SInt32& x, SInt32& y, SInt32& w, SInt32& h);
|
|
|
|
void getCursorPos(SInt32& x, SInt32& y);
|
2014-11-11 13:51:47 +00:00
|
|
|
String intToString(size_t i);
|
2013-07-24 16:41:12 +00:00
|
|
|
UInt8* newMockData(size_t size);
|
|
|
|
void createFile(fstream& file, const char* filename, size_t size);
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
class NetworkTests : public ::testing::Test
|
|
|
|
{
|
|
|
|
public:
|
2013-07-24 16:41:12 +00:00
|
|
|
NetworkTests() :
|
|
|
|
m_mockData(NULL),
|
|
|
|
m_mockDataSize(0),
|
|
|
|
m_mockFileSize(0)
|
|
|
|
{
|
|
|
|
m_mockData = newMockData(kMockDataSize);
|
|
|
|
createFile(m_mockFile, kMockFilename, kMockFileSize);
|
|
|
|
}
|
|
|
|
|
|
|
|
~NetworkTests()
|
|
|
|
{
|
|
|
|
remove(kMockFilename);
|
|
|
|
delete[] m_mockData;
|
|
|
|
}
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
void sendMockData(void* eventTarget);
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
void sendToClient_mockData_handleClientConnected(const Event&, void* vlistener);
|
|
|
|
void sendToClient_mockData_fileRecieveCompleted(const Event&, void*);
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
void sendToClient_mockFile_handleClientConnected(const Event&, void* vlistener);
|
|
|
|
void sendToClient_mockFile_fileRecieveCompleted(const Event& event, void*);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
void sendToServer_mockData_handleClientConnected(const Event&, void* vlistener);
|
|
|
|
void sendToServer_mockData_fileRecieveCompleted(const Event& event, void*);
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
void sendToServer_mockFile_handleClientConnected(const Event&, void* vlistener);
|
|
|
|
void sendToServer_mockFile_fileRecieveCompleted(const Event& event, void*);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
2013-07-16 19:02:30 +00:00
|
|
|
public:
|
2014-11-11 13:51:47 +00:00
|
|
|
TestEventQueue m_events;
|
2013-07-24 16:41:12 +00:00
|
|
|
UInt8* m_mockData;
|
|
|
|
size_t m_mockDataSize;
|
|
|
|
fstream m_mockFile;
|
|
|
|
size_t m_mockFileSize;
|
2013-07-16 19:02:30 +00:00
|
|
|
};
|
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
TEST_F(NetworkTests, sendToClient_mockData)
|
|
|
|
{
|
|
|
|
// server and client
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkAddress serverAddress(TEST_HOST, TEST_PORT);
|
|
|
|
CryptoOptions cryptoOptions;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
serverAddress.resolve();
|
|
|
|
|
|
|
|
// server
|
2014-11-11 13:51:47 +00:00
|
|
|
SocketMultiplexer serverSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* serverSocketFactory = new TCPSocketFactory(&m_events, &serverSocketMultiplexer);
|
2015-01-27 11:33:06 +00:00
|
|
|
ClientListener listener(serverAddress, serverSocketFactory, cryptoOptions, &m_events);
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> serverScreen;
|
|
|
|
NiceMock<MockPrimaryClient> primaryClient;
|
|
|
|
NiceMock<MockConfig> serverConfig;
|
|
|
|
NiceMock<MockInputFilter> serverInputFilter;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.forClientListener().connected(), &listener,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
|
|
|
this, &NetworkTests::sendToClient_mockData_handleClientConnected, &listener));
|
|
|
|
|
|
|
|
ON_CALL(serverConfig, isScreen(_)).WillByDefault(Return(true));
|
|
|
|
ON_CALL(serverConfig, getInputFilter()).WillByDefault(Return(&serverInputFilter));
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
Server server(serverConfig, &primaryClient, &serverScreen, &m_events, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
server.m_mock = true;
|
|
|
|
listener.setServer(&server);
|
|
|
|
|
|
|
|
// client
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> clientScreen;
|
|
|
|
SocketMultiplexer clientSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* clientSocketFactory = new TCPSocketFactory(&m_events, &clientSocketMultiplexer);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
ON_CALL(clientScreen, getShape(_, _, _, _)).WillByDefault(Invoke(getScreenShape));
|
|
|
|
ON_CALL(clientScreen, getCursorPos(_, _)).WillByDefault(Invoke(getCursorPos));
|
|
|
|
|
2015-01-27 11:33:06 +00:00
|
|
|
Client client(&m_events, "stub", serverAddress, clientSocketFactory, &clientScreen, cryptoOptions, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.forIScreen().fileRecieveCompleted(), &client,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
2013-08-30 14:38:43 +00:00
|
|
|
this, &NetworkTests::sendToClient_mockData_fileRecieveCompleted));
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
client.connect();
|
|
|
|
|
2013-07-26 12:44:14 +00:00
|
|
|
m_events.initQuitTimeout(10);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.loop();
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.removeHandler(m_events.forClientListener().connected(), &listener);
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.removeHandler(m_events.forIScreen().fileRecieveCompleted(), &client);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.cleanupQuitTimeout();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NetworkTests, sendToClient_mockFile)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
|
|
|
// server and client
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkAddress serverAddress(TEST_HOST, TEST_PORT);
|
|
|
|
CryptoOptions cryptoOptions;
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
serverAddress.resolve();
|
|
|
|
|
|
|
|
// server
|
2014-11-11 13:51:47 +00:00
|
|
|
SocketMultiplexer serverSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* serverSocketFactory = new TCPSocketFactory(&m_events, &serverSocketMultiplexer);
|
2015-01-27 11:33:06 +00:00
|
|
|
ClientListener listener(serverAddress, serverSocketFactory, cryptoOptions, &m_events);
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> serverScreen;
|
|
|
|
NiceMock<MockPrimaryClient> primaryClient;
|
|
|
|
NiceMock<MockConfig> serverConfig;
|
|
|
|
NiceMock<MockInputFilter> serverInputFilter;
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.forClientListener().connected(), &listener,
|
2013-07-16 19:02:30 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
2013-07-24 16:41:12 +00:00
|
|
|
this, &NetworkTests::sendToClient_mockFile_handleClientConnected, &listener));
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
ON_CALL(serverConfig, isScreen(_)).WillByDefault(Return(true));
|
|
|
|
ON_CALL(serverConfig, getInputFilter()).WillByDefault(Return(&serverInputFilter));
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
Server server(serverConfig, &primaryClient, &serverScreen, &m_events, true);
|
2013-07-16 19:02:30 +00:00
|
|
|
server.m_mock = true;
|
|
|
|
listener.setServer(&server);
|
|
|
|
|
|
|
|
// client
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> clientScreen;
|
|
|
|
SocketMultiplexer clientSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* clientSocketFactory = new TCPSocketFactory(&m_events, &clientSocketMultiplexer);
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
ON_CALL(clientScreen, getShape(_, _, _, _)).WillByDefault(Invoke(getScreenShape));
|
|
|
|
ON_CALL(clientScreen, getCursorPos(_, _)).WillByDefault(Invoke(getCursorPos));
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2015-01-27 11:33:06 +00:00
|
|
|
Client client(&m_events, "stub", serverAddress, clientSocketFactory, &clientScreen, cryptoOptions, true);
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.forIScreen().fileRecieveCompleted(), &client,
|
2013-07-16 19:02:30 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
2013-08-30 14:38:43 +00:00
|
|
|
this, &NetworkTests::sendToClient_mockFile_fileRecieveCompleted));
|
2013-07-16 19:02:30 +00:00
|
|
|
|
|
|
|
client.connect();
|
|
|
|
|
2013-07-26 12:44:14 +00:00
|
|
|
m_events.initQuitTimeout(10);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.loop();
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.removeHandler(m_events.forClientListener().connected(), &listener);
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.removeHandler(m_events.forIScreen().fileRecieveCompleted(), &client);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.cleanupQuitTimeout();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NetworkTests, sendToServer_mockData)
|
|
|
|
{
|
|
|
|
// server and client
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkAddress serverAddress(TEST_HOST, TEST_PORT);
|
|
|
|
CryptoOptions cryptoOptions;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
serverAddress.resolve();
|
|
|
|
|
|
|
|
// server
|
2014-11-11 13:51:47 +00:00
|
|
|
SocketMultiplexer serverSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* serverSocketFactory = new TCPSocketFactory(&m_events, &serverSocketMultiplexer);
|
2015-01-27 11:33:06 +00:00
|
|
|
ClientListener listener(serverAddress, serverSocketFactory, cryptoOptions, &m_events);
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> serverScreen;
|
|
|
|
NiceMock<MockPrimaryClient> primaryClient;
|
|
|
|
NiceMock<MockConfig> serverConfig;
|
|
|
|
NiceMock<MockInputFilter> serverInputFilter;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
ON_CALL(serverConfig, isScreen(_)).WillByDefault(Return(true));
|
|
|
|
ON_CALL(serverConfig, getInputFilter()).WillByDefault(Return(&serverInputFilter));
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
Server server(serverConfig, &primaryClient, &serverScreen, &m_events, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
server.m_mock = true;
|
|
|
|
listener.setServer(&server);
|
|
|
|
|
|
|
|
// client
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> clientScreen;
|
|
|
|
SocketMultiplexer clientSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* clientSocketFactory = new TCPSocketFactory(&m_events, &clientSocketMultiplexer);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
ON_CALL(clientScreen, getShape(_, _, _, _)).WillByDefault(Invoke(getScreenShape));
|
|
|
|
ON_CALL(clientScreen, getCursorPos(_, _)).WillByDefault(Invoke(getCursorPos));
|
|
|
|
|
2015-01-27 11:33:06 +00:00
|
|
|
Client client(&m_events, "stub", serverAddress, clientSocketFactory, &clientScreen, cryptoOptions, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.forClientListener().connected(), &listener,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
|
|
|
this, &NetworkTests::sendToServer_mockData_handleClientConnected, &client));
|
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.forIScreen().fileRecieveCompleted(), &server,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
2013-08-30 14:38:43 +00:00
|
|
|
this, &NetworkTests::sendToServer_mockData_fileRecieveCompleted));
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
client.connect();
|
|
|
|
|
2013-07-26 12:44:14 +00:00
|
|
|
m_events.initQuitTimeout(10);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.loop();
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.removeHandler(m_events.forClientListener().connected(), &listener);
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.removeHandler(m_events.forIScreen().fileRecieveCompleted(), &server);
|
2013-07-24 16:41:12 +00:00
|
|
|
m_events.cleanupQuitTimeout();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NetworkTests, sendToServer_mockFile)
|
|
|
|
{
|
|
|
|
// server and client
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkAddress serverAddress(TEST_HOST, TEST_PORT);
|
|
|
|
CryptoOptions cryptoOptions;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
serverAddress.resolve();
|
|
|
|
|
|
|
|
// server
|
2014-11-11 13:51:47 +00:00
|
|
|
SocketMultiplexer serverSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* serverSocketFactory = new TCPSocketFactory(&m_events, &serverSocketMultiplexer);
|
2015-01-27 11:33:06 +00:00
|
|
|
ClientListener listener(serverAddress, serverSocketFactory, cryptoOptions, &m_events);
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> serverScreen;
|
|
|
|
NiceMock<MockPrimaryClient> primaryClient;
|
|
|
|
NiceMock<MockConfig> serverConfig;
|
|
|
|
NiceMock<MockInputFilter> serverInputFilter;
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
ON_CALL(serverConfig, isScreen(_)).WillByDefault(Return(true));
|
|
|
|
ON_CALL(serverConfig, getInputFilter()).WillByDefault(Return(&serverInputFilter));
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
Server server(serverConfig, &primaryClient, &serverScreen, &m_events, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
server.m_mock = true;
|
|
|
|
listener.setServer(&server);
|
|
|
|
|
|
|
|
// client
|
2014-11-11 13:51:47 +00:00
|
|
|
NiceMock<MockScreen> clientScreen;
|
|
|
|
SocketMultiplexer clientSocketMultiplexer;
|
2015-01-12 10:33:29 +00:00
|
|
|
TCPSocketFactory* clientSocketFactory = new TCPSocketFactory(&m_events, &clientSocketMultiplexer);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
ON_CALL(clientScreen, getShape(_, _, _, _)).WillByDefault(Invoke(getScreenShape));
|
|
|
|
ON_CALL(clientScreen, getCursorPos(_, _)).WillByDefault(Invoke(getCursorPos));
|
|
|
|
|
2015-01-27 11:33:06 +00:00
|
|
|
Client client(&m_events, "stub", serverAddress, clientSocketFactory, &clientScreen, cryptoOptions, true);
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.forClientListener().connected(), &listener,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
|
|
|
this, &NetworkTests::sendToServer_mockFile_handleClientConnected, &client));
|
|
|
|
|
|
|
|
m_events.adoptHandler(
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.forIScreen().fileRecieveCompleted(), &server,
|
2013-07-24 16:41:12 +00:00
|
|
|
new TMethodEventJob<NetworkTests>(
|
2013-08-30 14:38:43 +00:00
|
|
|
this, &NetworkTests::sendToServer_mockFile_fileRecieveCompleted));
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
client.connect();
|
|
|
|
|
2013-07-26 12:44:14 +00:00
|
|
|
m_events.initQuitTimeout(10);
|
2013-07-16 19:02:30 +00:00
|
|
|
m_events.loop();
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.removeHandler(m_events.forClientListener().connected(), &listener);
|
2013-08-30 14:38:43 +00:00
|
|
|
m_events.removeHandler(m_events.forIScreen().fileRecieveCompleted(), &server);
|
2013-07-16 19:02:30 +00:00
|
|
|
m_events.cleanupQuitTimeout();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToClient_mockData_handleClientConnected(const Event&, void* vlistener)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
ClientListener* listener = reinterpret_cast<ClientListener*>(vlistener);
|
|
|
|
Server* server = listener->getServer();
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
ClientProxy* client = listener->getNextClient();
|
2013-07-16 19:02:30 +00:00
|
|
|
if (client == NULL) {
|
2013-07-24 16:41:12 +00:00
|
|
|
throw runtime_error("client is null");
|
2013-07-16 19:02:30 +00:00
|
|
|
}
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
BaseClientProxy* bcp = reinterpret_cast<BaseClientProxy*>(client);
|
2013-07-16 19:02:30 +00:00
|
|
|
server->adoptClient(bcp);
|
|
|
|
server->setActive(bcp);
|
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
sendMockData(server);
|
2013-07-16 19:02:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToClient_mockData_fileRecieveCompleted(const Event& event, void*)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Client* client = reinterpret_cast<Client*>(event.getTarget());
|
2013-07-16 19:02:30 +00:00
|
|
|
EXPECT_TRUE(client->isReceivedFileSizeValid());
|
|
|
|
|
|
|
|
m_events.raiseQuitEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToClient_mockFile_handleClientConnected(const Event&, void* vlistener)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
ClientListener* listener = reinterpret_cast<ClientListener*>(vlistener);
|
|
|
|
Server* server = listener->getServer();
|
2013-07-24 16:41:12 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
ClientProxy* client = listener->getNextClient();
|
2013-07-24 16:41:12 +00:00
|
|
|
if (client == NULL) {
|
|
|
|
throw runtime_error("client is null");
|
|
|
|
}
|
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
BaseClientProxy* bcp = reinterpret_cast<BaseClientProxy*>(client);
|
2013-07-24 16:41:12 +00:00
|
|
|
server->adoptClient(bcp);
|
|
|
|
server->setActive(bcp);
|
|
|
|
|
|
|
|
server->sendFileToClient(kMockFilename);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToClient_mockFile_fileRecieveCompleted(const Event& event, void*)
|
2013-07-24 16:41:12 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Client* client = reinterpret_cast<Client*>(event.getTarget());
|
2013-07-24 16:41:12 +00:00
|
|
|
EXPECT_TRUE(client->isReceivedFileSizeValid());
|
|
|
|
|
|
|
|
m_events.raiseQuitEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToServer_mockData_handleClientConnected(const Event&, void* vclient)
|
2013-07-24 16:41:12 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Client* client = reinterpret_cast<Client*>(vclient);
|
2013-07-24 16:41:12 +00:00
|
|
|
sendMockData(client);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToServer_mockData_fileRecieveCompleted(const Event& event, void*)
|
2013-07-24 16:41:12 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Server* server = reinterpret_cast<Server*>(event.getTarget());
|
2013-07-24 16:41:12 +00:00
|
|
|
EXPECT_TRUE(server->isReceivedFileSizeValid());
|
|
|
|
|
|
|
|
m_events.raiseQuitEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToServer_mockFile_handleClientConnected(const Event&, void* vclient)
|
2013-07-24 16:41:12 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Client* client = reinterpret_cast<Client*>(vclient);
|
2013-07-24 16:41:12 +00:00
|
|
|
client->sendFileToServer(kMockFilename);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-11-11 13:51:47 +00:00
|
|
|
NetworkTests::sendToServer_mockFile_fileRecieveCompleted(const Event& event, void*)
|
2013-07-24 16:41:12 +00:00
|
|
|
{
|
2014-11-11 13:51:47 +00:00
|
|
|
Server* server = reinterpret_cast<Server*>(event.getTarget());
|
2013-07-24 16:41:12 +00:00
|
|
|
EXPECT_TRUE(server->isReceivedFileSizeValid());
|
|
|
|
|
|
|
|
m_events.raiseQuitEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
NetworkTests::sendMockData(void* eventTarget)
|
|
|
|
{
|
|
|
|
// send first message (file size)
|
2014-11-11 13:51:47 +00:00
|
|
|
String size = intToString(kMockDataSize);
|
2013-08-02 13:21:06 +00:00
|
|
|
size_t sizeLength = size.size();
|
2014-11-11 13:51:47 +00:00
|
|
|
FileChunker::FileChunk* sizeMessage = new FileChunker::FileChunk(sizeLength + 2);
|
2013-07-24 16:41:12 +00:00
|
|
|
char* chunkData = sizeMessage->m_chunk;
|
|
|
|
|
|
|
|
chunkData[0] = kFileStart;
|
|
|
|
memcpy(&chunkData[1], size.c_str(), sizeLength);
|
|
|
|
chunkData[sizeLength + 1] = '\0';
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.addEvent(Event(m_events.forIScreen().fileChunkSending(), eventTarget, sizeMessage));
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
// send chunk messages with incrementing chunk size
|
|
|
|
size_t lastSize = 0;
|
|
|
|
size_t sentLength = 0;
|
|
|
|
while (true) {
|
|
|
|
size_t chunkSize = lastSize + kMockDataChunkIncrement;
|
|
|
|
|
|
|
|
// make sure we don't read too much from the mock data.
|
|
|
|
if (sentLength + chunkSize > kMockDataSize) {
|
|
|
|
chunkSize = kMockDataSize - sentLength;
|
|
|
|
}
|
|
|
|
|
|
|
|
// first byte is the chunk mark, last is \0
|
2014-11-11 13:51:47 +00:00
|
|
|
FileChunker::FileChunk* fileChunk = new FileChunker::FileChunk(chunkSize + 2);
|
2013-07-24 16:41:12 +00:00
|
|
|
char* chunkData = fileChunk->m_chunk;
|
|
|
|
|
|
|
|
chunkData[0] = kFileChunk;
|
|
|
|
memcpy(&chunkData[1], &m_mockData[sentLength], chunkSize);
|
|
|
|
chunkData[chunkSize + 1] = '\0';
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.addEvent(Event(m_events.forIScreen().fileChunkSending(), eventTarget, fileChunk));
|
2013-07-24 16:41:12 +00:00
|
|
|
|
|
|
|
sentLength += chunkSize;
|
|
|
|
lastSize = chunkSize;
|
|
|
|
|
|
|
|
if (sentLength == kMockDataSize) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
// send last message
|
2014-11-11 13:51:47 +00:00
|
|
|
FileChunker::FileChunk* transferFinished = new FileChunker::FileChunk(2);
|
2013-07-24 16:41:12 +00:00
|
|
|
chunkData = transferFinished->m_chunk;
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-07-24 16:41:12 +00:00
|
|
|
chunkData[0] = kFileEnd;
|
|
|
|
chunkData[1] = '\0';
|
2014-11-11 13:51:47 +00:00
|
|
|
m_events.addEvent(Event(m_events.forIScreen().fileChunkSending(), eventTarget, transferFinished));
|
2013-07-24 16:41:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
UInt8*
|
|
|
|
newMockData(size_t size)
|
|
|
|
{
|
|
|
|
UInt8* buffer = new UInt8[size];
|
|
|
|
|
|
|
|
UInt8* data = buffer;
|
|
|
|
const UInt8 head[] = "mock head... ";
|
|
|
|
size_t headSize = sizeof(head) - 1;
|
|
|
|
const UInt8 tail[] = "... mock tail";
|
|
|
|
size_t tailSize = sizeof(tail) - 1;
|
|
|
|
const UInt8 synergyRocks[] = "synergy\0 rocks! ";
|
|
|
|
size_t synergyRocksSize = sizeof(synergyRocks) - 1;
|
|
|
|
|
|
|
|
memcpy(data, head, headSize);
|
|
|
|
data += headSize;
|
|
|
|
|
2013-08-02 13:21:06 +00:00
|
|
|
size_t times = (size - headSize - tailSize) / synergyRocksSize;
|
2014-02-25 15:50:06 +00:00
|
|
|
for (size_t i = 0; i < times; ++i) {
|
2013-07-24 16:41:12 +00:00
|
|
|
memcpy(data, synergyRocks, synergyRocksSize);
|
|
|
|
data += synergyRocksSize;
|
|
|
|
}
|
2013-07-16 19:02:30 +00:00
|
|
|
|
2013-08-02 13:21:06 +00:00
|
|
|
size_t remainder = (size - headSize - tailSize) % synergyRocksSize;
|
2013-07-24 16:41:12 +00:00
|
|
|
if (remainder != 0) {
|
|
|
|
memset(data, '.', remainder);
|
|
|
|
data += remainder;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(data, tail, tailSize);
|
|
|
|
return buffer;
|
2013-07-16 19:02:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-07-24 16:41:12 +00:00
|
|
|
createFile(fstream& file, const char* filename, size_t size)
|
|
|
|
{
|
|
|
|
UInt8* buffer = newMockData(size);
|
|
|
|
|
|
|
|
file.open(filename, ios::out | ios::binary);
|
|
|
|
if (!file.is_open()) {
|
|
|
|
throw runtime_error("file not open");
|
|
|
|
}
|
|
|
|
|
|
|
|
file.write(reinterpret_cast<char*>(buffer), size);
|
|
|
|
file.close();
|
|
|
|
|
|
|
|
delete[] buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
getScreenShape(SInt32& x, SInt32& y, SInt32& w, SInt32& h)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
|
|
|
x = 0;
|
|
|
|
y = 0;
|
|
|
|
w = 1;
|
|
|
|
h = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-07-24 16:41:12 +00:00
|
|
|
getCursorPos(SInt32& x, SInt32& y)
|
2013-07-16 19:02:30 +00:00
|
|
|
{
|
|
|
|
x = 0;
|
|
|
|
y = 0;
|
|
|
|
}
|
2013-07-24 16:41:12 +00:00
|
|
|
|
2014-11-11 13:51:47 +00:00
|
|
|
String
|
2013-07-24 16:41:12 +00:00
|
|
|
intToString(size_t i)
|
|
|
|
{
|
|
|
|
stringstream ss;
|
|
|
|
ss << i;
|
|
|
|
return ss.str();
|
|
|
|
}
|
2013-09-18 06:52:18 +00:00
|
|
|
|
|
|
|
#endif // WINAPI_CARBON
|