Сигнал не перехвачен QSignalSpy
В настоящее время я пишу некоторые юнит-тесты для одного из моих классов. Однако я быстро столкнулся с проблемой. Кажется, что QSignalSpy иногда не ловит disconnected()
сигнал испускается моим Client
учебный класс. Вот мой юнит тест:
void ClientTest::test_disconnectFromHost()
{
QTcpServer server;
server.listen(QHostAddress::Any, 65000);
QTcpSocket* clientSocket = new QTcpSocket();
QSignalSpy connectedSpy(clientSocket, SIGNAL(connected()));
clientSocket->connectToHost(QHostAddress::Any, 65000);
if (!connectedSpy.wait()) {
QFAIL("Client socket connection failed.");
}
Chat::Client client(clientSocket);
QSignalSpy disconnectedSpy(clientSocket, SIGNAL(disconnected()));
// Return true if disconnection succeded
QVERIFY(client.disconnectFromHost());
QVERIFY(disconnectedSpy.wait(500)); // RETURNS FALSE!
// Return false if client was not connected
QVERIFY(!client.disconnectFromHost());
QCOMPARE(client.getLastError(),
Chat::Client::Error::NotConnected);
clientSocket->connectToHost(QHostAddress::Any, 65000);
if (!connectedSpy.wait()) {
QFAIL("Client socket connection failed.");
}
QTcpSocket* serverSocket = server.nextPendingConnection();
serverSocket->disconnectFromHost(); // RETURNS FALSE!
// Emit disconnected if the server closed the connection
QVERIFY(disconnectedSpy.wait(500));
delete serverSocket;
}
И вот методы связанного класса:
Client::Client(QTcpSocket* socket, QObject* parent)
: QObject(parent)
{
this->socket = socket;
messageSize = -1;
lastError = None;
lastErrorString = "";
connect(socket, SIGNAL(connected()), this, SLOT(onSocketConnected()));
connect(socket, SIGNAL(disconnected()), this, SLOT(onSocketDisconnected()));
connect(socket, SIGNAL(error(QAbstractSocket::SocketError)), this, SLOT(onSocketError(QAbstractSocket::SocketError)));
connect(socket, SIGNAL(readyRead()), this, SLOT(onDataReceived()));
}
bool Client::connectToHost(const QHostAddress& serverAddress, quint16 serverPort)
{
if (socket->state() != QTcpSocket::SocketState::UnconnectedState) {
lastError = AlreadyConnected;
return false;
}
messageSize = -1;
socket->connectToHost(serverAddress, serverPort);
return true;
}
bool Client::disconnectFromHost()
{
if (socket->state() != QTcpSocket::SocketState::ConnectedState) {
lastError = NotConnected;
return false;
}
socket->disconnectFromHost();
return true;
}
void Client::onSocketConnected()
{
emit connected();
}
void Client::onSocketDisconnected()
{
emit disconnected();
}
[...]
Есть ли у кого-нибудь объяснение, почему метод QSignalSpy.wait() возвращает false, даже если после отладки модульного теста я знаю, что disconnected()
сигнал испускается?
Спасибо!
0 ответов
Наконец, проблема заключалась в том, что QSignalSpy будет перехватывать испускаемый сигнал до вызова QSignalSpy::wait(). Поэтому QSignalSpy::wait() всегда приводил к таймауту и возвращал false.
Я исправил это, реализовав два вспомогательных метода, чтобы проверить счетчик QSignalSpy и затем подождать, если счет окажется неправильным. Затем я использую эти методы в своих модульных тестах.
namespace SignalUtils {
bool verifySignal(QSignalSpy& spy, int expectedCount);
bool verifyNoSignal(QSignalSpy& spy, int expectedCount);
}
bool SignalUtils::verifySignal(QSignalSpy& spy, int expectedCount)
{
return spy.count() == expectedCount || spy.wait(1000);
}
bool SignalUtils::verifyNoSignal(QSignalSpy& spy, int expectedCount)
{
return spy.count() == expectedCount && !spy.wait(1000);
}