mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-26 18:42:41 +01:00
tests for GH#169
tests for GH#169: Exceptions due to bug BufferedBidirectionalStreamBuf.h
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
@@ -47,6 +47,7 @@ public:
|
|||||||
~SocketStreamTest();
|
~SocketStreamTest();
|
||||||
|
|
||||||
void testStreamEcho();
|
void testStreamEcho();
|
||||||
|
void testLargeStreamEcho();
|
||||||
void testEOF();
|
void testEOF();
|
||||||
|
|
||||||
void setUp();
|
void setUp();
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -47,6 +47,7 @@ public:
|
|||||||
~WebSocketTest();
|
~WebSocketTest();
|
||||||
|
|
||||||
void testWebSocket();
|
void testWebSocket();
|
||||||
|
void testWebSocketLarge();
|
||||||
|
|
||||||
void setUp();
|
void setUp();
|
||||||
void tearDown();
|
void tearDown();
|
||||||
|
|||||||
Reference in New Issue
Block a user