summaryrefslogtreecommitdiffstats
path: root/kio/tests/kruntest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kio/tests/kruntest.cpp')
-rw-r--r--kio/tests/kruntest.cpp209
1 files changed, 209 insertions, 0 deletions
diff --git a/kio/tests/kruntest.cpp b/kio/tests/kruntest.cpp
new file mode 100644
index 000000000..92c0a3af3
--- /dev/null
+++ b/kio/tests/kruntest.cpp
@@ -0,0 +1,209 @@
+/*
+ * Copyright (C) 2002 David Faure <faure@kde.org>
+ * Copyright (C) 2003 Waldo Bastian <bastian@kde.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License version 2 as published by the Free Software Foundation;
+ *
+ * This library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this library; see the file COPYING.LIB. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+// ------ this test works only if your terminal application is set to "x-term" ------
+
+#include "kruntest.h"
+
+#include <kapplication.h>
+#include <kdebug.h>
+#include <kshell.h>
+#include <kservice.h>
+#include <kde_file.h>
+
+#include <qpushbutton.h>
+#include <qlayout.h>
+#include <qdir.h>
+
+#include <stdlib.h>
+#include <unistd.h>
+#include <fcntl.h>
+
+const int MAXKRUNS = 100;
+
+testKRun * myArray[MAXKRUNS];
+
+void testKRun::foundMimeType( const QString& _type )
+{
+ kdDebug() << "testKRun::foundMimeType " << _type << endl;
+ kdDebug() << "testKRun::foundMimeType URL=" << m_strURL.url() << endl;
+ m_bFinished = true;
+ m_timer.start( 0, true );
+ return;
+}
+
+Receiver::Receiver()
+{
+ QVBoxLayout *lay = new QVBoxLayout(this);
+ lay->setAutoAdd(true);
+ QPushButton * h = new QPushButton( "Press here to terminate", this );
+ start = new QPushButton( "Launch KRuns", this );
+ stop = new QPushButton( "Stop those KRuns", this );
+ stop->setEnabled(false);
+ QObject::connect( h, SIGNAL(clicked()), kapp, SLOT(quit()) );
+ QObject::connect( start, SIGNAL(clicked()), this, SLOT(slotStart()) );
+ QObject::connect( stop, SIGNAL(clicked()), this, SLOT(slotStop()) );
+
+ adjustSize();
+ show();
+}
+
+void Receiver::slotStop()
+{
+ for (int i = 0 ; i < MAXKRUNS ; i++ )
+ {
+ kdDebug() << " deleting krun " << i << endl;
+ delete myArray[i];
+ }
+ start->setEnabled(true);
+ stop->setEnabled(false);
+}
+
+
+void Receiver::slotStart()
+{
+ for (int i = 0 ; i < MAXKRUNS ; i++ )
+ {
+ kdDebug() << "creating testKRun " << i << endl;
+ myArray[i] = new testKRun( KURL("file:/tmp"), 0, true, false /* no autodelete */ );
+ }
+ start->setEnabled(false);
+ stop->setEnabled(true);
+}
+
+void check(QString txt, QString a, QString b)
+{
+ if (a.isEmpty())
+ a = QString::null;
+ if (b.isEmpty())
+ b = QString::null;
+ if (a == b)
+ kdDebug() << txt << " : '" << a << "' - ok" << endl;
+ else {
+ kdDebug() << txt << " : '" << a << "' but expected '" << b << "' - KO!" << endl;
+ exit(1);
+ }
+}
+
+const char *bt(bool tr) { return tr?"true":"false"; }
+
+void checkBN(QString a, bool tr, QString b)
+{
+ check( QString().sprintf("binaryName('%s', %s)", a.latin1(), bt(tr)), KRun::binaryName(a, tr), b);
+}
+
+void checkPDE(const KService &service, const KURL::List &urls, bool hs, bool tf, QString b)
+{
+ check(
+ QString().sprintf("processDesktopExec( "
+ "service = {\nexec = %s\nterminal = %s, terminalOptions = %s\nsubstituteUid = %s, user = %s },"
+ "\nURLs = { %s },\nhas_shell = %s, temp_files = %s )",
+ service.exec().latin1(), bt(service.terminal()), service.terminalOptions().latin1(), bt(service.substituteUid()), service.username().latin1(),
+ KShell::joinArgs(urls.toStringList()).latin1(), bt(hs), bt(tf)),
+ KShell::joinArgs(KRun::processDesktopExec(service,urls,hs,tf)), b);
+}
+
+int main(int argc, char **argv)
+{
+ KApplication app( argc, argv, "kruntest", true /* it _has_ a GUI ! */);
+
+ // First some non-interactive tests
+ checkBN( "/usr/bin/ls", true, "ls");
+ checkBN( "/usr/bin/ls", false, "/usr/bin/ls");
+ checkBN( "/path/to/wine \"long argument with path\"", true, "wine" );
+ checkBN( "/path/with/a/sp\\ ace/exe arg1 arg2", true, "exe" );
+ checkBN( "\"progname\" \"arg1\"", true, "progname" );
+ checkBN( "'quoted' \"arg1\"", true, "quoted" );
+ checkBN( " 'leading space' arg1", true, "leading space" );
+
+ KURL::List l0;
+ KURL::List l1; l1 << "file:/tmp";
+ KURL::List l2; l2 << "http://localhost/foo";
+ KURL::List l3; l3 << "file:/local/file" << "http://remotehost.org/bar";
+
+ static const char
+ *execs[] = { "Exec=date -u", "Exec=echo $$PWD" },
+ *terms[] = { "Terminal=false", "Terminal=true\nTerminalOptions=-T \"%f - %c\"" },
+ *sus[] = { "X-KDE-SubstituteUID=false", "X-KDE-SubstituteUID=true\nX-KDE-Username=sprallo" },
+ *rslts[] = {
+"'date' '-u'", // 0
+"'/bin/sh' '-c' 'echo $PWD '", // 1
+"'x-term' '-T' ' - just_a_test' '-e' 'date' '-u'", // 2
+"'x-term' '-T' ' - just_a_test' '-e' '/bin/sh' '-c' 'echo $PWD '", // 3
+"'kdesu' '-u' 'sprallo' '-c' 'date -u '", // 4
+"'kdesu' '-u' 'sprallo' '-c' '/bin/sh -c '\\''echo $PWD '\\'''", // 5
+"'x-term' '-T' ' - just_a_test' '-e' 'su' 'sprallo' '-c' 'date -u '", // 6
+"'x-term' '-T' ' - just_a_test' '-e' 'su' 'sprallo' '-c' '/bin/sh -c '\\''echo $PWD '\\'''", // 7
+"'date -u '", // 8
+"'echo $PWD '", // 9
+"'x-term -T \" - just_a_test\"' '-e' 'date -u '", // a
+"'x-term -T \" - just_a_test\"' '-e' '/bin/sh -c '\\''echo $PWD '\\'''", // b
+"'kdesu' '-u' 'sprallo' '-c' ''\\''date -u '\\'''", // c
+"'kdesu' '-u' 'sprallo' '-c' ''\\''/bin/sh -c '\\''\\'\\'''\\''echo $PWD '\\''\\'\\'''\\'''\\'''", // d
+"'x-term -T \" - just_a_test\"' '-e' 'su' 'sprallo' '-c' ''\\''date -u '\\'''", // e
+"'x-term -T \" - just_a_test\"' '-e' 'su' 'sprallo' '-c' ''\\''/bin/sh -c '\\''\\'\\'''\\''echo $PWD '\\''\\'\\'''\\'''\\'''", // f
+ };
+ for (int hs = 0; hs < 2; hs++)
+ for (int su = 0; su < 2; su++)
+ for (int te = 0; te < 2; te++)
+ for (int ex = 0; ex < 2; ex++) {
+ int fd = creat("kruntest.desktop", 0666);
+ FILE *f;
+ if (fd < 0) abort();
+ f = KDE_fdopen(fd, "w");
+ fprintf(f, "[Desktop Entry]\n"
+ "Type=Application\n"
+ "Name=just_a_test\n"
+ "Icon=~/icon.png\n"
+ "%s\n%s\n%s\n",execs[ex],terms[te],sus[su]);
+ close(fd);
+ fclose(f);
+ KService s(QDir::currentDirPath() + "/kruntest.desktop");
+ unlink("kruntest.desktop");
+ checkPDE( s, l0, hs, false, rslts[ex+te*2+su*4+hs*8]);
+ }
+
+ KService s1("dummy", "kate %U", "app");
+ checkPDE( s1, l0, false, false, "'kate'");
+ checkPDE( s1, l1, false, false, "'kate' '/tmp'");
+ checkPDE( s1, l2, false, false, "'kate' 'http://localhost/foo'");
+ checkPDE( s1, l3, false, false, "'kate' '/local/file' 'http://remotehost.org/bar'");
+ KService s2("dummy", "kate %u", "app");
+ checkPDE( s2, l0, false, false, "'kate'");
+ checkPDE( s2, l1, false, false, "'kate' '/tmp'");
+ checkPDE( s2, l2, false, false, "'kate' 'http://localhost/foo'");
+ checkPDE( s2, l3, false, false, "'kate'");
+ KService s3("dummy", "kate %F", "app");
+ checkPDE( s3, l0, false, false, "'kate'");
+ checkPDE( s3, l1, false, false, "'kate' '/tmp'");
+ checkPDE( s3, l2, false, false, "'kfmexec' 'kate %F' 'http://localhost/foo'");
+ checkPDE( s3, l3, false, false, "'kfmexec' 'kate %F' 'file:/local/file' 'http://remotehost.org/bar'");
+
+ checkPDE( s3, l1, false, true, "'kfmexec' '--tempfiles' 'kate %F' 'file:/tmp'");
+ checkPDE( s3, l1, true, true, "''\\''kfmexec'\\'' '\\''--tempfiles'\\'' '\\''kate %F'\\'' '\\''file:/tmp'\\'''");
+
+ KService s4("dummy", "sh -c \"kate \"'\\\"'\"%F\"'\\\"'", "app");
+ checkPDE( s4, l1, false, false, "'kate' '\"/tmp\"'");
+
+ Receiver receiver;
+ app.setMainWidget(&receiver);
+ return app.exec();
+}
+
+#include "kruntest.moc"