2017-01-13 16:44:45 +03:00
|
|
|
/*
|
|
|
|
* 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>
|
2017-09-01 19:11:43 +03:00
|
|
|
#include <common/syncjournaldb.h>
|
2017-01-13 16:44:45 +03:00
|
|
|
|
|
|
|
using namespace OCC;
|
|
|
|
|
|
|
|
class TestUploadReset : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
|
|
|
|
// Verify that the chunked transfer eventually gets reset with the new chunking
|
|
|
|
void testFileUploadNg() {
|
|
|
|
FakeFolder fakeFolder{FileInfo::A12_B12_C12_S12()};
|
|
|
|
|
|
|
|
fakeFolder.syncEngine().account()->setCapabilities({ { "dav", QVariantMap{
|
|
|
|
{"chunking", "1.0"},
|
|
|
|
{"httpErrorCodesThatResetFailingChunkedUploads", QVariantList{500} } } } });
|
|
|
|
|
|
|
|
const int size = 100 * 1000 * 1000; // 100 MB
|
|
|
|
fakeFolder.localModifier().insert("A/a0", size);
|
|
|
|
QDateTime modTime = QDateTime::currentDateTime();
|
|
|
|
fakeFolder.localModifier().setModTime("A/a0", modTime);
|
|
|
|
|
|
|
|
// Create a transfer id, so we can make the final MOVE fail
|
|
|
|
SyncJournalDb::UploadInfo uploadInfo;
|
|
|
|
uploadInfo._transferid = 1;
|
|
|
|
uploadInfo._valid = true;
|
|
|
|
uploadInfo._modtime = modTime;
|
|
|
|
fakeFolder.syncEngine().journal()->setUploadInfo("A/a0", uploadInfo);
|
|
|
|
|
|
|
|
fakeFolder.uploadState().mkdir("1");
|
|
|
|
fakeFolder.serverErrorPaths().append("1/.file");
|
|
|
|
|
|
|
|
QVERIFY(!fakeFolder.syncOnce());
|
|
|
|
|
|
|
|
uploadInfo = fakeFolder.syncEngine().journal()->getUploadInfo("A/a0");
|
|
|
|
QCOMPARE(uploadInfo._errorCount, 1);
|
|
|
|
QCOMPARE(uploadInfo._transferid, 1);
|
|
|
|
|
|
|
|
fakeFolder.syncEngine().journal()->wipeErrorBlacklist();
|
|
|
|
QVERIFY(!fakeFolder.syncOnce());
|
|
|
|
|
|
|
|
uploadInfo = fakeFolder.syncEngine().journal()->getUploadInfo("A/a0");
|
|
|
|
QCOMPARE(uploadInfo._errorCount, 2);
|
|
|
|
QCOMPARE(uploadInfo._transferid, 1);
|
|
|
|
|
|
|
|
fakeFolder.syncEngine().journal()->wipeErrorBlacklist();
|
|
|
|
QVERIFY(!fakeFolder.syncOnce());
|
|
|
|
|
|
|
|
uploadInfo = fakeFolder.syncEngine().journal()->getUploadInfo("A/a0");
|
|
|
|
QCOMPARE(uploadInfo._errorCount, 3);
|
|
|
|
QCOMPARE(uploadInfo._transferid, 1);
|
|
|
|
|
|
|
|
fakeFolder.syncEngine().journal()->wipeErrorBlacklist();
|
|
|
|
QVERIFY(!fakeFolder.syncOnce());
|
|
|
|
|
|
|
|
uploadInfo = fakeFolder.syncEngine().journal()->getUploadInfo("A/a0");
|
|
|
|
QCOMPARE(uploadInfo._errorCount, 0);
|
|
|
|
QCOMPARE(uploadInfo._transferid, 0);
|
|
|
|
QVERIFY(!uploadInfo._valid);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
QTEST_GUILESS_MAIN(TestUploadReset)
|
|
|
|
#include "testuploadreset.moc"
|