1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
/***************************************************************************
* Copyright (C) 2010 by Frank Reininghaus ([email protected]) *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program 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 General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
#ifndef TESTHELPER_H
#define TESTHELPER_H
#include <KUrl>
class KTempDir;
class QAbstractItemView;
class QDir;
class DolphinDirLister;
class DolphinModel;
class DolphinSortFilterProxyModel;
class DolphinView;
/*
* The class TestBase aims to make writing Dolphin unit tests easier.
* It provides functionality that almost every unit test needs: setup of the DolphinView and
* easy creation of test files and subfolders in a temporary directory which is removed in
* the TestBase destructor.
*
* TODO: TestBase should also backup the DolphinSettings and restore them later!
*/
class TestBase : public QObject
{
Q_OBJECT
public:
TestBase();
~TestBase();
// Returns the item view (icons, details, or columns)
QAbstractItemView* itemView () const;
KUrl testDirUrl() const;
/*
* The following functions create either a file, a list of files, or a directory.
* The paths may be absolute or relative to the test directory. Any missing parent
* directories will be created automatically.
*/
void createFile(const QString& path, const QByteArray& data = QByteArray("test"));
void createFiles(const QStringList& files);
void createDir(const QString& path);
/*
* Remove the test directory and create an empty one.
*/
void cleanupTestDir();
// Make members that are accessed frequently by the derived test classes public
DolphinDirLister* m_dirLister;
DolphinModel* m_dolphinModel;
DolphinSortFilterProxyModel* m_proxyModel;
DolphinView* m_view;
private:
KTempDir* m_tempDir;
QString m_path;
QDir* m_dir;
void makePathAbsoluteAndCreateParents(QString& path);
};
#endif
|