mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-02-02 09:34:58 -05:00
Copy the database in TestGui before opening it.
We don't want to create lock files in the source tree.
This commit is contained in:
parent
7d3fb58cf5
commit
3d1c27ceb7
@ -57,11 +57,21 @@ void TestGui::initTestCase()
|
|||||||
m_tabWidget = m_mainWindow->findChild<DatabaseTabWidget*>("tabWidget");
|
m_tabWidget = m_mainWindow->findChild<DatabaseTabWidget*>("tabWidget");
|
||||||
m_mainWindow->show();
|
m_mainWindow->show();
|
||||||
Tools::wait(50);
|
Tools::wait(50);
|
||||||
|
|
||||||
|
QByteArray tmpData;
|
||||||
|
QFile sourceDbFile(QString(KEEPASSX_TEST_DATA_DIR).append("/NewDatabase.kdbx"));
|
||||||
|
QVERIFY(sourceDbFile.open(QIODevice::ReadOnly));
|
||||||
|
QVERIFY(Tools::readAllFromDevice(&sourceDbFile, tmpData));
|
||||||
|
|
||||||
|
QVERIFY(m_orgDbFile.open());
|
||||||
|
m_orgDbFileName = QFileInfo(m_orgDbFile.fileName()).fileName();
|
||||||
|
QCOMPARE(m_orgDbFile.write(tmpData), static_cast<qint64>((tmpData.size())));
|
||||||
|
m_orgDbFile.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestGui::testOpenDatabase()
|
void TestGui::testOpenDatabase()
|
||||||
{
|
{
|
||||||
fileDialog()->setNextFileName(QString(KEEPASSX_TEST_DATA_DIR).append("/NewDatabase.kdbx"));
|
fileDialog()->setNextFileName(m_orgDbFile.fileName());
|
||||||
triggerAction("actionDatabaseOpen");
|
triggerAction("actionDatabaseOpen");
|
||||||
|
|
||||||
QWidget* databaseOpenWidget = m_mainWindow->findChild<QWidget*>("databaseOpenWidget");
|
QWidget* databaseOpenWidget = m_mainWindow->findChild<QWidget*>("databaseOpenWidget");
|
||||||
@ -75,7 +85,7 @@ void TestGui::testOpenDatabase()
|
|||||||
void TestGui::testTabs()
|
void TestGui::testTabs()
|
||||||
{
|
{
|
||||||
QCOMPARE(m_tabWidget->count(), 1);
|
QCOMPARE(m_tabWidget->count(), 1);
|
||||||
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx"));
|
QCOMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), m_orgDbFileName);
|
||||||
|
|
||||||
m_dbWidget = m_tabWidget->currentDatabaseWidget();
|
m_dbWidget = m_tabWidget->currentDatabaseWidget();
|
||||||
m_db = m_dbWidget->database();
|
m_db = m_dbWidget->database();
|
||||||
@ -103,7 +113,7 @@ void TestGui::testEditEntry()
|
|||||||
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
QTest::mouseClick(editEntryWidgetButtonBox->button(QDialogButtonBox::Ok), Qt::LeftButton);
|
||||||
// make sure the database isn't marked as modified
|
// make sure the database isn't marked as modified
|
||||||
// wait for modified timer
|
// wait for modified timer
|
||||||
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx"));
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), m_orgDbFileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestGui::testAddEntry()
|
void TestGui::testAddEntry()
|
||||||
@ -134,7 +144,7 @@ void TestGui::testAddEntry()
|
|||||||
QCOMPARE(entry->title(), QString("test"));
|
QCOMPARE(entry->title(), QString("test"));
|
||||||
QCOMPARE(entry->historyItems().size(), 0);
|
QCOMPARE(entry->historyItems().size(), 0);
|
||||||
// wait for modified timer
|
// wait for modified timer
|
||||||
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("NewDatabase.kdbx*"));
|
QTRY_COMPARE(m_tabWidget->tabText(m_tabWidget->currentIndex()), QString("%1*").arg(m_orgDbFileName));
|
||||||
|
|
||||||
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
QAction* entryEditAction = m_mainWindow->findChild<QAction*>("actionEntryEdit");
|
||||||
QVERIFY(entryEditAction->isEnabled());
|
QVERIFY(entryEditAction->isEnabled());
|
||||||
@ -352,7 +362,7 @@ void TestGui::testDragAndDropGroup()
|
|||||||
|
|
||||||
void TestGui::testSaveAs()
|
void TestGui::testSaveAs()
|
||||||
{
|
{
|
||||||
QFileInfo fileInfo(QString(KEEPASSX_TEST_DATA_DIR).append("/NewDatabase.kdbx"));
|
QFileInfo fileInfo(m_orgDbFile.fileName());
|
||||||
QDateTime lastModified = fileInfo.lastModified();
|
QDateTime lastModified = fileInfo.lastModified();
|
||||||
|
|
||||||
m_db->metadata()->setName("SaveAs");
|
m_db->metadata()->setName("SaveAs");
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include <QAbstractItemModel>
|
#include <QAbstractItemModel>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
#include <QTemporaryFile>
|
||||||
|
|
||||||
class Database;
|
class Database;
|
||||||
class DatabaseTabWidget;
|
class DatabaseTabWidget;
|
||||||
@ -60,6 +61,8 @@ private:
|
|||||||
MainWindow* m_mainWindow;
|
MainWindow* m_mainWindow;
|
||||||
DatabaseTabWidget* m_tabWidget;
|
DatabaseTabWidget* m_tabWidget;
|
||||||
DatabaseWidget* m_dbWidget;
|
DatabaseWidget* m_dbWidget;
|
||||||
|
QTemporaryFile m_orgDbFile;
|
||||||
|
QString m_orgDbFileName;
|
||||||
QString m_tmpFileName;
|
QString m_tmpFileName;
|
||||||
Database* m_db;
|
Database* m_db;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user