~ubuntu-branches/ubuntu/wily/qtbase-opensource-src/wily

« back to all changes in this revision

Viewing changes to tests/auto/widgets/itemviews/qfileiconprovider/tst_qfileiconprovider.cpp

  • Committer: Package Import Robot
  • Author(s): Timo Jyrinki
  • Date: 2013-02-05 12:46:17 UTC
  • Revision ID: package-import@ubuntu.com-20130205124617-c8jouts182j002fx
Tags: upstream-5.0.1+dfsg
ImportĀ upstreamĀ versionĀ 5.0.1+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
 
4
** Contact: http://www.qt-project.org/legal
 
5
**
 
6
** This file is part of the test suite of the Qt Toolkit.
 
7
**
 
8
** $QT_BEGIN_LICENSE:LGPL$
 
9
** Commercial License Usage
 
10
** Licensees holding valid commercial Qt licenses may use this file in
 
11
** accordance with the commercial license agreement provided with the
 
12
** Software or, alternatively, in accordance with the terms contained in
 
13
** a written agreement between you and Digia.  For licensing terms and
 
14
** conditions see http://qt.digia.com/licensing.  For further information
 
15
** use the contact form at http://qt.digia.com/contact-us.
 
16
**
 
17
** GNU Lesser General Public License Usage
 
18
** Alternatively, this file may be used under the terms of the GNU Lesser
 
19
** General Public License version 2.1 as published by the Free Software
 
20
** Foundation and appearing in the file LICENSE.LGPL included in the
 
21
** packaging of this file.  Please review the following information to
 
22
** ensure the GNU Lesser General Public License version 2.1 requirements
 
23
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
 
24
**
 
25
** In addition, as a special exception, Digia gives you certain additional
 
26
** rights.  These rights are described in the Digia Qt LGPL Exception
 
27
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
 
28
**
 
29
** GNU General Public License Usage
 
30
** Alternatively, this file may be used under the terms of the GNU
 
31
** General Public License version 3.0 as published by the Free Software
 
32
** Foundation and appearing in the file LICENSE.GPL included in the
 
33
** packaging of this file.  Please review the following information to
 
34
** ensure the GNU General Public License version 3.0 requirements will be
 
35
** met: http://www.gnu.org/copyleft/gpl.html.
 
36
**
 
37
**
 
38
** $QT_END_LICENSE$
 
39
**
 
40
****************************************************************************/
 
41
 
 
42
 
 
43
#include <QtTest/QtTest>
 
44
#include <qfileiconprovider.h>
 
45
#include <qfileinfo.h>
 
46
 
 
47
class tst_QFileIconProvider : public QObject
 
48
{
 
49
    Q_OBJECT
 
50
 
 
51
public slots:
 
52
    void initTestCase();
 
53
    void cleanupTestCase();
 
54
    void init();
 
55
    void cleanup();
 
56
 
 
57
private slots:
 
58
    void qfileiconprovider_data();
 
59
    void qfileiconprovider();
 
60
 
 
61
    void iconType_data();
 
62
    void iconType();
 
63
 
 
64
    void iconInfo_data();
 
65
    void iconInfo();
 
66
 
 
67
    void type_data();
 
68
    void type();
 
69
};
 
70
 
 
71
// Subclass that exposes the protected functions.
 
72
class SubQFileIconProvider : public QFileIconProvider
 
73
{
 
74
public:
 
75
 
 
76
};
 
77
 
 
78
// This will be called before the first test function is executed.
 
79
// It is only called once.
 
80
void tst_QFileIconProvider::initTestCase()
 
81
{
 
82
}
 
83
 
 
84
// This will be called after the last test function is executed.
 
85
// It is only called once.
 
86
void tst_QFileIconProvider::cleanupTestCase()
 
87
{
 
88
}
 
89
 
 
90
// This will be called before each test function is executed.
 
91
void tst_QFileIconProvider::init()
 
92
{
 
93
}
 
94
 
 
95
// This will be called after every test function.
 
96
void tst_QFileIconProvider::cleanup()
 
97
{
 
98
}
 
99
 
 
100
 
 
101
void tst_QFileIconProvider::qfileiconprovider_data()
 
102
{
 
103
}
 
104
 
 
105
void tst_QFileIconProvider::qfileiconprovider()
 
106
{
 
107
    // don't crash
 
108
    SubQFileIconProvider provider;
 
109
}
 
110
 
 
111
Q_DECLARE_METATYPE(QFileIconProvider::IconType)
 
112
void tst_QFileIconProvider::iconType_data()
 
113
{
 
114
    QTest::addColumn<QFileIconProvider::IconType>("type");
 
115
 
 
116
    QTest::newRow("computer") << QFileIconProvider::Computer;
 
117
    QTest::newRow("desktop") << QFileIconProvider::Desktop;
 
118
    QTest::newRow("trashcan") << QFileIconProvider::Trashcan;
 
119
    QTest::newRow("network") << QFileIconProvider::Network;
 
120
    QTest::newRow("drive") << QFileIconProvider::Drive;
 
121
    QTest::newRow("folder") << QFileIconProvider::Folder;
 
122
    QTest::newRow("file") << QFileIconProvider::File;
 
123
}
 
124
 
 
125
// public QIcon icon(QFileIconProvider::IconType const& type) const
 
126
void tst_QFileIconProvider::iconType()
 
127
{
 
128
    QFETCH(QFileIconProvider::IconType, type);
 
129
    SubQFileIconProvider provider;
 
130
    QVERIFY(!provider.icon(type).isNull());
 
131
}
 
132
 
 
133
void tst_QFileIconProvider::iconInfo_data()
 
134
{
 
135
    QTest::addColumn<QFileInfo>("info");
 
136
    QTest::addColumn<bool>("setPath");
 
137
 
 
138
    QTest::newRow("null") << QFileInfo() << false;
 
139
    QTest::newRow("drive") << QFileInfo(QDir::rootPath()) << true;
 
140
    QTest::newRow("home") << QFileInfo(QDir::homePath()) << true;
 
141
    QTest::newRow("current") << QFileInfo(QDir::currentPath()) << true;
 
142
}
 
143
 
 
144
// public QIcon icon(QFileInfo const& info) const
 
145
void tst_QFileIconProvider::iconInfo()
 
146
{
 
147
    QFETCH(QFileInfo, info);
 
148
    QFETCH(bool, setPath);
 
149
 
 
150
    if (setPath)
 
151
        QVERIFY(info.exists());
 
152
    SubQFileIconProvider provider;
 
153
    // we should always get an icon
 
154
    QVERIFY(!provider.icon(info).isNull());
 
155
}
 
156
 
 
157
void tst_QFileIconProvider::type_data()
 
158
{
 
159
    QTest::addColumn<QFileInfo>("info");
 
160
    // Return value is _very_ system dependent, hard to test
 
161
    // QTest::addColumn<QString>("type");
 
162
 
 
163
    QTest::newRow("null") << QFileInfo();
 
164
    QTest::newRow("drive") << QFileInfo(QDir::rootPath());
 
165
    QTest::newRow("home") << QFileInfo(QDir::homePath());
 
166
    QTest::newRow("current") << QFileInfo(QDir::currentPath());
 
167
    QTest::newRow("exe") << QFileInfo(QCoreApplication::applicationFilePath());
 
168
}
 
169
 
 
170
// public QString type(QFileInfo const& info) const
 
171
void tst_QFileIconProvider::type()
 
172
{
 
173
    QFETCH(QFileInfo, info);
 
174
    SubQFileIconProvider provider;
 
175
    QVERIFY(!provider.type(info).isEmpty());
 
176
}
 
177
 
 
178
QTEST_MAIN(tst_QFileIconProvider)
 
179
#include "tst_qfileiconprovider.moc"
 
180