Qt信号记录器

QSignalSpy可以记录对象的信号发射的次数,参数等信息。

QSignalSpy可以连接到任何对象的任何信号并记录其发射信息。QSignalSpy本身是一个QVariant列表的列表QList<QList<QVariant> >。信号的每次发射都将向列表中追加一个项,其中包含信号的参数列表。

常用接口

  • 将需要记录对象和其信号传入到构造函数中。
QSignalSpy(const QObject *object, PointerToMemberFunction signal)
QSignalSpy(const QObject *object, const char *signal)
  • 返回信号触发的次数。
inline int count() const
  • 返回当前记录的信号名字。
QByteArray QSignalSpy::signal() const
  • 获取第n次触发的信号信息。
QSignalSpy::at(n)
  • 获取第n次触发的信号参数列表信息。
 QVariantList arguments = spy.at(n);
arguments.at(0).type();
arguments.at(1).type();
...
arguments.at(n).type();
  • 默认等待5秒超时时间,如果在超时范围内触发信号则返回true,否则返回false。
bool QSignalSpy::wait(int timeout = 5000)

应用场景

  该类位于testlib测试模块中,意味着它大多数用于测试场景。比如我们为了验证某个对象的信号触发的次数是否符合预期,就可以使用QSignalSpy的count来验证是否成立。

小例子

#include <QApplication>
#include <QSignalSpy>
#include <QPushButton>
#include <QDebug>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    QPushButton *btn = new QPushButton;
    QSignalSpy spy(btn, &QPushButton::clicked);

    emit btn->click();
    emit btn->click();
    emit btn->click();

    QVariantList arguments = spy.first();
    qDebug() << "name: " << spy.signal();
    qDebug() << "type: " << arguments.at(0).type();
    qDebug() << "count: " << spy.count();

    return a.exec();
}

打印输出:

name:  "clicked(bool)"
type:  QVariant::bool
count:  3

作者:

喜欢围棋和编程。

 
发布于 分类 编程标签

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注