2020-12-26 12:42:39 +01:00
|
|
|
#include "common/NetworkRequest.hpp"
|
|
|
|
#include "common/NetworkManager.hpp"
|
|
|
|
#include "common/NetworkResult.hpp"
|
|
|
|
#include "common/Outcome.hpp"
|
|
|
|
#include "providers/twitch/api/Helix.hpp"
|
|
|
|
|
|
|
|
#include "common/Outcome.hpp"
|
|
|
|
#include "common/QLogging.hpp"
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
using namespace chatterino;
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
static QString getStatusURL(int code)
|
|
|
|
{
|
|
|
|
return QString("http://httpbin.org/status/%1").arg(code);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
TEST(NetworkRequest, Success)
|
|
|
|
{
|
|
|
|
const std::vector<int> codes{200, 201, 202, 203, 204, 205, 206};
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
for (const auto code : codes)
|
|
|
|
{
|
|
|
|
auto url = getStatusURL(code);
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.onSuccess([code, &mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) -> Outcome {
|
|
|
|
EXPECT_EQ(result.status(), code);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([&](NetworkResult result) {
|
|
|
|
// The codes should *not* throw an error
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
}
|
|
|
|
|
2021-01-16 18:25:56 +01:00
|
|
|
TEST(NetworkRequest, FinallyCallbackOnSuccess)
|
|
|
|
{
|
|
|
|
const std::vector<int> codes{200, 201, 202, 203, 204, 205, 206};
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
for (const auto code : codes)
|
|
|
|
{
|
|
|
|
auto url = getStatusURL(code);
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
bool finallyCalled = false;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.finally(
|
|
|
|
[&mut, &requestDone, &requestDoneCondition, &finallyCalled] {
|
|
|
|
finallyCalled = true;
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
|
|
|
|
EXPECT_TRUE(finallyCalled);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-26 12:42:39 +01:00
|
|
|
TEST(NetworkRequest, Error)
|
|
|
|
{
|
|
|
|
const std::vector<int> codes{
|
|
|
|
400, 401, 402, 403, 404, 405, 406, 407, 408, 409, 410,
|
|
|
|
411, 412, 413, 414, 418, 500, 501, 502, 503, 504,
|
|
|
|
};
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
for (const auto code : codes)
|
|
|
|
{
|
|
|
|
auto url = getStatusURL(code);
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.onSuccess([code, &mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) -> Outcome {
|
|
|
|
// The codes should throw an error
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([code, &mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) {
|
|
|
|
EXPECT_EQ(result.status(), code);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
}
|
|
|
|
|
2021-01-16 18:25:56 +01:00
|
|
|
TEST(NetworkRequest, FinallyCallbackOnError)
|
|
|
|
{
|
|
|
|
const std::vector<int> codes{
|
|
|
|
400, 401, 402, 403, 404, 405, 406, 407, 408, 409, 410,
|
|
|
|
411, 412, 413, 414, 418, 500, 501, 502, 503, 504,
|
|
|
|
};
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
for (const auto code : codes)
|
|
|
|
{
|
|
|
|
auto url = getStatusURL(code);
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
bool finallyCalled = false;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.finally(
|
|
|
|
[&mut, &requestDone, &requestDoneCondition, &finallyCalled] {
|
|
|
|
finallyCalled = true;
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
|
|
|
|
EXPECT_TRUE(finallyCalled);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-26 12:42:39 +01:00
|
|
|
TEST(NetworkRequest, TimeoutTimingOut)
|
|
|
|
{
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
auto url = "http://httpbin.org/delay/5";
|
|
|
|
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.timeout(1000)
|
|
|
|
.onSuccess([&mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) -> Outcome {
|
|
|
|
// The timeout should throw an error
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([&mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) {
|
|
|
|
qDebug() << QTime::currentTime().toString()
|
|
|
|
<< "timeout request finish error";
|
|
|
|
EXPECT_EQ(result.status(), NetworkResult::timedoutStatus);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(NetworkRequest, TimeoutNotTimingOut)
|
|
|
|
{
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
auto url = "http://httpbin.org/delay/1";
|
|
|
|
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.timeout(2000)
|
|
|
|
.onSuccess([&mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) -> Outcome {
|
|
|
|
EXPECT_EQ(result.status(), 200);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([&mut, &requestDone, &requestDoneCondition,
|
|
|
|
url](NetworkResult result) {
|
|
|
|
// The timeout should *not* throw an error
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
}
|
2021-01-16 18:25:56 +01:00
|
|
|
|
|
|
|
TEST(NetworkRequest, FinallyCallbackOnTimeout)
|
|
|
|
{
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
|
|
|
|
auto url = "http://httpbin.org/delay/5";
|
|
|
|
|
|
|
|
std::mutex mut;
|
|
|
|
bool requestDone = false;
|
|
|
|
std::condition_variable requestDoneCondition;
|
|
|
|
bool finallyCalled = false;
|
|
|
|
bool onSuccessCalled = false;
|
|
|
|
bool onErrorCalled = false;
|
|
|
|
|
|
|
|
NetworkRequest(url)
|
|
|
|
.timeout(1000)
|
|
|
|
.onSuccess([&](NetworkResult result) -> Outcome {
|
|
|
|
onSuccessCalled = true;
|
|
|
|
return Success;
|
|
|
|
})
|
|
|
|
.onError([&](NetworkResult result) {
|
|
|
|
onErrorCalled = true;
|
|
|
|
EXPECT_EQ(result.status(), NetworkResult::timedoutStatus);
|
|
|
|
})
|
|
|
|
.finally([&] {
|
|
|
|
finallyCalled = true;
|
|
|
|
|
|
|
|
{
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDone = true;
|
|
|
|
}
|
|
|
|
requestDoneCondition.notify_one();
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
// Wait for the request to finish
|
|
|
|
std::unique_lock lck(mut);
|
|
|
|
requestDoneCondition.wait(lck, [&requestDone] {
|
|
|
|
return requestDone;
|
|
|
|
});
|
|
|
|
|
|
|
|
EXPECT_TRUE(finallyCalled);
|
|
|
|
EXPECT_TRUE(onErrorCalled);
|
|
|
|
EXPECT_FALSE(onSuccessCalled);
|
|
|
|
EXPECT_TRUE(NetworkManager::workerThread.isRunning());
|
|
|
|
}
|