tests/auto/qmake/testcompiler.cpp
changeset 0 1918ee327afb
child 4 3b1da2848fc7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/auto/qmake/testcompiler.cpp	Mon Jan 11 14:00:40 2010 +0000
@@ -0,0 +1,277 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the Technology Preview License Agreement accompanying
+** this package.
+**
+** 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, Nokia gives you certain additional
+** rights.  These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** If you have questions regarding the use of this file, please contact
+** Nokia at qt-info@nokia.com.
+**
+**
+**
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include "testcompiler.h"
+
+#include <QProcess>
+#include <QDir>
+
+static QString targetName( BuildType buildMode, const QString& target, const QString& version )
+{
+    Q_UNUSED(version);
+    QString targetName = target;
+
+#if defined (Q_OS_WIN32)
+    switch (buildMode)
+    {
+    case Exe: // app
+        targetName.append(".exe");
+        break;
+    case Dll: // dll
+        if (!version.isEmpty())
+            targetName.append(version.section(".", 0, 0));
+        targetName.append(".dll");
+        break;
+    case Lib: // lib
+#ifdef Q_CC_GNU
+        targetName.prepend("lib");
+        targetName.append(".a");
+#else
+        targetName.append(".lib");
+#endif
+        break;
+    case Plain:
+        // no conversion
+        break;
+    }
+#elif defined( Q_OS_MAC )
+    switch (buildMode)
+    {
+    case Exe: // app
+        targetName += ".app/Contents/MacOS/" + target.section('/', -1);
+        break;
+    case Dll: // dll
+        targetName.prepend("lib");
+        targetName.append("." + version + ".dylib");
+        break;
+    case Lib: // lib
+        targetName.prepend("lib");
+        targetName.append(".a");
+        break;
+    case Plain:
+        // no conversion
+        break;
+    }
+#else
+    switch (buildMode)
+    {
+    case Exe: // app
+        break;
+    case Dll: // dll
+        targetName.prepend("lib");
+#if defined (Q_OS_HPUX) && !defined (__ia64)
+        targetName.append(".sl");
+#elif defined (Q_OS_AIX)
+        targetName.append(".a");
+#else
+        targetName.append(".so");
+#endif
+        break;
+    case Lib: // lib
+        targetName.prepend("lib");
+        targetName.append(".a");
+        break;
+    case Plain:
+        // no conversion
+        break;
+    }
+#endif
+    return targetName;
+}
+
+TestCompiler::TestCompiler()
+{
+    setBaseCommands( "", "" );
+}
+
+TestCompiler::~TestCompiler()
+{
+}
+
+bool TestCompiler::runCommand( QString cmdline )
+{
+    testOutput_.append("Running command: " + cmdline);
+
+    QProcess child;
+    if (!environment_.empty())
+        child.setEnvironment(QProcess::systemEnvironment() + environment_);
+
+    child.start(cmdline);
+    if (!child.waitForStarted(-1)) {
+        testOutput_.append( "Unable to start child process." );
+        return false;
+    }
+
+    bool failed = false;
+    child.setReadChannel(QProcess::StandardError);
+    while (QProcess::Running == child.state()) {
+        if (child.waitForReadyRead(1000)) {
+            QString output = child.readAllStandardError();
+            testOutput_.append(output);
+
+            output.prepend('\n');
+            if (output.contains("\nProject MESSAGE: FAILED"))
+                failed = true;
+        }
+    }
+
+    child.waitForFinished(-1);
+
+    return failed
+        ? false
+        : (child.exitStatus() == QProcess::NormalExit)
+            && (child.exitCode() == 0);
+}
+
+void TestCompiler::setBaseCommands( QString makeCmd, QString qmakeCmd )
+{
+    makeCmd_ = makeCmd;
+    qmakeCmd_ = qmakeCmd;
+}
+
+void TestCompiler::resetEnvironment()
+{
+    environment_.clear();
+}
+
+void TestCompiler::addToEnvironment( QString varAssignment )
+{
+    environment_.push_back(varAssignment);
+}
+
+bool TestCompiler::makeClean( const QString &workPath )
+{
+    QDir D;
+    if (!D.exists(workPath)) {
+        testOutput_.append( "Directory '" + workPath + "' doesn't exist" );
+        return false;
+    }
+
+    D.setCurrent(workPath);
+    QFileInfo Fi( workPath + "/Makefile");
+    if (Fi.exists())
+        // Run make clean
+        return runCommand( makeCmd_ + " clean" );
+
+    return true;
+}
+
+bool TestCompiler::makeDistClean( const QString &workPath )
+{
+    QDir D;
+    if (!D.exists(workPath)) {
+        testOutput_.append( "Directory '" + workPath + "' doesn't exist" );
+        return false;
+    }
+
+    D.setCurrent(workPath);
+    QFileInfo Fi( workPath + "/Makefile");
+    if (Fi.exists())
+        // Run make distclean
+        return runCommand( makeCmd_ + " distclean" );
+
+    return true;
+
+}
+
+bool TestCompiler::qmake( const QString &workDir, const QString &proName, const QString &buildDir )
+{
+    QDir D;
+    D.setCurrent( workDir );
+
+    if (D.exists("Makefile"))
+        D.remove("Makefile");
+
+    QString projectFile = proName;
+    QString makeFile = buildDir;
+    if (!projectFile.endsWith(".pro"))
+        projectFile += ".pro";
+    if (!makeFile.isEmpty() && !makeFile.endsWith('/'))
+        makeFile += '/';
+    makeFile += "Makefile";
+
+    // Now start qmake and generate the makefile
+    return runCommand( qmakeCmd_ + " " + projectFile + " -o " + makeFile );
+}
+
+bool TestCompiler::make( const QString &workPath, const QString &target )
+{
+    QDir D;
+    D.setCurrent( workPath );
+
+    QString cmdline = makeCmd_;
+    if ( cmdline.contains("nmake", Qt::CaseInsensitive) )
+        cmdline.append(" /NOLOGO");
+    if ( !target.isEmpty() )
+        cmdline += " " + target;
+
+    return runCommand( cmdline );
+}
+
+bool TestCompiler::exists( const QString &destDir, const QString &exeName, BuildType buildType, const QString &version )
+{
+    QFileInfo f(destDir + "/" + targetName(buildType, exeName, version));
+    return f.exists();
+}
+
+bool TestCompiler::removeMakefile( const QString &workPath )
+{
+    QDir D;
+    D.setCurrent( workPath );
+    if ( D.exists( "Makefile" ) )
+        return D.remove( "Makefile" );
+    else
+        return true;
+}
+
+QString TestCompiler::commandOutput() const
+{
+#ifndef Q_OS_WIN
+    return testOutput_.join("\n");
+#else
+    return testOutput_.join("\r\n");
+#endif
+}
+
+void TestCompiler::clearCommandOutput()
+{
+   testOutput_.clear();
+}