mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-25 06:25:56 +03:00
81 lines
2.8 KiB
C++
81 lines
2.8 KiB
C++
|
/*
|
||
|
* This software is in the public domain, furnished "as is", without technical
|
||
|
* support, and with no warranty, express or implied, as to its usefulness for
|
||
|
* any purpose.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include <QtTest>
|
||
|
#include "syncenginetestutils.h"
|
||
|
#include <syncengine.h>
|
||
|
|
||
|
using namespace OCC;
|
||
|
|
||
|
|
||
|
class TestDatabaseError : public QObject
|
||
|
{
|
||
|
Q_OBJECT
|
||
|
|
||
|
private slots:
|
||
|
void testDatabaseError() {
|
||
|
/* This test will make many iteration, at each iteration, the iᵗʰ database access will fail.
|
||
|
* The test ensure that if there is a failure, the next sync recovers. And if there was
|
||
|
* no error, then everything was sync'ed properly.
|
||
|
*/
|
||
|
|
||
|
FileInfo finalState;
|
||
|
for (int count = 0; true; ++count) {
|
||
|
qInfo() << "Starting Iteration" << count;
|
||
|
|
||
|
FakeFolder fakeFolder{FileInfo::A12_B12_C12_S12()};
|
||
|
|
||
|
// Do a couple of changes
|
||
|
fakeFolder.remoteModifier().insert("A/a0");
|
||
|
fakeFolder.remoteModifier().appendByte("A/a1");
|
||
|
fakeFolder.remoteModifier().remove("A/a2");
|
||
|
fakeFolder.remoteModifier().rename("S/s1", "S/s1_renamed");
|
||
|
fakeFolder.remoteModifier().mkdir("D");
|
||
|
fakeFolder.remoteModifier().mkdir("D/subdir");
|
||
|
fakeFolder.remoteModifier().insert("D/subdir/file");
|
||
|
fakeFolder.localModifier().insert("B/b0");
|
||
|
fakeFolder.localModifier().appendByte("B/b1");
|
||
|
fakeFolder.remoteModifier().remove("B/b2");
|
||
|
fakeFolder.localModifier().mkdir("NewDir");
|
||
|
fakeFolder.localModifier().rename("C", "NewDir/C");
|
||
|
|
||
|
// Set the counter
|
||
|
fakeFolder.syncJournal().autotestFailCounter = count;
|
||
|
|
||
|
// run the sync
|
||
|
bool result = fakeFolder.syncOnce();
|
||
|
|
||
|
qInfo() << "Result of iteration" << count << "was" << result;
|
||
|
|
||
|
if (fakeFolder.syncJournal().autotestFailCounter >= 0) {
|
||
|
// No error was thrown, we are finished
|
||
|
QVERIFY(result);
|
||
|
QCOMPARE(fakeFolder.currentLocalState(), fakeFolder.currentRemoteState());
|
||
|
QCOMPARE(fakeFolder.currentRemoteState(), finalState);
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (!result) {
|
||
|
fakeFolder.syncJournal().autotestFailCounter = -1;
|
||
|
// Try again
|
||
|
QVERIFY(fakeFolder.syncOnce());
|
||
|
}
|
||
|
|
||
|
QCOMPARE(fakeFolder.currentLocalState(), fakeFolder.currentRemoteState());
|
||
|
if (count == 0) {
|
||
|
finalState = fakeFolder.currentRemoteState();
|
||
|
} else {
|
||
|
// the final state should be the same for every iteration
|
||
|
QCOMPARE(fakeFolder.currentRemoteState(), finalState);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
|
||
|
QTEST_GUILESS_MAIN(TestDatabaseError)
|
||
|
#include "testdatabaseerror.moc"
|