3

我正在使用QTest在我的应用程序中创建一些自动化GUI 测试

我可以使用以下命令从我的应用程序访问小部件:

savePushButton = mainWindow->findChild<QPushButton *>("savePushButton");

它工作正常,但现在我必须单击QMessageBox的 OK 按钮。

我在我的应用程序中创建了QMessageBox,如下所示:

if( something_wrong )
{
    QMessageBox::warning(new Widget(), "Title", "Something wrong!");
}

我如何才能访问此QMessageBox及其按钮?

4

2 回答 2

5

我在以下链接上找到了解决方案:http ://www.qtcentre.org/threads/31239-Testing-modal-dialogs-with-QTestLib 。

它使用命令QApplication::topLevelWidgets();来获取小部件列表。然后它搜索消息框小部件并模拟一个键 enter ( QTest::keyClick(mb, Qt::Key_Enter);) 来关闭消息框。

例子:

void MyTest::testDialog()
{
    QTimer::singleShot(500, this, SLOT(timeOut()));
    QVERIFY(functionThatProducesMessageBox());
}

void MyTest::timeOut()
{
    QWidgetList allToplevelWidgets = QApplication::topLevelWidgets();
    foreach (QWidget *w, allToplevelWidgets) {
        if (w->inherits("QMessageBox")) {
            QMessageBox *mb = qobject_cast<QMessageBox *>(w);
            QTest::keyClick(mb, Qt::Key_Enter);
        }
    }
}

头文件必须包含Q_OBJECT宏才能使用信号和槽机制。例子:

class MyClass: public QWidget
{
    Q_OBJECT
public:
    ...

它对我来说效果很好,因为当消息框出现时 UI(线程)被阻止。

注意:记得在添加Q_OBJECT宏时重建项目。

于 2016-08-02T22:35:42.547 回答
2

查看Qt 的自动测试通常会有所帮助:

void ExecCloseHelper::timerEvent(QTimerEvent *te)
{
    if (te->timerId() != m_timerId)
        return;

    QWidget *modalWidget = QApplication::activeModalWidget();

    if (!m_testCandidate && modalWidget)
        m_testCandidate = modalWidget;

    if (m_testCandidate && m_testCandidate == modalWidget) {
        if (m_key == CloseWindow) {
            m_testCandidate->close();
        } else {
            QKeyEvent *ke = new QKeyEvent(QEvent::KeyPress, m_key, Qt::NoModifier);
            QCoreApplication::postEvent(m_testCandidate, ke);
        }
        m_testCandidate = Q_NULLPTR;
        killTimer(m_timerId);
        m_timerId = m_key = 0;
    }
}

从该代码来看,您可以通过QApplication::activeModalWidget(). 测试原生(我假设它们是原生的)小部件很困难,这可能是它们选择发送关键事件的原因,因为您不需要知道这些按钮的位置,就像使用鼠标一样点击。

于 2016-07-26T18:16:31.917 回答