Sergio Ahumada 8f4053db30 Change copyright headers from Nokia to Digia
Change-Id: Id55a71a6ee24b234739b6066e11e9c1f2e389f73
Reviewed-by: Karsten Heimrich <karsten.heimrich@digia.com>
2012-12-21 22:25:29 +01:00

195 lines
6.1 KiB
C++

/**************************************************************************
**
** Copyright (C) 2012 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 <fsengineclient.h>
#include <QProcess>
#include <QCoreApplication>
#include <QThread>
#include <QDebug>
class OutputHandler : public QObject
{
Q_OBJECT
public:
OutputHandler(QProcess* processWrapper, QObject *parent = 0)
: QObject (parent)
{
m_process = processWrapper;
QObject::connect(m_process, SIGNAL(readyRead()),
this, SLOT(readProcessOutput()), Qt::DirectConnection);
}
void clearSavedOutPut() { m_savedOutPut.clear(); }
QByteArray savedOutPut() { return m_savedOutPut; }
public slots:
void readProcessOutput()
{
Q_ASSERT(m_process);
Q_ASSERT(QThread::currentThread() == m_process->thread());
if (QThread::currentThread() != m_process->thread()) {
qDebug() << Q_FUNC_INFO << QLatin1String("can only be called from the same thread as the "
"process is.");
}
const QByteArray output = m_process->readAll();
if (!output.isEmpty()) {
m_savedOutPut.append(output);
qDebug() << output;
}
}
private:
QProcess* m_process;
QByteArray m_savedOutPut;
};
int main(int argc, char **argv)
{
QCoreApplication app(argc, argv);
QString fileName(QLatin1String("give_me_some_output.bat"));
QFile file(fileName);
if (file.exists() && !file.remove()) {
qFatal(qPrintable(QString::fromLatin1("something is wrong, can not delete: %1").arg(file.fileName())));
return -1;
}
if (!file.open(QIODevice::WriteOnly | QIODevice::Text))
{
qFatal(qPrintable(QString::fromLatin1("something is wrong, can not open for writing to: %1")
.arg(file.fileName())));
return -2;
}
QTextStream out(&file);
out << QLatin1String("echo mega test output");
if (!file.flush())
{
qFatal(qPrintable(QString::fromLatin1("something is wrong, can not write to: %1").arg(file.fileName())));
return -3;
}
file.close();
//first run as a normal QProcess
QByteArray firstOutPut;
{
QProcess process;
OutputHandler outputer(&process);
process.start(fileName);
qDebug() << "1";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
process.waitForStarted();
qDebug() << "2";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
process.waitForFinished();
qDebug() << "3";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
firstOutPut = outputer.savedOutPut();
}
//first run as a normal QProcess
QByteArray secondOutPut;
{
FSEngineClientHandler::instance().enableTestMode();
FSEngineClientHandler::instance().init(39999);
FSEngineClientHandler::instance().setActive(true);
QProcess process;
OutputHandler outputer(&process);
process.start(fileName);
qDebug() << "1";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
process.waitForStarted();
qDebug() << "2";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
process.waitForFinished();
qDebug() << "3";
{
const QByteArray output = process.readAll();
if (!output.isEmpty()) {
qDebug() << output;
}
}
secondOutPut = outputer.savedOutPut();
}
if (firstOutPut != secondOutPut) {
qFatal(qPrintable(QString::fromLatin1("Test failed: output is different between a normal QProcess "
"and QProcessWrapper: %1").arg(file.fileName())));
return -2;
} else {
qDebug() << QLatin1String("Test OK: QProcess works as expected.");
}
return app.exec();
}
#include "fileengineclient.moc"