You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdelibs/kate/part/test_regression.h

250 lines
7.3 KiB

/**
* This file is part of the KDE project
*
* Copyright (C) 2001,2003 Peter Kelly (pmk@post.com)
* Copyright 2006 Leo Savernik (l.savernik@aon.at)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* 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.
*
*/
#ifndef TEST_REGRESSION_H
#define TEST_REGRESSION_H
#include <katejscript.h>
#include <kateview.h>
#include <kurl.h>
#include <tqobject.h>
#include <tqstringlist.h>
#include <kjs/ustring.h>
#include <kjs/object.h>
#include <kjs/interpreter.h>
class KateDocument;
class KateView;
class RegressionTest;
class TQTimer;
namespace KParts {
class URLArgs;
}
class OutputObject;
/**
* @internal
* The backbone of Kate's automatic regression tests.
*/
class TestJScriptEnv : public KateJScript
{
public:
TestJScriptEnv(KateDocument *part);
virtual ~TestJScriptEnv();
/** returns the global scope */
KJS::Object global() const { return *m_global; }
/** returns the script interpreter */
KJS::Interpreter &interpreter() { return *m_interpreter; }
/** returns the document scope */
KJS::Object document() const { return *m_document; }
/** returns the view scope */
KJS::Object view() const { return *m_view; }
/** returns the output object */
OutputObject *output() const { return m_output; }
protected:
OutputObject *m_output;
};
/**
* @internal
*/
class KateViewObject : public KJS::ObjectImp
{
public:
KateViewObject(KJS::ExecState *exec, KateView *v, KJS::ObjectImp *fallback);
virtual ~KateViewObject();
virtual const KJS::ClassInfo *classInfo() const;
virtual KJS::Value get(KJS::ExecState *exec, const KJS::Identifier &propertyName) const;
private:
// evil hack I: class layout of katejscript/KateJSView must be duplicated
// here, structurally as well as functionally
KateView *view;
// end evil hack
KJS::ObjectImp *fallback;
};
/**
* @internal
*/
class KateViewFunction : public KJS::ObjectImp
{
public:
KateViewFunction(KJS::ExecState *exec, KateView *v, int _id, int length);
bool implementsCall() const;
KJS::Value call(KJS::ExecState *exec, KJS::Object &thisObj, const KJS::List &args);
enum { KeyReturn, Type, Backspace, DeleteWordLeft, KeyDelete,
DeleteWordRight, Transpose, CursorLeft, ShiftCursorLeft, CursorRight,
ShiftCursorRight, WordLeft, ShiftWordLeft, WordRight, ShiftWordRight,
Home, ShiftHome, End, ShiftEnd, Up, ShiftUp, Down, ShiftDown, ScrollUp,
ScrollDown, TopOfView, ShiftTopOfView, BottomOfView, ShiftBottomOfView,
PageUp, ShiftPageUp, PageDown, ShiftPageDown, Top, ShiftTop, Bottom,
ShiftBottom, ToMatchingBracket, ShiftToMatchingBracket };
private:
KateView *m_view;
int id;
};
class OutputFunction;
/**
* Customizing output to result-files. Writing any output into result files
* inhibits outputting the content of the katepart after script execution, enabling one to check for coordinates and the like.
* @internal
*/
class OutputObject : public KJS::ObjectImp
{
public:
OutputObject(KJS::ExecState *exec, KateDocument *d, KateView *v);
virtual ~OutputObject();
virtual KJS::UString className() const;
void setChangedFlag(bool *flag) { changed = flag; }
void setOutputString(TQString *s) { outstr = s; }
private:
KateDocument *doc;
KateView *view;
bool *changed;
TQString *outstr;
friend class OutputFunction;
};
/**
* Customizing output to result-files.
* @internal
*/
class OutputFunction : public KJS::ObjectImp
{
public:
OutputFunction(KJS::ExecState *exec, OutputObject *obj, int _id, int length);
bool implementsCall() const;
virtual KJS::Value call(KJS::ExecState *exec, KJS::Object &thisObj, const KJS::List &args);
enum { Write, Writeln, WriteCursorPosition, WriteCursorPositionln };
private:
OutputObject *o;
int id;
};
/**
* @internal
*/
class RegressionTest : public TQObject
{
Q_OBJECT
public:
RegressionTest(KateDocument *part, KConfig *baseConfig,
const TQString &baseDir, const TQString &outputDir,
bool _genOutput);
~RegressionTest();
enum OutputType { ResultDocument };
void testStaticFile(const TQString& filename, const TQStringList &commands);
enum CheckResult { Failure = 0, Success = 1, Ignored = 2 };
CheckResult checkOutput(const TQString& againstFilename);
enum FailureType { NoFailure = 0, AllFailure = 1, ResultFailure = 4, NewFailure = 65536 };
bool runTests(TQString relPath = TQString::null, bool mustExist = false, int known_failure = NoFailure);
bool reportResult( bool passed, const TQString & description = TQString::null, bool *newfailure = 0 );
bool reportResult(CheckResult result, const TQString & description = TQString::null, bool *newfailure = 0 );
void rereadConfig();
static void createMissingDirs(const TQString &path);
void setFailureSnapshotConfig(KConfig *cfg, const TQString &snapshotname);
void setFailureSnapshotSaver(KConfig *cfg, const TQString &snapshotname);
void createLink( const TQString& test, int failures );
void doFailureReport( const TQString& test, int failures );
KateDocument *m_part;
KateView *m_view;
KConfig *m_baseConfig;
TQString m_baseDir;
TQString m_outputDir;
bool m_genOutput;
TQString m_currentBase;
KConfig *m_failureComp;
KConfig *m_failureSave;
TQString m_currentOutput;
TQString m_currentCategory;
TQString m_currentTest;
bool m_keepOutput;
bool m_getOutput;
bool m_showGui;
int m_passes_work;
int m_passes_fail;
int m_passes_new;
int m_failures_work;
int m_failures_fail;
int m_failures_new;
int m_errors;
bool saw_failure;
bool ignore_errors;
int m_known_failures;
bool m_outputCustomised;
TQString m_outputString;
static RegressionTest *curr;
private:
void printDescription(const TQString& description);
static bool svnIgnored( const TQString &filename );
private:
/**
* evaluate script given by \c filename within the context of \c interp.
* @param ignore if \c true don't evaluate if script does not exist but
* return true nonetheless.
* @return true if script was valid, false otherwise
*/
bool evalJS( KJS::Interpreter &interp, const TQString &filename, bool ignore = false);
/**
* concatenate contents of all list files down to but not including the
* tests directory.
* @param relPath relative path against tests-directory
* @param filename file name of the list files
*/
TQStringList concatListFiles(const TQString &relPath, const TQString &filename);
private slots:
void slotOpenURL(const KURL &url, const KParts::URLArgs &args);
void resizeTopLevelWidget( int, int );
};
#endif