summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkh1 <karsten.heimrich@digia.com>2013-05-03 14:25:59 +0200
committerKarsten Heimrich <karsten.heimrich@digia.com>2013-05-06 12:51:30 +0200
commit53d70144622f36c38b7559e6beb9cb79d4546096 (patch)
tree6781220a6102dc07eef599871274494b8efd2e32
parent23b7654f0d80cc56990cef19f6d4b06b209120b5 (diff)
Add 7z facade auto test and fix bug in out stream.
Change-Id: Idd046e09da0ee0fe49eb305296181f969b42e393 Reviewed-by: Niels Weber <niels.weber@digia.com> Reviewed-by: Tim Jenssen <tim.jenssen@digia.com>
-rw-r--r--src/libs/installer/lib7z_facade.cpp33
-rw-r--r--tests/auto/installer/installer.pro3
-rw-r--r--tests/auto/installer/lib7zfacade/data.qrc6
-rw-r--r--tests/auto/installer/lib7zfacade/data/invalid.7zbin0 -> 25600 bytes
-rw-r--r--tests/auto/installer/lib7zfacade/data/valid.7zbin0 -> 950 bytes
-rw-r--r--tests/auto/installer/lib7zfacade/lib7zfacade.pro7
-rw-r--r--tests/auto/installer/lib7zfacade/tst_lib7zfacade.cpp181
7 files changed, 213 insertions, 17 deletions
diff --git a/src/libs/installer/lib7z_facade.cpp b/src/libs/installer/lib7z_facade.cpp
index 624c08b54..a818e9a61 100644
--- a/src/libs/installer/lib7z_facade.cpp
+++ b/src/libs/installer/lib7z_facade.cpp
@@ -334,40 +334,39 @@ namespace Lib7z {
class QIODeviceSequentialOutStream : public ISequentialOutStream, public CMyUnknownImp
{
public:
- enum DestructorBehavior{
- CloseAndDeleteIODeviceAtDestructor,
- KeepIODeviceAtItIsAtDestructor
+ enum Behavior {
+ KeepDeviceUntouched,
+ CloseAndDeleteDevice
};
MY_UNKNOWN_IMP
- explicit QIODeviceSequentialOutStream(QIODevice* device, DestructorBehavior behavior);
+ explicit QIODeviceSequentialOutStream(QIODevice* device, Behavior behavior);
~QIODeviceSequentialOutStream();
QString errorString() const;
/* reimp */ STDMETHOD(Write)(const void* data, UInt32 size, UInt32* processedSize);
private:
- QPointer<QIODevice> m_device;
- const DestructorBehavior m_destructorBehavior;
+ Behavior m_behavior;
QString m_errorString;
+ QPointer<QIODevice> m_device;
};
-QIODeviceSequentialOutStream::QIODeviceSequentialOutStream(QIODevice* device, DestructorBehavior behavior)
+QIODeviceSequentialOutStream::QIODeviceSequentialOutStream(QIODevice* device, Behavior behavior)
: ISequentialOutStream()
, CMyUnknownImp()
+ , m_behavior(behavior)
, m_device(device)
- , m_destructorBehavior(behavior)
{
Q_ASSERT(m_device);
- if (!m_device->open(QIODevice::WriteOnly)) {
+ if (!device->isOpen() && !m_device->open(QIODevice::WriteOnly))
m_errorString = m_device->errorString();
- }
}
QIODeviceSequentialOutStream::~QIODeviceSequentialOutStream()
{
- if (m_destructorBehavior == CloseAndDeleteIODeviceAtDestructor) {
+ if (m_behavior == CloseAndDeleteDevice) {
m_device->close();
delete m_device;
m_device = 0;
@@ -792,7 +791,7 @@ public:
*outStream = 0;
if (device != 0) {
QIODeviceSequentialOutStream *qOutStream = new QIODeviceSequentialOutStream(device,
- QIODeviceSequentialOutStream::KeepIODeviceAtItIsAtDestructor);
+ QIODeviceSequentialOutStream::KeepDeviceUntouched);
if (!qOutStream->errorString().isEmpty()) {
Lib7z::setLastError(qOutStream->errorString());
return E_FAIL;
@@ -841,7 +840,7 @@ public:
}
#endif
QIODeviceSequentialOutStream *qOutStream = new QIODeviceSequentialOutStream(
- new QFile(fi.absoluteFilePath()), QIODeviceSequentialOutStream::CloseAndDeleteIODeviceAtDestructor);
+ new QFile(fi.absoluteFilePath()), QIODeviceSequentialOutStream::CloseAndDeleteDevice);
if (!qOutStream->errorString().isEmpty()) {
Lib7z::setLastError(QObject::tr("Could not open file: %1 (%2)").arg(
fi.absoluteFilePath(), qOutStream->errorString()));
@@ -1440,13 +1439,15 @@ void Lib7z::extractFileFromArchive(QIODevice* archive, const File& item, QIODevi
assert(item.path == UString2QString(s).replace(QLatin1Char('\\'), QLatin1Char('/')));
callback->setTarget(target);
- const LONG extractResult = parchive->Extract(&itemIdx, 1, /*testmode=*/1, callback->impl());
+ const LONG extractResult = parchive->Extract(&itemIdx, 1, /*testmode=*/0, callback->impl());
if (extractResult != S_OK)
throw SevenZipException(errorMessageFrom7zResult(extractResult));
} catch (const char *err) {
throw SevenZipException(err);
+ } catch (const Lib7z::SevenZipException& e) {
+ throw e;
} catch (...) {
throw SevenZipException(QObject::tr("Unknown exception caught (%1)")
.arg(QString::fromLatin1(Q_FUNC_INFO)));
@@ -1470,10 +1471,10 @@ void Lib7z::extractFileFromArchive(QIODevice* archive, const File& item, const Q
throw SevenZipException(QObject::tr("Could not create output file for writing: %1")
.arg(fi.absoluteFilePath()));
}
- if (item.permissions)
- out.setPermissions(item.permissions);
callback->setTarget(&out);
extractFileFromArchive(archive, item, &out, callback);
+ if (item.permissions)
+ out.setPermissions(item.permissions);
outDir.release();
}
diff --git a/tests/auto/installer/installer.pro b/tests/auto/installer/installer.pro
index e22407368..5b4c32dab 100644
--- a/tests/auto/installer/installer.pro
+++ b/tests/auto/installer/installer.pro
@@ -6,4 +6,5 @@ SUBDIRS += \
componentmodel \
fakestopprocessforupdateoperation \
messageboxhandler \
- extractarchiveoperationtest
+ extractarchiveoperationtest \
+ lib7zfacade
diff --git a/tests/auto/installer/lib7zfacade/data.qrc b/tests/auto/installer/lib7zfacade/data.qrc
new file mode 100644
index 000000000..d6453a9b3
--- /dev/null
+++ b/tests/auto/installer/lib7zfacade/data.qrc
@@ -0,0 +1,6 @@
+<RCC>
+ <qresource prefix="/">
+ <file>data/valid.7z</file>
+ <file>data/invalid.7z</file>
+ </qresource>
+</RCC>
diff --git a/tests/auto/installer/lib7zfacade/data/invalid.7z b/tests/auto/installer/lib7zfacade/data/invalid.7z
new file mode 100644
index 000000000..bcf81250e
--- /dev/null
+++ b/tests/auto/installer/lib7zfacade/data/invalid.7z
Binary files differ
diff --git a/tests/auto/installer/lib7zfacade/data/valid.7z b/tests/auto/installer/lib7zfacade/data/valid.7z
new file mode 100644
index 000000000..e583bdf99
--- /dev/null
+++ b/tests/auto/installer/lib7zfacade/data/valid.7z
Binary files differ
diff --git a/tests/auto/installer/lib7zfacade/lib7zfacade.pro b/tests/auto/installer/lib7zfacade/lib7zfacade.pro
new file mode 100644
index 000000000..034cf1eed
--- /dev/null
+++ b/tests/auto/installer/lib7zfacade/lib7zfacade.pro
@@ -0,0 +1,7 @@
+include(../../qttest.pri)
+
+QT -= gui
+QT += testlib
+
+RESOURCES += data.qrc
+SOURCES = tst_lib7zfacade.cpp
diff --git a/tests/auto/installer/lib7zfacade/tst_lib7zfacade.cpp b/tests/auto/installer/lib7zfacade/tst_lib7zfacade.cpp
new file mode 100644
index 000000000..d6945bf68
--- /dev/null
+++ b/tests/auto/installer/lib7zfacade/tst_lib7zfacade.cpp
@@ -0,0 +1,181 @@
+/**************************************************************************
+**
+** Copyright (C) 2012-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 "lib7z_facade.h"
+
+#include <QDir>
+#include <QObject>
+#include <QTemporaryFile>
+#include <QTest>
+
+class tst_lib7zfacade : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void initTestCase()
+ {
+ QInstaller::init();
+
+ m_file.path = "valid";
+ m_file.permissions = 0;
+ m_file.compressedSize = 836;
+ m_file.uncompressedSize = 5242880;
+ m_file.isDirectory = false;
+ m_file.archiveIndex = QPoint(0, 0);
+ m_file.mtime = QDateTime(QDate::fromJulianDay(2456413), QTime(12, 50, 42));
+ }
+
+ void testIsSupportedArchive()
+ {
+ QCOMPARE(Lib7z::isSupportedArchive(":///data/valid.7z"), true);
+ QCOMPARE(Lib7z::isSupportedArchive(":///data/invalid.7z"), false);
+
+ {
+ QFile file(":///data/valid.7z");
+ QVERIFY(file.open(QIODevice::ReadOnly));
+ QCOMPARE(Lib7z::isSupportedArchive(&file), true);
+ }
+
+ {
+ QFile file(":///data/invalid.7z");
+ QVERIFY(file.open(QIODevice::ReadOnly));
+ QCOMPARE(Lib7z::isSupportedArchive(&file), false);
+ }
+ }
+
+ void testListArchive()
+ {
+ // TODO: this should work without scope, there's a bug in Lib7z::OpenArchiveInfo
+ // caused by the fact that we keep a pointer to the device, not the devices target
+ {
+ QFile file(":///data/valid.7z");
+ QVERIFY(file.open(QIODevice::ReadOnly));
+
+ QVector<Lib7z::File> files = Lib7z::listArchive(&file);
+ QCOMPARE(files.count(), 1);
+ QCOMPARE(files.first(), m_file);
+ }
+
+ {
+ try {
+ QFile file(":///data/invalid.7z");
+ QVERIFY(file.open(QIODevice::ReadOnly));
+ QVector<Lib7z::File> files = Lib7z::listArchive(&file);
+ } catch (const Lib7z::SevenZipException& e) {
+ QCOMPARE(e.message(), QString("Could not open archive"));
+ } catch (...) {
+ QFAIL("Unexpected error during list archive!");
+ }
+ }
+ }
+
+ void testCreateArchive()
+ {
+ QTemporaryFile target;
+ QVERIFY(target.open());
+
+ try {
+ // TODO: we do not get any information about success
+ Lib7z::createArchive(&target, QStringList() << ":///data/invalid.7z");
+ } catch (const Lib7z::SevenZipException& e) {
+ QFAIL(e.message().toUtf8());
+ } catch (...) {
+ QFAIL("Unexpected error during create archive!");
+ }
+ }
+
+ void testExtractArchive()
+ {
+ QFile source(":///data/valid.7z");
+ QVERIFY(source.open(QIODevice::ReadOnly));
+
+ try {
+ // TODO: we do not get any information about success
+ Lib7z::extractArchive(&source, QDir::tempPath());
+ } catch (const Lib7z::SevenZipException& e) {
+ QFAIL(e.message().toUtf8());
+ } catch (...) {
+ QFAIL("Unexpected error during extract archive!");
+ }
+ }
+
+ void testExtractFileFromArchive()
+ {
+ QFile source(":///data/valid.7z");
+ QVERIFY(source.open(QIODevice::ReadOnly));
+
+ QTemporaryFile target;
+ QVERIFY(target.open());
+
+ try {
+ // TODO: we do not get any information about success
+ Lib7z::extractFileFromArchive(&source, m_file, &target);
+ } catch (const Lib7z::SevenZipException& e) {
+ QFAIL(e.message().toUtf8());
+ } catch (...) {
+ QFAIL("Unexpected error during extract file from archive!");
+ }
+ }
+
+ void testExtractFileFromArchive2()
+ {
+ QFile source(":///data/valid.7z");
+ QVERIFY(source.open(QIODevice::ReadOnly));
+
+ try {
+ // TODO: we do not get any information about success
+ Lib7z::extractFileFromArchive(&source, m_file, QDir::tempPath());
+ } catch (const Lib7z::SevenZipException& e) {
+ QFAIL(e.message().toUtf8());
+ } catch (...) {
+ QFAIL("Unexpected error during extract file from archive!");
+ }
+ }
+
+private:
+ Lib7z::File m_file;
+};
+
+QTEST_MAIN(tst_lib7zfacade)
+
+#include "tst_lib7zfacade.moc"