From 058b4da954f6901600416e26c7ab588daad4202c Mon Sep 17 00:00:00 2001 From: libklein <42714034+libklein@users.noreply.github.com> Date: Sat, 5 Oct 2019 19:58:00 +0200 Subject: [PATCH] Fix entry clone modification time update (#3602) * Add test for (unwanted) history timeinfo update when cloning entries. * Add timeInfo test for clone with rename. * Fixed modification time update when cloning an entry with renaming. --- src/core/Entry.cpp | 5 +++-- tests/TestEntry.cpp | 32 +++++++++++++++++++++++++++++--- 2 files changed, 32 insertions(+), 5 deletions(-) diff --git a/src/core/Entry.cpp b/src/core/Entry.cpp index fffa329bd..60d64167a 100644 --- a/src/core/Entry.cpp +++ b/src/core/Entry.cpp @@ -762,14 +762,13 @@ Entry* Entry::clone(CloneFlags flags) const entry->m_autoTypeAssociations->copyDataFrom(m_autoTypeAssociations); if (flags & CloneIncludeHistory) { for (Entry* historyItem : m_history) { - Entry* historyItemClone = historyItem->clone(flags & ~CloneIncludeHistory & ~CloneNewUuid); + Entry* historyItemClone = historyItem->clone(flags & ~CloneIncludeHistory & ~CloneNewUuid & ~CloneResetTimeInfo); historyItemClone->setUpdateTimeinfo(false); historyItemClone->setUuid(entry->uuid()); historyItemClone->setUpdateTimeinfo(true); entry->addHistoryItem(historyItemClone); } } - entry->setUpdateTimeinfo(true); if (flags & CloneResetTimeInfo) { QDateTime now = Clock::currentDateTimeUtc(); @@ -782,6 +781,8 @@ Entry* Entry::clone(CloneFlags flags) const if (flags & CloneRenameTitle) entry->setTitle(tr("%1 - Clone").arg(entry->title())); + entry->setUpdateTimeinfo(true); + return entry; } diff --git a/tests/TestEntry.cpp b/tests/TestEntry.cpp index 5552549fe..708654a6a 100644 --- a/tests/TestEntry.cpp +++ b/tests/TestEntry.cpp @@ -107,18 +107,44 @@ void TestEntry::testClone() QCOMPARE(entryCloneNewUuid->historyItems().size(), 0); QCOMPARE(entryCloneNewUuid->timeInfo().creationTime(), entryOrg->timeInfo().creationTime()); + // Reset modification time + entryOrgTime.setLastModificationTime(Clock::datetimeUtc(60)); + entryOrg->setTimeInfo(entryOrgTime); + + QScopedPointer entryCloneRename(entryOrg->clone(Entry::CloneRenameTitle)); + QCOMPARE(entryCloneRename->uuid(), entryOrg->uuid()); + QCOMPARE(entryCloneRename->title(), QString("New Title - Clone")); + // Cloning should not modify time info unless explicity requested + QCOMPARE(entryCloneRename->timeInfo(), entryOrg->timeInfo()); + QScopedPointer entryCloneResetTime(entryOrg->clone(Entry::CloneResetTimeInfo)); QCOMPARE(entryCloneResetTime->uuid(), entryOrg->uuid()); QCOMPARE(entryCloneResetTime->title(), QString("New Title")); QCOMPARE(entryCloneResetTime->historyItems().size(), 0); QVERIFY(entryCloneResetTime->timeInfo().creationTime() != entryOrg->timeInfo().creationTime()); - QScopedPointer entryCloneHistory(entryOrg->clone(Entry::CloneIncludeHistory)); + // Date back history of original entry + Entry * firstHistoryItem = entryOrg->historyItems()[0]; + TimeInfo entryOrgHistoryTimeInfo = firstHistoryItem->timeInfo(); + QDateTime datedBackEntryOrgModificationTime = entryOrgHistoryTimeInfo.lastModificationTime().addMSecs(-10); + entryOrgHistoryTimeInfo.setLastModificationTime(datedBackEntryOrgModificationTime); + entryOrgHistoryTimeInfo.setCreationTime(datedBackEntryOrgModificationTime); + firstHistoryItem->setTimeInfo(entryOrgHistoryTimeInfo); + + QScopedPointer entryCloneHistory(entryOrg->clone(Entry::CloneIncludeHistory | Entry::CloneResetTimeInfo)); QCOMPARE(entryCloneHistory->uuid(), entryOrg->uuid()); QCOMPARE(entryCloneHistory->title(), QString("New Title")); - QCOMPARE(entryCloneHistory->historyItems().size(), 1); + QCOMPARE(entryCloneHistory->historyItems().size(), entryOrg->historyItems().size()); QCOMPARE(entryCloneHistory->historyItems().at(0)->title(), QString("Original Title")); - QCOMPARE(entryCloneHistory->timeInfo().creationTime(), entryOrg->timeInfo().creationTime()); + QVERIFY(entryCloneHistory->timeInfo().creationTime() != entryOrg->timeInfo().creationTime()); + // Timeinfo of history items should not be modified + QList entryOrgHistory = entryOrg->historyItems(), clonedHistory = entryCloneHistory->historyItems(); + auto entryOrgHistoryItem = entryOrgHistory.constBegin(); + for(auto entryCloneHistoryItem = clonedHistory.constBegin() + ;entryCloneHistoryItem != clonedHistory.constEnd() + ;++entryCloneHistoryItem, ++entryOrgHistoryItem) { + QCOMPARE((*entryOrgHistoryItem)->timeInfo(), (*entryCloneHistoryItem)->timeInfo()); + } Database db; auto* entryOrgClone = entryOrg->clone(Entry::CloneNoFlags);