| Server IP : 3.138.164.131 / Your IP : 216.73.216.136 Web Server : Apache System : Linux ns1.techtime.me 4.18.0-147.8.1.el8.lve.1.x86_64 #1 SMP Mon Jun 29 09:55:57 EDT 2020 x86_64 User : injazaat ( 1471) PHP Version : 8.1.20 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/self/root/opt/cpanel/ea-ruby27/src/passenger-release-6.0.18/test/cxx/ |
Upload File : |
#include <TestSupport.h>
#include <boost/bind/bind.hpp>
#include <Utils/MessagePassing.h>
#include <Utils/Timer.h>
using namespace Passenger;
using namespace std;
namespace tut {
struct MessagePassingTest: public TestBase {
MessageBoxPtr box;
MessagePassingTest() {
box = boost::make_shared<MessageBox>();
}
void sendMessagesLater() {
syscalls::usleep(20000);
box->send("hi");
syscalls::usleep(20000);
box->send("ho");
}
};
DEFINE_TEST_GROUP(MessagePassingTest);
TEST_METHOD(1) {
// Sending and receiving 1 message.
box->send("hi");
ensure_equals(box->size(), 1u);
ensure_equals(box->recv("hi")->name, "hi");
ensure_equals(box->size(), 0u);
}
TEST_METHOD(2) {
// Sending and receiving multiple messages out of order.
box->send("ho");
box->send("hi");
box->send("ha");
ensure_equals(box->size(), 3u);
ensure_equals(box->recv("hi")->name, "hi");
ensure_equals(box->size(), 2u);
ensure_equals(box->recv("ho")->name, "ho");
ensure_equals(box->size(), 1u);
ensure_equals(box->recv("ha")->name, "ha");
ensure_equals(box->size(), 0u);
}
TEST_METHOD(3) {
// Receive with zero timeout.
unsigned long long timeoutUSec = 0;
Timer<> timer;
ensure_equals(box->recv("hi", &timeoutUSec), MessagePtr());
ensure(timer.elapsed() < 10);
ensure_equals(timeoutUSec, 0ull);
}
TEST_METHOD(4) {
// Receive with non-zero timeout.
unsigned long long timeoutUSec = 20000;
Timer<> timer;
ensure_equals(box->recv("hi", &timeoutUSec), MessagePtr());
ensure("(1)", timer.elapsed() >= 19);
ensure("(2)", timer.elapsed() < 95);
ensure("(3)", timeoutUSec <= 2000ull);
}
TEST_METHOD(5) {
// Test waiting with timeout.
TempThread thr(boost::bind(&MessagePassingTest::sendMessagesLater, this));
unsigned long long timeoutUSec = 200000;
Timer<> timer;
ensure_equals("(1)", box->recv("ho", &timeoutUSec)->name, "ho");
ensure("(2)", timer.elapsed() >= 39);
ensure("(3)", timer.elapsed() < 95);
ensure_equals("(4)", box->size(), 1u);
ensure_equals("(5)", box->recv("hi")->name, "hi");
ensure_equals("(6)", box->size(), 0u);
ensure("(7)", timeoutUSec >= 100000);
}
}