Renamed test folder to tests
This commit is contained in:
parent
c33009beb1
commit
d6f3d55019
4 changed files with 1 additions and 1 deletions
17
tests/CMakeLists.txt
Normal file
17
tests/CMakeLists.txt
Normal file
|
|
@ -0,0 +1,17 @@
|
|||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-access-control")
|
||||
|
||||
add_executable(io_test io_test.cpp)
|
||||
target_link_libraries(io_test ${Boost_LIBRARIES})
|
||||
target_link_libraries(io_test ${CMAKE_THREAD_LIBS_INIT})
|
||||
|
||||
add_executable(parse_test parse_test.cpp)
|
||||
target_link_libraries(parse_test ${Boost_LIBRARIES})
|
||||
target_link_libraries(parse_test ${CMAKE_THREAD_LIBS_INIT})
|
||||
|
||||
if(MSYS) #TODO: Is MSYS true when MSVC is true?
|
||||
target_link_libraries(io_test ws2_32 wsock32)
|
||||
target_link_libraries(parse_test ws2_32 wsock32)
|
||||
endif()
|
||||
|
||||
add_test(io_test io_test)
|
||||
add_test(parse_test parse_test)
|
||||
68
tests/io_test.cpp
Normal file
68
tests/io_test.cpp
Normal file
|
|
@ -0,0 +1,68 @@
|
|||
#include "server_http.hpp"
|
||||
#include "client_http.hpp"
|
||||
|
||||
#include <cassert>
|
||||
|
||||
using namespace std;
|
||||
|
||||
typedef SimpleWeb::Server<SimpleWeb::HTTP> HttpServer;
|
||||
typedef SimpleWeb::Client<SimpleWeb::HTTP> HttpClient;
|
||||
|
||||
int main() {
|
||||
HttpServer server(8080, 1);
|
||||
|
||||
server.resource["^/string$"]["POST"]=[](shared_ptr<HttpServer::Response> response, shared_ptr<HttpServer::Request> request) {
|
||||
auto content=request->content.string();
|
||||
|
||||
*response << "HTTP/1.1 200 OK\r\nContent-Length: " << content.length() << "\r\n\r\n" << content;
|
||||
};
|
||||
|
||||
server.resource["^/info$"]["GET"]=[](shared_ptr<HttpServer::Response> response, shared_ptr<HttpServer::Request> request) {
|
||||
stringstream content_stream;
|
||||
content_stream << request->method << " " << request->path << " " << request->http_version << " ";
|
||||
content_stream << request->header.find("test parameter")->second;
|
||||
|
||||
content_stream.seekp(0, ios::end);
|
||||
|
||||
*response << "HTTP/1.1 200 OK\r\nContent-Length: " << content_stream.tellp() << "\r\n\r\n" << content_stream.rdbuf();
|
||||
};
|
||||
|
||||
server.resource["^/match/([0-9]+)$"]["GET"]=[&server](shared_ptr<HttpServer::Response> response, shared_ptr<HttpServer::Request> request) {
|
||||
string number=request->path_match[1];
|
||||
*response << "HTTP/1.1 200 OK\r\nContent-Length: " << number.length() << "\r\n\r\n" << number;
|
||||
};
|
||||
|
||||
thread server_thread([&server](){
|
||||
//Start server
|
||||
server.start();
|
||||
});
|
||||
|
||||
this_thread::sleep_for(chrono::seconds(1));
|
||||
HttpClient client("localhost:8080");
|
||||
|
||||
{
|
||||
stringstream output;
|
||||
auto r=client.request("POST", "/string", "A string");
|
||||
output << r->content.rdbuf();
|
||||
assert(output.str()=="A string");
|
||||
}
|
||||
|
||||
{
|
||||
stringstream output;
|
||||
auto r=client.request("GET", "/info", "", {{"Test Parameter", "test value"}});
|
||||
output << r->content.rdbuf();
|
||||
assert(output.str()=="GET /info 1.1 test value");
|
||||
}
|
||||
|
||||
{
|
||||
stringstream output;
|
||||
auto r=client.request("GET", "/match/123");
|
||||
output << r->content.rdbuf();
|
||||
assert(output.str()=="123");
|
||||
}
|
||||
|
||||
server.stop();
|
||||
server_thread.join();
|
||||
|
||||
return 0;
|
||||
}
|
||||
127
tests/parse_test.cpp
Normal file
127
tests/parse_test.cpp
Normal file
|
|
@ -0,0 +1,127 @@
|
|||
#include "server_http.hpp"
|
||||
#include "client_http.hpp"
|
||||
#include <iostream>
|
||||
|
||||
using namespace std;
|
||||
using namespace SimpleWeb;
|
||||
|
||||
class ServerTest : public ServerBase<HTTP> {
|
||||
public:
|
||||
ServerTest() :
|
||||
ServerBase<HTTP>::ServerBase(8080, 1, 5, 300) {}
|
||||
|
||||
void accept() {}
|
||||
|
||||
bool parse_request_test() {
|
||||
std::shared_ptr<Request> request(new Request());
|
||||
|
||||
stringstream ss;
|
||||
ss << "GET /test/ HTTP/1.1\r\n";
|
||||
ss << "TestHeader: test\r\n";
|
||||
ss << "TestHeader2:test2\r\n";
|
||||
ss << "\r\n";
|
||||
|
||||
if(!parse_request(request, ss))
|
||||
return 0;
|
||||
|
||||
if(request->method!="GET")
|
||||
return 0;
|
||||
if(request->path!="/test/")
|
||||
return 0;
|
||||
if(request->http_version!="1.1")
|
||||
return 0;
|
||||
|
||||
if(request->header.size()!=2)
|
||||
return 0;
|
||||
auto header_it=request->header.find("TestHeader");
|
||||
if(header_it==request->header.end() || header_it->second!="test")
|
||||
return 0;
|
||||
header_it=request->header.find("TestHeader2");
|
||||
if(header_it==request->header.end() || header_it->second!="test2")
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
};
|
||||
|
||||
class ClientTest : public ClientBase<HTTP> {
|
||||
public:
|
||||
ClientTest(const std::string& server_port_path) : ClientBase<HTTP>::ClientBase(server_port_path, 80) {}
|
||||
|
||||
void connect() {}
|
||||
|
||||
bool constructor_parse_test1() {
|
||||
if(host!="test.org")
|
||||
return 0;
|
||||
if(port!=8080)
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
bool constructor_parse_test2() {
|
||||
if(host!="test.org")
|
||||
return 0;
|
||||
if(port!=80)
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
bool parse_response_header_test() {
|
||||
std::shared_ptr<Response> response(new Response());
|
||||
|
||||
stringstream ss;
|
||||
ss << "HTTP/1.1 200 OK\r\n";
|
||||
ss << "TestHeader: test\r\n";
|
||||
ss << "TestHeader2:test2\r\n";
|
||||
ss << "\r\n";
|
||||
|
||||
parse_response_header(response, ss);
|
||||
|
||||
if(response->http_version!="1.1")
|
||||
return 0;
|
||||
if(response->status_code!="200 OK")
|
||||
return 0;
|
||||
|
||||
if(response->header.size()!=2)
|
||||
return 0;
|
||||
|
||||
auto header_it=response->header.find("TestHeader");
|
||||
if(header_it==response->header.end() || header_it->second!="test")
|
||||
return 0;
|
||||
header_it=response->header.find("TestHeader2");
|
||||
if(header_it==response->header.end() || header_it->second!="test2")
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
};
|
||||
|
||||
int main() {
|
||||
ServerTest serverTest;
|
||||
|
||||
if(!serverTest.parse_request_test()) {
|
||||
cerr << "FAIL Server::parse_request" << endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
ClientTest clientTest("test.org:8080");
|
||||
if(!clientTest.constructor_parse_test1()) {
|
||||
cerr << "FAIL Client::Client" << endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
ClientTest clientTest2("test.org");
|
||||
if(!clientTest2.constructor_parse_test2()) {
|
||||
cerr << "FAIL Client::Client" << endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
if(!clientTest2.parse_response_header_test()) {
|
||||
cerr << "FAIL Client::parse_response_header" << endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue