tests for GH#169

tests for GH#169: Exceptions due to bug BufferedBidirectionalStreamBuf.h
This commit is contained in:
Aleksandar Fabijanic
2013-06-06 21:31:17 -05:00
parent 57c2d703ff
commit 6184be0025
4 changed files with 80 additions and 4 deletions

View File

@@ -87,6 +87,30 @@ void SocketStreamTest::testStreamEcho()
} }
void SocketStreamTest::testLargeStreamEcho()
{
const int msgSize = 64000;
EchoServer echoServer;
StreamSocket ss;
ss.connect(SocketAddress("localhost", echoServer.port()));
SocketStream str(ss);
std::string payload(msgSize, 'x');
str << payload;
assert (str.good());
str.flush();
assert (str.good());
ss.shutdownSend();
assert (str.gcount() == 0);
char buffer[msgSize];
str.read(buffer, sizeof(buffer));
assert (str.good());
assert (str.gcount() == msgSize);
ss.close();
}
void SocketStreamTest::testEOF() void SocketStreamTest::testEOF()
{ {
StreamSocket ss; StreamSocket ss;
@@ -131,6 +155,7 @@ CppUnit::Test* SocketStreamTest::suite()
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("SocketStreamTest"); CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("SocketStreamTest");
CppUnit_addTest(pSuite, SocketStreamTest, testStreamEcho); CppUnit_addTest(pSuite, SocketStreamTest, testStreamEcho);
CppUnit_addTest(pSuite, SocketStreamTest, testLargeStreamEcho);
CppUnit_addTest(pSuite, SocketStreamTest, testEOF); CppUnit_addTest(pSuite, SocketStreamTest, testEOF);
return pSuite; return pSuite;

View File

@@ -47,6 +47,7 @@ public:
~SocketStreamTest(); ~SocketStreamTest();
void testStreamEcho(); void testStreamEcho();
void testLargeStreamEcho();
void testEOF(); void testEOF();
void setUp(); void setUp();

View File

@@ -34,6 +34,7 @@
#include "CppUnit/TestCaller.h" #include "CppUnit/TestCaller.h"
#include "CppUnit/TestSuite.h" #include "CppUnit/TestSuite.h"
#include "Poco/Net/WebSocket.h" #include "Poco/Net/WebSocket.h"
#include "Poco/Net/SocketStream.h"
#include "Poco/Net/HTTPClientSession.h" #include "Poco/Net/HTTPClientSession.h"
#include "Poco/Net/HTTPServer.h" #include "Poco/Net/HTTPServer.h"
#include "Poco/Net/HTTPServerParams.h" #include "Poco/Net/HTTPServerParams.h"
@@ -51,6 +52,7 @@ using Poco::Net::HTTPRequest;
using Poco::Net::HTTPResponse; using Poco::Net::HTTPResponse;
using Poco::Net::HTTPServerRequest; using Poco::Net::HTTPServerRequest;
using Poco::Net::HTTPServerResponse; using Poco::Net::HTTPServerResponse;
using Poco::Net::SocketStream;
using Poco::Net::WebSocket; using Poco::Net::WebSocket;
using Poco::Net::WebSocketException; using Poco::Net::WebSocketException;
@@ -60,18 +62,22 @@ namespace
class WebSocketRequestHandler: public Poco::Net::HTTPRequestHandler class WebSocketRequestHandler: public Poco::Net::HTTPRequestHandler
{ {
public: public:
WebSocketRequestHandler(std::size_t bufSize = 1024): _bufSize(bufSize)
{
}
void handleRequest(HTTPServerRequest& request, HTTPServerResponse& response) void handleRequest(HTTPServerRequest& request, HTTPServerResponse& response)
{ {
try try
{ {
WebSocket ws(request, response); WebSocket ws(request, response);
char buffer[1024]; std::auto_ptr<char> pBuffer(new char[_bufSize]);
int flags; int flags;
int n; int n;
do do
{ {
n = ws.receiveFrame(buffer, sizeof(buffer), flags); n = ws.receiveFrame(pBuffer.get(), _bufSize, flags);
ws.sendFrame(buffer, n, flags); ws.sendFrame(pBuffer.get(), n, flags);
} }
while (n > 0 || (flags & WebSocket::FRAME_OP_BITMASK) != WebSocket::FRAME_OP_CLOSE); while (n > 0 || (flags & WebSocket::FRAME_OP_BITMASK) != WebSocket::FRAME_OP_CLOSE);
} }
@@ -92,15 +98,25 @@ namespace
} }
} }
} }
private:
std::size_t _bufSize;
}; };
class WebSocketRequestHandlerFactory: public Poco::Net::HTTPRequestHandlerFactory class WebSocketRequestHandlerFactory: public Poco::Net::HTTPRequestHandlerFactory
{ {
public: public:
WebSocketRequestHandlerFactory(std::size_t bufSize = 1024): _bufSize(bufSize)
{
}
Poco::Net::HTTPRequestHandler* createRequestHandler(const HTTPServerRequest& request) Poco::Net::HTTPRequestHandler* createRequestHandler(const HTTPServerRequest& request)
{ {
return new WebSocketRequestHandler; return new WebSocketRequestHandler(_bufSize);
} }
private:
std::size_t _bufSize;
}; };
} }
@@ -180,6 +196,38 @@ void WebSocketTest::testWebSocket()
} }
void WebSocketTest::testWebSocketLarge()
{
const int msgSize = 64000;
Poco::Net::ServerSocket ss(0);
Poco::Net::HTTPServer server(new WebSocketRequestHandlerFactory(msgSize), ss, new Poco::Net::HTTPServerParams);
server.start();
Poco::Thread::sleep(200);
HTTPClientSession cs("localhost", ss.address().port());
HTTPRequest request(HTTPRequest::HTTP_GET, "/ws");
HTTPResponse response;
WebSocket ws(cs, request, response);
std::string payload(msgSize, 'x');
SocketStream sstr(ws);
sstr << payload;
sstr.flush();
char buffer[msgSize + 1];
int flags;
int n = 0;
do
{
n += ws.receiveFrame(buffer + n, sizeof(buffer) - n, flags);
} while (n > 0 && n < msgSize);
assert (n == payload.size());
assert (payload.compare(0, payload.size(), buffer, 0, n) == 0);
}
void WebSocketTest::setUp() void WebSocketTest::setUp()
{ {
} }
@@ -195,6 +243,7 @@ CppUnit::Test* WebSocketTest::suite()
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("WebSocketTest"); CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("WebSocketTest");
CppUnit_addTest(pSuite, WebSocketTest, testWebSocket); CppUnit_addTest(pSuite, WebSocketTest, testWebSocket);
CppUnit_addTest(pSuite, WebSocketTest, testWebSocketLarge);
return pSuite; return pSuite;
} }

View File

@@ -47,6 +47,7 @@ public:
~WebSocketTest(); ~WebSocketTest();
void testWebSocket(); void testWebSocket();
void testWebSocketLarge();
void setUp(); void setUp();
void tearDown(); void tearDown();