mirror of
https://github.com/nextcloud/desktop.git
synced 2025-10-26 11:17:43 +00:00
To be able to test the SyncEngine efficiently, a set of server mocking classes have been implemented on top of QNetworkAccessManager. The local disk side hasn't been mocked since this would require adding a large abstraction layer in csync. The SyncEngine is instead pointed to a different temporary dir in each test and we test by interacting with files in this directory instead. The FakeFolder object wraps the SyncEngine with those abstractions and allow controlling the local files, and the fake remote state through the FileModifier interface, using a FileInfo tree structure for the remote-side implementation as well as feeding and comparing the states on both side in tests. Tests run fast and require no setup to be run, but each server feature that we want to test on the client side needs to be implemented in this fake objects library. For example, the OC-FileId header isn't set as of this commit, and we can't test the file move logic properly without implementing it first. The TestSyncFileStatusTracker tests already contain a few QEXPECT_FAIL for what I esteem being issues that need to be fixed in order to catch up on our test coverage without making this patch too huge.
97 lines
2.3 KiB
C++
97 lines
2.3 KiB
C++
/*
|
|
* Copyright (C) by Christian Kamm <mail@ckamm.com>
|
|
*
|
|
* 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
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*/
|
|
|
|
#include "excludedfiles.h"
|
|
|
|
#include <QFileInfo>
|
|
|
|
extern "C" {
|
|
#include "std/c_string.h"
|
|
#include "csync.h"
|
|
#include "csync_exclude.h"
|
|
}
|
|
|
|
using namespace OCC;
|
|
|
|
ExcludedFiles::ExcludedFiles(c_strlist_t** excludesPtr)
|
|
: _excludesPtr(excludesPtr)
|
|
{
|
|
}
|
|
|
|
ExcludedFiles::~ExcludedFiles()
|
|
{
|
|
c_strlist_destroy(*_excludesPtr);
|
|
}
|
|
|
|
ExcludedFiles& ExcludedFiles::instance()
|
|
{
|
|
static c_strlist_t* globalExcludes;
|
|
static ExcludedFiles inst(&globalExcludes);
|
|
return inst;
|
|
}
|
|
|
|
void ExcludedFiles::addExcludeFilePath(const QString& path)
|
|
{
|
|
_excludeFiles.insert(path);
|
|
}
|
|
|
|
#ifdef WITH_UNIT_TESTING
|
|
void ExcludedFiles::addExcludeExpr(const QString &expr)
|
|
{
|
|
_csync_exclude_add(_excludesPtr, expr.toLatin1().constData());
|
|
}
|
|
#endif
|
|
|
|
bool ExcludedFiles::reloadExcludes()
|
|
{
|
|
c_strlist_destroy(*_excludesPtr);
|
|
*_excludesPtr = NULL;
|
|
|
|
bool success = true;
|
|
foreach (const QString& file, _excludeFiles) {
|
|
if (csync_exclude_load(file.toUtf8(), _excludesPtr) < 0)
|
|
success = false;
|
|
}
|
|
return success;
|
|
}
|
|
|
|
bool ExcludedFiles::isExcluded(
|
|
const QString& filePath,
|
|
const QString& basePath,
|
|
bool excludeHidden) const
|
|
{
|
|
if (!filePath.startsWith(basePath)) {
|
|
// Mark paths we're not responsible for as excluded...
|
|
return true;
|
|
}
|
|
|
|
QFileInfo fi(filePath);
|
|
if( excludeHidden ) {
|
|
if( fi.isHidden() || fi.fileName().startsWith(QLatin1Char('.')) ) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
csync_ftw_type_e type = CSYNC_FTW_TYPE_FILE;
|
|
if (fi.isDir()) {
|
|
type = CSYNC_FTW_TYPE_DIR;
|
|
}
|
|
|
|
QString relativePath = filePath.mid(basePath.size());
|
|
if (relativePath.endsWith(QLatin1Char('/'))) {
|
|
relativePath.chop(1);
|
|
}
|
|
|
|
return csync_excluded_no_ctx(*_excludesPtr, relativePath.toUtf8(), type) != CSYNC_NOT_EXCLUDED;
|
|
}
|