Skip to content

Commit 44a334b

Browse files
committedNov 20, 2014
Add hasDefaultValues method to QgsDataDefined, add some tests
1 parent 6cc073d commit 44a334b

File tree

5 files changed

+134
-0
lines changed

5 files changed

+134
-0
lines changed
 

‎python/core/qgsdatadefined.sip

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,13 @@ class QgsDataDefined
2424
const QString& field = QString() );
2525

2626
~QgsDataDefined();
27+
28+
/**Returns whether the data defined container is set to all the default
29+
* values, ie, disabled, with empty expression and no assigned field
30+
* @returns true if data defined container is set to default values
31+
* @note added in QGIS 2.7
32+
*/
33+
bool hasDefaultValues() const;
2734

2835
bool isActive() const;
2936
void setActive( bool active );

‎src/core/qgsdatadefined.cpp

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,11 @@ QgsDataDefined::~QgsDataDefined()
3939
delete mExpression;
4040
}
4141

42+
bool QgsDataDefined::hasDefaultValues() const
43+
{
44+
return ( !mActive && !mUseExpression && mExpressionString.isEmpty() && mField.isEmpty() );
45+
}
46+
4247
void QgsDataDefined::setExpressionString( const QString &expr )
4348
{
4449
mExpressionString = expr;

‎src/core/qgsdatadefined.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -46,6 +46,13 @@ class CORE_EXPORT QgsDataDefined
4646

4747
~QgsDataDefined();
4848

49+
/**Returns whether the data defined container is set to all the default
50+
* values, ie, disabled, with empty expression and no assigned field
51+
* @returns true if data defined container is set to default values
52+
* @note added in QGIS 2.7
53+
*/
54+
bool hasDefaultValues() const;
55+
4956
bool isActive() const { return mActive; }
5057
void setActive( bool active ) { mActive = active; }
5158

‎tests/src/core/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -104,6 +104,7 @@ ADD_QGIS_TEST(vectorlayertest testqgsvectorlayer.cpp)
104104
ADD_QGIS_TEST(rulebasedrenderertest testqgsrulebasedrenderer.cpp)
105105
ADD_QGIS_TEST(ziplayertest testziplayer.cpp)
106106
ADD_QGIS_TEST(dataitemtest testqgsdataitem.cpp)
107+
ADD_QGIS_TEST(datadefined testqgsdatadefined.cpp)
107108
ADD_QGIS_TEST(composerobject testqgscomposerobject.cpp)
108109
ADD_QGIS_TEST(composerutils testqgscomposerutils.cpp)
109110
ADD_QGIS_TEST(compositiontest testqgscomposition.cpp)

‎tests/src/core/testqgsdatadefined.cpp

Lines changed: 114 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,114 @@
1+
/***************************************************************************
2+
testqgsdatadefined.cpp
3+
----------------------
4+
Date : November 2014
5+
Copyright : (C) 2014 Nyall Dawson
6+
Email : nyall dot dawson at gmail dot com
7+
***************************************************************************
8+
* *
9+
* This program is free software; you can redistribute it and/or modify *
10+
* it under the terms of the GNU General Public License as published by *
11+
* the Free Software Foundation; either version 2 of the License, or *
12+
* (at your option) any later version. *
13+
* *
14+
***************************************************************************/
15+
#include <QtTest>
16+
#include <QObject>
17+
#include <QString>
18+
#include <QStringList>
19+
#include <QSettings>
20+
21+
#include <qgsdatadefined.h>
22+
23+
/** \ingroup UnitTests
24+
* Unit tests for QgsDataDefined
25+
*/
26+
class TestQgsDataDefined: public QObject
27+
{
28+
Q_OBJECT;
29+
30+
private slots:
31+
void initTestCase();// will be called before the first testfunction is executed.
32+
void cleanupTestCase();// will be called after the last testfunction was executed.
33+
void init();// will be called before each testfunction is executed.
34+
void cleanup();// will be called after every testfunction.
35+
void create();//test creating a data defined container
36+
void gettersSetters(); //test getters and setters
37+
void defaultValues(); //test hasDefaultValues method
38+
39+
private:
40+
};
41+
42+
void TestQgsDataDefined::initTestCase()
43+
{
44+
45+
}
46+
47+
void TestQgsDataDefined::cleanupTestCase()
48+
{
49+
50+
}
51+
52+
void TestQgsDataDefined::init()
53+
{
54+
55+
}
56+
57+
void TestQgsDataDefined::cleanup()
58+
{
59+
60+
}
61+
62+
void TestQgsDataDefined::create()
63+
{
64+
QgsDataDefined* dd = new QgsDataDefined( true, true, QString( "exp" ), QString( "field" ) );
65+
QVERIFY( dd->isActive() );
66+
QVERIFY( dd->useExpression() );
67+
QCOMPARE( dd->expressionString(), QString( "exp" ) );
68+
QCOMPARE( dd->field(), QString( "field" ) );
69+
delete dd;
70+
}
71+
72+
void TestQgsDataDefined::gettersSetters()
73+
{
74+
QgsDataDefined dd;
75+
dd.setActive( false );
76+
QVERIFY( !dd.isActive() );
77+
dd.setActive( true );
78+
QVERIFY( dd.isActive() );
79+
80+
dd.setUseExpression( false );
81+
QVERIFY( !dd.useExpression() );
82+
dd.setUseExpression( true );
83+
QVERIFY( dd.useExpression() );
84+
85+
dd.setExpressionString( QString( "expression" ) );
86+
QCOMPARE( dd.expressionString(), QString( "expression" ) );
87+
88+
dd.setField( QString( "field" ) );
89+
QCOMPARE( dd.field(), QString( "field" ) );
90+
}
91+
92+
void TestQgsDataDefined::defaultValues()
93+
{
94+
QgsDataDefined* dd = new QgsDataDefined();
95+
QVERIFY( dd->hasDefaultValues() );
96+
dd->setActive( true );
97+
QVERIFY( !dd->hasDefaultValues() );
98+
delete dd;
99+
dd = new QgsDataDefined();
100+
dd->setUseExpression( true );
101+
QVERIFY( !dd->hasDefaultValues() );
102+
delete dd;
103+
dd = new QgsDataDefined();
104+
dd->setExpressionString( QString( "expression" ) );
105+
QVERIFY( !dd->hasDefaultValues() );
106+
delete dd;
107+
dd = new QgsDataDefined();
108+
dd->setField( QString( "field" ) );
109+
QVERIFY( !dd->hasDefaultValues() );
110+
delete dd;
111+
}
112+
113+
QTEST_MAIN( TestQgsDataDefined )
114+
#include "testqgsdatadefined.moc"

0 commit comments

Comments
 (0)
Please sign in to comment.