summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Changelog3
-rw-r--r--src/libs/kdtools/kdupdaterupdateoperations.cpp61
-rw-r--r--tests/auto/installer/installer.pro3
-rw-r--r--tests/auto/installer/mkdiroperationtest/mkdiroperationtest.pro6
-rw-r--r--tests/auto/installer/mkdiroperationtest/tst_mkdiroperationtest.cpp169
5 files changed, 221 insertions, 21 deletions
diff --git a/Changelog b/Changelog
index 8e0d64a87..8ce773ddd 100644
--- a/Changelog
+++ b/Changelog
@@ -43,5 +43,6 @@
- Now continues on unknown operations.
- Fixed error handling in 7z lib.
- Added a DisplayName setting for repositories. (QTIFW-244)
+- Chinese Translation added
- Documentation fixes and additions.
-- Bugfixes
+- Bugfixes (QTIFW-271 et al)
diff --git a/src/libs/kdtools/kdupdaterupdateoperations.cpp b/src/libs/kdtools/kdupdaterupdateoperations.cpp
index 484df9838..41f9ef289 100644
--- a/src/libs/kdtools/kdupdaterupdateoperations.cpp
+++ b/src/libs/kdtools/kdupdaterupdateoperations.cpp
@@ -45,6 +45,34 @@ static QString errnoToQString(int error)
#endif
}
+static bool removeDirectory(const QString &path, QString *errorString, bool force = true)
+{
+ Q_ASSERT(errorString);
+ const QFileInfoList entries = QDir(path).entryInfoList(QDir::NoDotAndDotDot | QDir::AllEntries | QDir::Hidden);
+ for (QFileInfoList::const_iterator it = entries.constBegin(); it != entries.constEnd(); ++it) {
+ if (it->isDir() && !it->isSymLink()) {
+ removeDirectory(it->filePath(), errorString, force);
+ } else if (force) {
+ QFile f(it->filePath());
+ if (!f.remove())
+ return false;
+ }
+ }
+
+ // even remove some hidden, OS-created files in there
+#if defined Q_OS_MAC
+ QFile::remove(path + QLatin1String("/.DS_Store"));
+#elif defined Q_OS_WIN
+ QFile::remove(path + QLatin1String("/Thumbs.db"));
+#endif
+
+ errno = 0;
+ const bool success = QDir().rmdir(path);
+ if (errno)
+ *errorString = errnoToQString(errno);
+ return success;
+}
+
/*
* \internal
* Returns a filename for a temporary file based on \a templateName
@@ -394,9 +422,8 @@ void MkdirOperation::backup()
bool MkdirOperation::performOperation()
{
- // Requires only one parameter. That is the name of
- // the file to remove.
- const QStringList args = this->arguments();
+ // Requires only one parameter. That is the path which should be created
+ QStringList args = this->arguments();
if (args.count() != 1) {
setError(InvalidArguments);
setErrorString(tr("Invalid arguments: %1 arguments given, 1 expected.").arg(args.count()));
@@ -416,7 +443,10 @@ bool MkdirOperation::undoOperation()
{
Q_ASSERT(arguments().count() == 1);
- QDir createdDir = QDir(value(QLatin1String("createddir")).toString());
+ QString createdDirValue = value(QLatin1String("createddir")).toString();
+ if (createdDirValue.isEmpty())
+ createdDirValue = arguments().first();
+ QDir createdDir = QDir(createdDirValue);
const bool forceremoval = QVariant(value(QLatin1String("forceremoval"))).toBool();
// Since refactoring we know the mkdir operation which is creating the target path. If we do a full
@@ -430,23 +460,16 @@ bool MkdirOperation::undoOperation()
if (!createdDir.exists())
return true;
- if (forceremoval) {
- try {
- QInstaller::removeDirectory(createdDir.path());
- } catch (const QInstaller::Error &error) {
- setError(UserDefinedError, error.message());
- return false;
- }
- return true;
- }
+ QString errorString;
- // remove some hidden, OS-created files in there
- QInstaller::removeSystemGeneratedFiles(createdDir.path());
+ const bool result = removeDirectory(createdDir.path(), &errorString, forceremoval);
- errno = 0;
- const bool result = QDir::root().rmdir(createdDir.path());
- if (!result)
- setError(UserDefinedError, tr("Cannot remove directory %1: %2").arg(createdDir.path(), errnoToQString(errno)));
+ if (!result) {
+ if (errorString.isEmpty())
+ setError(UserDefinedError, tr("Cannot remove directory %1: %2").arg(createdDir.path(), errorString));
+ else
+ setError(UserDefinedError, tr("Cannot remove directory %1: %2").arg(createdDir.path(), errnoToQString(errno)));
+ }
return result;
}
diff --git a/tests/auto/installer/installer.pro b/tests/auto/installer/installer.pro
index 13acba4f1..fea58129d 100644
--- a/tests/auto/installer/installer.pro
+++ b/tests/auto/installer/installer.pro
@@ -9,4 +9,5 @@ SUBDIRS += \
extractarchiveoperationtest \
lib7zfacade \
scriptengine \
- consumeoutputoperationtest
+ consumeoutputoperationtest \
+ mkdiroperationtest
diff --git a/tests/auto/installer/mkdiroperationtest/mkdiroperationtest.pro b/tests/auto/installer/mkdiroperationtest/mkdiroperationtest.pro
new file mode 100644
index 000000000..19ca5819c
--- /dev/null
+++ b/tests/auto/installer/mkdiroperationtest/mkdiroperationtest.pro
@@ -0,0 +1,6 @@
+include(../../qttest.pri)
+
+QT -= gui
+QT += testlib
+
+SOURCES = tst_mkdiroperationtest.cpp
diff --git a/tests/auto/installer/mkdiroperationtest/tst_mkdiroperationtest.cpp b/tests/auto/installer/mkdiroperationtest/tst_mkdiroperationtest.cpp
new file mode 100644
index 000000000..fd427400d
--- /dev/null
+++ b/tests/auto/installer/mkdiroperationtest/tst_mkdiroperationtest.cpp
@@ -0,0 +1,169 @@
+/**************************************************************************
+**
+** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of the Qt Installer Framework.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights. These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3.0 as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU General Public License version 3.0 requirements will be
+** met: http://www.gnu.org/copyleft/gpl.html.
+**
+**
+** $QT_END_LICENSE$
+**
+**************************************************************************/
+
+#include "init.h"
+#include "kdupdaterupdateoperations.h"
+
+#include <QDir>
+#include <QObject>
+#include <QTest>
+#include <QFile>
+#include <QTextStream>
+
+using namespace KDUpdater;
+using namespace QInstaller;
+
+class tst_mkdiroperationtest : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void initTestCase()
+ {
+ QInstaller::init();
+ QString path = QDir::current().path() + QDir::toNativeSeparators("/test");
+ if (QDir(path).exists()) {
+ QFAIL("Remove test folder first!");
+ }
+ }
+
+ void testMissingArguments()
+ {
+ MkdirOperation op;
+
+ QVERIFY(op.testOperation());
+ QVERIFY(!op.performOperation());
+
+ QCOMPARE(UpdateOperation::Error(op.error()), UpdateOperation::InvalidArguments);
+ QCOMPARE(op.errorString(), QString("Invalid arguments: 0 arguments given, 1 expected."));
+
+ }
+
+ void testCreateDirectory_data()
+ {
+ QTest::addColumn<QString>("directory");
+ QTest::newRow("/test") << "/test";
+ QTest::newRow("/test/test") << "/test/test";
+ QTest::newRow("/test/test/test") << "/test/test/test";
+ }
+
+ void testCreateDirectory()
+ {
+ QFETCH(QString, directory);
+ QString path = QDir::current().path() + QDir::toNativeSeparators(directory);
+
+ QVERIFY2(!QDir(path).exists(), path.toAscii());
+ MkdirOperation op;
+ op.setArguments(QStringList() << path);
+ op.backup();
+ QVERIFY2(op.performOperation(), op.errorString().toAscii());
+ QVERIFY2(QDir(path).exists(), path.toAscii());
+ QVERIFY2(op.undoOperation(), op.errorString().toAscii());
+ QVERIFY2(!QDir(path).exists(), path.toAscii());
+ }
+
+ void testCreateDirectory_customFile_data()
+ {
+ QTest::addColumn<QString>("directory");
+ QTest::addColumn<QString>("filename");
+ QTest::newRow("/test") << "/test" << "/test/file.txt";
+ QTest::newRow("/test/test") << "/test/test" << "/test/file.txt";
+ QTest::newRow("/test/test/test") << "/test/test/test" << "/test/test/test/file.txt";
+ }
+
+ void testCreateDirectory_customFile()
+ {
+ QFETCH(QString, directory);
+ QFETCH(QString, filename);
+ QString path = QDir::current().path() + QDir::toNativeSeparators(directory);
+ QString filepath = QDir::current().path() + QDir::toNativeSeparators(filename);
+
+ QVERIFY2(!QDir(path).exists(), path.toAscii());
+ MkdirOperation op;
+ op.setArguments(QStringList() << path);
+ op.backup();
+ QVERIFY2(op.performOperation(), op.errorString().toAscii());
+ QVERIFY2(QDir(path).exists(), path.toAscii());
+ QFile file(filepath);
+ file.open(QIODevice::WriteOnly | QIODevice::Text);
+ QTextStream out(&file);
+ out << "This file is generated by QTest\n";
+ file.close();
+ QVERIFY2(!op.undoOperation(), op.errorString().toAscii());
+ QVERIFY2(file.exists(), filepath.toAscii());
+ QVERIFY2(QDir(filepath).remove(filepath), "Could not remove file");
+ QVERIFY2(!file.exists(), filepath.toAscii());
+ QVERIFY2(op.undoOperation(), op.errorString().toAscii());
+ QVERIFY2(!QDir(path).exists(), path.toAscii());
+ }
+
+ void testCreateDirectory_customFile_force_data()
+ {
+ testCreateDirectory_customFile_data();
+ }
+
+ void testCreateDirectory_customFile_force()
+ {
+ QFETCH(QString, directory);
+ QFETCH(QString, filename);
+ QString path = QDir::current().path() + QDir::toNativeSeparators(directory);
+ QString filepath = QDir::current().path() + QDir::toNativeSeparators(filename);
+
+ QVERIFY2(!QDir(path).exists(), path.toAscii());
+ MkdirOperation op;
+ op.setArguments(QStringList() << path);
+ op.setValue("forceremoval",true);
+ op.backup();
+ QVERIFY2(op.performOperation(), op.errorString().toAscii());
+ QVERIFY2(QDir(path).exists(), path.toAscii());
+ QFile file(filepath);
+ file.open(QIODevice::WriteOnly | QIODevice::Text);
+ QTextStream out(&file);
+ out << "This file is generated by QTest\n";
+ file.close();
+ QVERIFY2(op.undoOperation(), op.errorString().toAscii());
+ QVERIFY2(!file.exists(), path.toAscii());
+ }
+};
+
+QTEST_MAIN(tst_mkdiroperationtest)
+
+#include "tst_mkdiroperationtest.moc"