mirror of
https://github.com/WinampDesktop/winamp.git
synced 2024-12-18 20:05:52 +01:00
98 lines
3.3 KiB
C++
98 lines
3.3 KiB
C++
#include <gtest/gtest.h>
|
|
|
|
#include <chrono>
|
|
#include <string>
|
|
|
|
#include <cpr/cpr.h>
|
|
#include <curl/curl.h>
|
|
|
|
#include "httpServer.hpp"
|
|
#include "httpsServer.hpp"
|
|
|
|
using namespace cpr;
|
|
|
|
static HttpServer* server = new HttpServer();
|
|
|
|
TEST(ErrorTests, UnsupportedProtocolFailure) {
|
|
Url url{"urk://wat.is.this"};
|
|
Response response = cpr::Get(url);
|
|
EXPECT_EQ(0, response.status_code);
|
|
EXPECT_EQ(ErrorCode::UNSUPPORTED_PROTOCOL, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, InvalidURLFailure) {
|
|
Url url{"???"};
|
|
Response response = cpr::Get(url);
|
|
EXPECT_EQ(0, response.status_code);
|
|
EXPECT_EQ(ErrorCode::INVALID_URL_FORMAT, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, TimeoutFailure) {
|
|
Url url{server->GetBaseUrl() + "/timeout.html"};
|
|
Response response = cpr::Get(url, cpr::Timeout{1});
|
|
EXPECT_EQ(0, response.status_code);
|
|
EXPECT_EQ(ErrorCode::OPERATION_TIMEDOUT, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, ChronoTimeoutFailure) {
|
|
Url url{server->GetBaseUrl() + "/timeout.html"};
|
|
Response response = cpr::Get(url, cpr::Timeout{std::chrono::milliseconds{1}});
|
|
EXPECT_EQ(0, response.status_code);
|
|
EXPECT_EQ(ErrorCode::OPERATION_TIMEDOUT, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, ConnectTimeoutFailure) {
|
|
Url url{"http://localhost:67"};
|
|
Response response = cpr::Get(url, cpr::ConnectTimeout{1});
|
|
EXPECT_EQ(0, response.status_code);
|
|
// Sometimes a CONNECTION_FAILURE happens before the OPERATION_TIMEDOUT:
|
|
EXPECT_TRUE(response.error.code == ErrorCode::OPERATION_TIMEDOUT || response.error.code == ErrorCode::CONNECTION_FAILURE);
|
|
}
|
|
|
|
TEST(ErrorTests, ChronoConnectTimeoutFailure) {
|
|
Url url{"http://localhost:67"};
|
|
Response response = cpr::Get(url, cpr::ConnectTimeout{std::chrono::milliseconds{1}});
|
|
EXPECT_EQ(0, response.status_code);
|
|
// Sometimes a CONNECTION_FAILURE happens before the OPERATION_TIMEDOUT:
|
|
EXPECT_TRUE(response.error.code == ErrorCode::OPERATION_TIMEDOUT || response.error.code == ErrorCode::CONNECTION_FAILURE);
|
|
}
|
|
|
|
TEST(ErrorTests, LowSpeedTimeFailure) {
|
|
Url url{server->GetBaseUrl() + "/low_speed.html"};
|
|
Response response = cpr::Get(url, cpr::LowSpeed{1000, 1});
|
|
// Do not check for the HTTP status code, since libcurl always provides the status code of the header if it was received
|
|
EXPECT_EQ(ErrorCode::OPERATION_TIMEDOUT, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, LowSpeedBytesFailure) {
|
|
Url url{server->GetBaseUrl() + "/low_speed_bytes.html"};
|
|
Response response = cpr::Get(url, cpr::LowSpeed{1000, 1});
|
|
// Do not check for the HTTP status code, since libcurl always provides the status code of the header if it was received
|
|
EXPECT_EQ(ErrorCode::OPERATION_TIMEDOUT, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, ProxyFailure) {
|
|
Url url{server->GetBaseUrl() + "/hello.html"};
|
|
Response response = cpr::Get(url, cpr::Proxies{{"http", "http://bad_host/"}});
|
|
EXPECT_EQ(url, response.url);
|
|
EXPECT_EQ(0, response.status_code);
|
|
EXPECT_EQ(ErrorCode::PROXY_RESOLUTION_FAILURE, response.error.code);
|
|
}
|
|
|
|
TEST(ErrorTests, BoolFalseTest) {
|
|
Error error;
|
|
EXPECT_FALSE(error);
|
|
}
|
|
|
|
TEST(ErrorTests, BoolTrueTest) {
|
|
Error error;
|
|
error.code = ErrorCode::UNSUPPORTED_PROTOCOL;
|
|
EXPECT_TRUE(error);
|
|
}
|
|
|
|
int main(int argc, char** argv) {
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
::testing::AddGlobalTestEnvironment(server);
|
|
return RUN_ALL_TESTS();
|
|
}
|