mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-25 22:16:01 -05:00
Speed up TestGui by removing unnecessary waits.
Backport QTRY_VERIFY and QTRY_COMPARE from Qt 5.
This commit is contained in:
parent
5786d0c279
commit
2185afefed
@ -60,7 +60,6 @@ void TestGui::testOpenDatabase()
|
|||||||
{
|
{
|
||||||
fileDialog()->setNextFileName(QString(KEEPASSX_TEST_DATA_DIR).append("/NewDatabase.kdbx"));
|
fileDialog()->setNextFileName(QString(KEEPASSX_TEST_DATA_DIR).append("/NewDatabase.kdbx"));
|
||||||
triggerAction("actionDatabaseOpen");
|
triggerAction("actionDatabaseOpen");
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QWidget* databaseOpenWidget = m_mainWindow->findChild<QWidget*>("databaseOpenWidget");
|
QWidget* databaseOpenWidget = m_mainWindow->findChild<QWidget*>("databaseOpenWidget");
|
||||||
QLineEdit* editPassword = databaseOpenWidget->findChild<QLineEdit*>("editPassword");
|
QLineEdit* editPassword = databaseOpenWidget->findChild<QLineEdit*>("editPassword");
|
||||||
@ -68,8 +67,6 @@ void TestGui::testOpenDatabase()
|
|||||||
|
|
||||||
QTest::keyClicks(editPassword, "a");
|
QTest::keyClicks(editPassword, "a");
|
||||||
QTest::keyClick(editPassword, Qt::Key_Enter);
|
QTest::keyClick(editPassword, Qt::Key_Enter);
|
||||||
|
|
||||||
QTest::qWait(20);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestGui::testTabs()
|
void TestGui::testTabs()
|
||||||
@ -87,7 +84,6 @@ void TestGui::testEditEntry()
|
|||||||
QModelIndex item = entryView->model()->index(0, 1);
|
QModelIndex item = entryView->model()->index(0, 1);
|
||||||
QRect itemRect = entryView->visualRect(item);
|
QRect itemRect = entryView->visualRect(item);
|
||||||
QTest::mouseClick(entryView->viewport(), Qt::LeftButton, Qt::NoModifier, itemRect.center());
|
QTest::mouseClick(entryView->viewport(), Qt::LeftButton, Qt::NoModifier, itemRect.center());
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
||||||
QVERIFY(entryEditAction->isEnabled());
|
QVERIFY(entryEditAction->isEnabled());
|
||||||
@ -96,16 +92,15 @@ void TestGui::testEditEntry()
|
|||||||
QVERIFY(entryEditWidget->isVisible());
|
QVERIFY(entryEditWidget->isVisible());
|
||||||
QVERIFY(entryEditWidget->isEnabled());
|
QVERIFY(entryEditWidget->isEnabled());
|
||||||
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
||||||
QVERIFY(m_dbWidget->currentWidget() == editEntryWidget);
|
QVERIFY(m_dbWidget->currentWidget() == editEntryWidget);
|
||||||
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
||||||
QVERIFY(editEntryWidgetButtonBox);
|
QVERIFY(editEntryWidgetButtonBox);
|
||||||
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
||||||
QTest::qWait(200); // wait for modified timer
|
|
||||||
// make sure the database isn't marked as modified
|
// make sure the database isn't marked as modified
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx"));
|
// wait for modified timer
|
||||||
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestGui::testAddEntry()
|
void TestGui::testAddEntry()
|
||||||
@ -119,18 +114,15 @@ void TestGui::testAddEntry()
|
|||||||
QVERIFY(entryNewWidget->isEnabled());
|
QVERIFY(entryNewWidget->isEnabled());
|
||||||
|
|
||||||
QTest::mouseClick(entryNewWidget, Qt::LeftButton);
|
QTest::mouseClick(entryNewWidget, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
||||||
|
|
||||||
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
||||||
QLineEdit* titleEdit = editEntryWidget->findChild<QLineEdit*>("titleEdit");
|
QLineEdit* titleEdit = editEntryWidget->findChild<QLineEdit*>("titleEdit");
|
||||||
QTest::keyClicks(titleEdit, "test");
|
QTest::keyClicks(titleEdit, "test");
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
||||||
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::ViewMode);
|
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::ViewMode);
|
||||||
QModelIndex item = entryView->model()->index(1, 1);
|
QModelIndex item = entryView->model()->index(1, 1);
|
||||||
@ -138,8 +130,8 @@ void TestGui::testAddEntry()
|
|||||||
|
|
||||||
QCOMPARE(entry->title(), QString("test"));
|
QCOMPARE(entry->title(), QString("test"));
|
||||||
QCOMPARE(entry->historyItems().size(), 0);
|
QCOMPARE(entry->historyItems().size(), 0);
|
||||||
QTest::qWait(200); // wait for modified timer
|
// wait for modified timer
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx*"));
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx*"));
|
||||||
|
|
||||||
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
||||||
QVERIFY(entryEditAction->isEnabled());
|
QVERIFY(entryEditAction->isEnabled());
|
||||||
@ -147,12 +139,10 @@ void TestGui::testAddEntry()
|
|||||||
QVERIFY(entryEditWidget->isVisible());
|
QVERIFY(entryEditWidget->isVisible());
|
||||||
QVERIFY(entryEditWidget->isEnabled());
|
QVERIFY(entryEditWidget->isEnabled());
|
||||||
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
||||||
QTest::keyClicks(titleEdit, "something");
|
QTest::keyClicks(titleEdit, "something");
|
||||||
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(entry->title(), QString("testsomething"));
|
QCOMPARE(entry->title(), QString("testsomething"));
|
||||||
QCOMPARE(entry->historyItems().size(), 1);
|
QCOMPARE(entry->historyItems().size(), 1);
|
||||||
@ -167,22 +157,19 @@ void TestGui::testSearch()
|
|||||||
QVERIFY(searchActionWidget->isVisible());
|
QVERIFY(searchActionWidget->isVisible());
|
||||||
QVERIFY(searchActionWidget->isEnabled());
|
QVERIFY(searchActionWidget->isEnabled());
|
||||||
QTest::mouseClick(searchActionWidget, Qt::LeftButton);
|
QTest::mouseClick(searchActionWidget, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
EntryView* entryView = m_dbWidget->findChild<EntryView*>("entryView");
|
EntryView* entryView = m_dbWidget->findChild<EntryView*>("entryView");
|
||||||
QLineEdit* searchEdit = m_dbWidget->findChild<QLineEdit*>("searchEdit");
|
QLineEdit* searchEdit = m_dbWidget->findChild<QLineEdit*>("searchEdit");
|
||||||
QToolButton* clearSearch = m_dbWidget->findChild<QToolButton*>("clearButton");
|
QToolButton* clearSearch = m_dbWidget->findChild<QToolButton*>("clearButton");
|
||||||
|
|
||||||
QTest::keyClicks(searchEdit, "ZZZ");
|
QTest::keyClicks(searchEdit, "ZZZ");
|
||||||
QTest::qWait(200);
|
|
||||||
|
|
||||||
QCOMPARE(entryView->model()->rowCount(), 0);
|
QTRY_COMPARE(entryView->model()->rowCount(), 0);
|
||||||
|
|
||||||
QTest::mouseClick(clearSearch, Qt::LeftButton);
|
QTest::mouseClick(clearSearch, Qt::LeftButton);
|
||||||
QTest::keyClicks(searchEdit, "some");
|
QTest::keyClicks(searchEdit, "some");
|
||||||
QTest::qWait(200);
|
|
||||||
|
|
||||||
QCOMPARE(entryView->model()->rowCount(), 2);
|
QTRY_COMPARE(entryView->model()->rowCount(), 2);
|
||||||
|
|
||||||
QModelIndex item = entryView->model()->index(0, 1);
|
QModelIndex item = entryView->model()->index(0, 1);
|
||||||
QRect itemRect = entryView->visualRect(item);
|
QRect itemRect = entryView->visualRect(item);
|
||||||
@ -193,14 +180,12 @@ void TestGui::testSearch()
|
|||||||
QVERIFY(entryEditWidget->isVisible());
|
QVERIFY(entryEditWidget->isVisible());
|
||||||
QVERIFY(entryEditWidget->isEnabled());
|
QVERIFY(entryEditWidget->isEnabled());
|
||||||
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
QTest::mouseClick(entryEditWidget, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::EditMode);
|
||||||
|
|
||||||
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
EditEntryWidget* editEntryWidget = m_dbWidget->findChild<EditEntryWidget*>("editEntryWidget");
|
||||||
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
QDialogButtonBox* editEntryWidgetButtonBox = editEntryWidget->findChild<QDialogButtonBox*>("buttonBox");
|
||||||
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::ViewMode);
|
QCOMPARE(m_dbWidget->currentMode(), DatabaseWidget::ViewMode);
|
||||||
|
|
||||||
@ -216,7 +201,6 @@ void TestGui::testSearch()
|
|||||||
QTest::mouseClick(entryDeleteWidget, Qt::LeftButton);
|
QTest::mouseClick(entryDeleteWidget, Qt::LeftButton);
|
||||||
QWidget* closeSearchButton = m_dbWidget->findChild<QToolButton*>("closeSearchButton");
|
QWidget* closeSearchButton = m_dbWidget->findChild<QToolButton*>("closeSearchButton");
|
||||||
QTest::mouseClick(closeSearchButton, Qt::LeftButton);
|
QTest::mouseClick(closeSearchButton, Qt::LeftButton);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(entryView->model()->rowCount(), 1);
|
QCOMPARE(entryView->model()->rowCount(), 1);
|
||||||
}
|
}
|
||||||
@ -231,7 +215,6 @@ void TestGui::testCloneEntry()
|
|||||||
Entry* entryOrg = entryView->entryFromIndex(item);
|
Entry* entryOrg = entryView->entryFromIndex(item);
|
||||||
QRect itemRect = entryView->visualRect(item);
|
QRect itemRect = entryView->visualRect(item);
|
||||||
QTest::mouseClick(entryView->viewport(), Qt::LeftButton, Qt::NoModifier, itemRect.center());
|
QTest::mouseClick(entryView->viewport(), Qt::LeftButton, Qt::NoModifier, itemRect.center());
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
triggerAction("actionEntryClone");
|
triggerAction("actionEntryClone");
|
||||||
|
|
||||||
@ -311,8 +294,8 @@ void TestGui::testSaveAs()
|
|||||||
void TestGui::testSave()
|
void TestGui::testSave()
|
||||||
{
|
{
|
||||||
m_db->metadata()->setName("Save");
|
m_db->metadata()->setName("Save");
|
||||||
QTest::qWait(200); // wait for modified timer
|
// wait for modified timer
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save*"));
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save*"));
|
||||||
|
|
||||||
triggerAction("actionDatabaseSave");
|
triggerAction("actionDatabaseSave");
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save"));
|
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save"));
|
||||||
@ -327,8 +310,8 @@ void TestGui::testDatabaseSettings()
|
|||||||
QSpinBox* transformRoundsSpinBox = dbSettingsWidget->findChild<QSpinBox*>("transformRoundsSpinBox");
|
QSpinBox* transformRoundsSpinBox = dbSettingsWidget->findChild<QSpinBox*>("transformRoundsSpinBox");
|
||||||
transformRoundsSpinBox->setValue(100);
|
transformRoundsSpinBox->setValue(100);
|
||||||
QTest::keyClick(transformRoundsSpinBox, Qt::Key_Enter);
|
QTest::keyClick(transformRoundsSpinBox, Qt::Key_Enter);
|
||||||
QTest::qWait(200); // wait for modified timer
|
// wait for modified timer
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save*"));
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("Save*"));
|
||||||
QCOMPARE(m_db->transformRounds(), Q_UINT64_C(100));
|
QCOMPARE(m_db->transformRounds(), Q_UINT64_C(100));
|
||||||
|
|
||||||
triggerAction("actionDatabaseSave");
|
triggerAction("actionDatabaseSave");
|
||||||
@ -341,7 +324,6 @@ void TestGui::testKeePass1Import()
|
|||||||
{
|
{
|
||||||
fileDialog()->setNextFileName(QString(KEEPASSX_TEST_DATA_DIR).append("/basic.kdb"));
|
fileDialog()->setNextFileName(QString(KEEPASSX_TEST_DATA_DIR).append("/basic.kdb"));
|
||||||
triggerAction("actionImportKeePass1");
|
triggerAction("actionImportKeePass1");
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QWidget* keepass1OpenWidget = m_mainWindow->findChild<QWidget*>("keepass1OpenWidget");
|
QWidget* keepass1OpenWidget = m_mainWindow->findChild<QWidget*>("keepass1OpenWidget");
|
||||||
QLineEdit* editPassword = keepass1OpenWidget->findChild<QLineEdit*>("editPassword");
|
QLineEdit* editPassword = keepass1OpenWidget->findChild<QLineEdit*>("editPassword");
|
||||||
@ -349,7 +331,6 @@ void TestGui::testKeePass1Import()
|
|||||||
|
|
||||||
QTest::keyClicks(editPassword, "masterpw");
|
QTest::keyClicks(editPassword, "masterpw");
|
||||||
QTest::keyClick(editPassword, Qt::Key_Enter);
|
QTest::keyClick(editPassword, Qt::Key_Enter);
|
||||||
QTest::qWait(20);
|
|
||||||
|
|
||||||
QCOMPARE(m_tabWidget->count(), 2);
|
QCOMPARE(m_tabWidget->count(), 2);
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("basic [New database]*"));
|
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("basic [New database]*"));
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2011 Felix Geyer <debfx@fobos.de>
|
* Copyright (C) 2011 Felix Geyer <debfx@fobos.de>
|
||||||
|
* Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -31,4 +32,41 @@ int main(int argc, char* argv[]) \
|
|||||||
// just for the sake of a consistent naming scheme
|
// just for the sake of a consistent naming scheme
|
||||||
#define KEEPASSX_QTEST_GUI_MAIN QTEST_MAIN
|
#define KEEPASSX_QTEST_GUI_MAIN QTEST_MAIN
|
||||||
|
|
||||||
|
|
||||||
|
// backport QTRY_VERIFY and QTRY_COMPARE from Qt 5
|
||||||
|
|
||||||
|
#ifndef QTRY_VERIFY
|
||||||
|
#define KEEPASSX_VERIFY_WITH_TIMEOUT(__expr, __timeout) \
|
||||||
|
do { \
|
||||||
|
const int __step = 50; \
|
||||||
|
const int __timeoutValue = __timeout; \
|
||||||
|
if (!(__expr)) { \
|
||||||
|
QTest::qWait(0); \
|
||||||
|
} \
|
||||||
|
for (int __i = 0; __i < __timeoutValue && !(__expr); __i+=__step) { \
|
||||||
|
QTest::qWait(__step); \
|
||||||
|
} \
|
||||||
|
QVERIFY(__expr); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define QTRY_VERIFY(__expr) KEEPASSX_VERIFY_WITH_TIMEOUT(__expr, 5000)
|
||||||
|
#endif // QTRY_VERIFY
|
||||||
|
|
||||||
|
#ifndef QTRY_COMPARE
|
||||||
|
#define KEEPASSX_COMPARE_WITH_TIMEOUT(__expr, __expected, __timeout) \
|
||||||
|
do { \
|
||||||
|
const int __step = 50; \
|
||||||
|
const int __timeoutValue = __timeout; \
|
||||||
|
if ((__expr) != (__expected)) { \
|
||||||
|
QTest::qWait(0); \
|
||||||
|
} \
|
||||||
|
for (int __i = 0; __i < __timeoutValue && ((__expr) != (__expected)); __i+=__step) { \
|
||||||
|
QTest::qWait(__step); \
|
||||||
|
} \
|
||||||
|
QCOMPARE(__expr, __expected); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define QTRY_COMPARE(__expr, __expected) KEEPASSX_COMPARE_WITH_TIMEOUT(__expr, __expected, 5000)
|
||||||
|
#endif // QTRY_COMPARE
|
||||||
|
|
||||||
#endif // KEEPASSX_TESTS_H
|
#endif // KEEPASSX_TESTS_H
|
||||||
|
Loading…
x
Reference in New Issue
Block a user