断开qt定时器进行单元测试
Disconnect qt timer for unit test
我正在尝试对一些使用 QTimer 进行周期性操作的遗留代码进行单元测试:
class MyClass : public QObject
{
Q_OBJECT
public:
explicit MyClass(QObject* parent = nullptr) : QObject(parent)
{
timer.setInterval(1000);
timer.setSingleShot(false);
timer.start();
connect(&timer, &QTimer::timeout, this, &MyClass::onTimeout);
}
int getValue() const
{
return value;
}
signals:
public slots:
void onTimeout()
{
value++;
}
private:
int value{0};
QTimer timer{this};
};
我需要为 onTimeout() 方法编写单元测试,因此我试图断开 QTimer::timeout 与 MyClass::onTimeout 的连接,并从单元测试触发更新。
void testFirstUpdate()
{
MyClass myClass;
qDebug() << "disconnect: " << myClass.disconnect(); //returns false
myClass.dumpObjectInfo();
QCOMPARE(myClass.getValue(), 0);
myClass.onTimeout();
QCOMPARE(myClass.getValue(), 1);
}
如何使断开连接正常工作?或者有更好的方法从 QtTestLib 控制 QTimer 吗?添加 MyClass::disconnectTimer() 是唯一可行的选择吗?
另一种解决方案可能是创建一个新线程并将 MyClass 移至该线程。
由于您不会启动新线程,因此不会有事件循环来捕获超时函数。移动 myClass 将导致计时器重新启动,但由于新线程的事件循环不是 运行,超时信号永远不会触发。
QThread t;
myClass.moveToThread(&t);
我认为您无法编辑 "legacy" 代码,将遗留代码重构为可单元测试将是最佳解决方案。
我正在尝试对一些使用 QTimer 进行周期性操作的遗留代码进行单元测试:
class MyClass : public QObject
{
Q_OBJECT
public:
explicit MyClass(QObject* parent = nullptr) : QObject(parent)
{
timer.setInterval(1000);
timer.setSingleShot(false);
timer.start();
connect(&timer, &QTimer::timeout, this, &MyClass::onTimeout);
}
int getValue() const
{
return value;
}
signals:
public slots:
void onTimeout()
{
value++;
}
private:
int value{0};
QTimer timer{this};
};
我需要为 onTimeout() 方法编写单元测试,因此我试图断开 QTimer::timeout 与 MyClass::onTimeout 的连接,并从单元测试触发更新。
void testFirstUpdate()
{
MyClass myClass;
qDebug() << "disconnect: " << myClass.disconnect(); //returns false
myClass.dumpObjectInfo();
QCOMPARE(myClass.getValue(), 0);
myClass.onTimeout();
QCOMPARE(myClass.getValue(), 1);
}
如何使断开连接正常工作?或者有更好的方法从 QtTestLib 控制 QTimer 吗?添加 MyClass::disconnectTimer() 是唯一可行的选择吗?
另一种解决方案可能是创建一个新线程并将 MyClass 移至该线程。 由于您不会启动新线程,因此不会有事件循环来捕获超时函数。移动 myClass 将导致计时器重新启动,但由于新线程的事件循环不是 运行,超时信号永远不会触发。
QThread t;
myClass.moveToThread(&t);
我认为您无法编辑 "legacy" 代码,将遗留代码重构为可单元测试将是最佳解决方案。