##// END OF EJS Templates
Fix Charts documentation...
Fix Charts documentation The documentation structure is changed so that it can be generated with both Qt5 and Qt4. Also the erroneous VBarModelMapper is removed from VBoxPlotModelMapper documentation. Task-number: QTRD-2492, QTRD-2495 Change-Id: I45028915ca55f6ff1170db58518a8f08ac4158fb Reviewed-by: Miikka Heikkinen <miikka.heikkinen@digia.com>

File last commit:

r2574:599370d0561c
r2639:2ce3423968b5
Show More
tst_domain.cpp
747 lines | 19.7 KiB | text/x-c | CppLexer
/****************************************************************************
**
** Copyright (C) 2013 Digia Plc
** All rights reserved.
** For any questions to Digia, please use contact form at http://qt.digia.com
**
** This file is part of the Qt Enterprise Charts Add-on.
**
** $QT_BEGIN_LICENSE$
** Licensees holding valid Qt Enterprise licenses may use this file in
** accordance with the Qt Enterprise License Agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Digia.
**
** If you have questions regarding the use of this file, please use
** contact form at http://qt.digia.com
** $QT_END_LICENSE$
**
****************************************************************************/
#ifndef BUILD_PRIVATE_UNIT_TESTS
#include <QtTest/QtTest>
class tst_Domain: public QObject {
Q_OBJECT
private Q_SLOTS:
void skip();
};
void tst_Domain::skip()
{
#if (QT_VERSION >= QT_VERSION_CHECK(5, 0, 0))
QSKIP("This test requires the debug version of library");
#else
QSKIP("This test requires the debug version of library", SkipAll);
#endif
}
QTEST_MAIN(tst_Domain)
#include "tst_domain.moc"
#else
#include <QtTest/QtTest>
#include <private/xydomain_p.h>
#include <private/qabstractaxis_p.h>
#include <tst_definitions.h>
QTCOMMERCIALCHART_USE_NAMESPACE
Q_DECLARE_METATYPE(XYDomain*)
Q_DECLARE_METATYPE(QSizeF)
Q_DECLARE_METATYPE(QMargins)
class AxisMock: public QAbstractAxisPrivate
{
Q_OBJECT
public:
AxisMock(Qt::Alignment alignment):QAbstractAxisPrivate(0){ setAlignment(alignment);};
void initializeGraphics(QGraphicsItem* item)
{
Q_UNUSED(item);
};
void initializeDomain(AbstractDomain* domain)
{
Q_UNUSED(domain);
};
void setMin(const QVariant &min)
{
Q_UNUSED(min);
}
qreal min() { return m_min;}
void setMax(const QVariant &max)
{
Q_UNUSED(max);
}
qreal max() { return m_max; }
void setRange(const QVariant &min, const QVariant &max)
{
Q_UNUSED(min);
Q_UNUSED(max);
};
void setRange(qreal min, qreal max)
{
m_min=min;
m_max=max;
emit rangeChanged(min,max);
};
int count () const { return m_count; }
void handleDomainUpdated(){};
public:
int m_count;
qreal m_min;
qreal m_max;
};
class tst_Domain: public QObject
{
Q_OBJECT
public Q_SLOTS:
void initTestCase();
void cleanupTestCase();
void init();
void cleanup();
private Q_SLOTS:
void domain();
void handleHorizontalAxisRangeChanged_data();
void handleHorizontalAxisRangeChanged();
void handleVerticalAxisRangeChanged_data();
void handleVerticalAxisRangeChanged();
void isEmpty_data();
void isEmpty();
void maxX_data();
void maxX();
void maxY_data();
void maxY();
void minX_data();
void minX();
void minY_data();
void minY();
void operatorEquals_data();
void operatorEquals();
void setRange_data();
void setRange();
void setRangeX_data();
void setRangeX();
void setRangeY_data();
void setRangeY();
void spanX_data();
void spanX();
void spanY_data();
void spanY();
void zoomIn_data();
void zoomIn();
void zoomOut_data();
void zoomOut();
void move_data();
void move();
};
void tst_Domain::initTestCase()
{
}
void tst_Domain::cleanupTestCase()
{
}
void tst_Domain::init()
{
}
void tst_Domain::cleanup()
{
}
void tst_Domain::domain()
{
XYDomain domain;
QCOMPARE(domain.isEmpty(), true);
QCOMPARE(domain.maxX(), 0.0);
QCOMPARE(domain.maxY(), 0.0);
QCOMPARE(domain.minX(), 0.0);
QCOMPARE(domain.minY(), 0.0);
}
void tst_Domain::handleHorizontalAxisRangeChanged_data()
{
QTest::addColumn<qreal>("min");
QTest::addColumn<qreal>("max");
QTest::newRow("-1 1") << -1.0 << 1.0;
QTest::newRow("0 1") << 0.0 << 1.0;
QTest::newRow("-1 0") << -1.0 << 0.0;
}
void tst_Domain::handleHorizontalAxisRangeChanged()
{
QFETCH(qreal, min);
QFETCH(qreal, max);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
AxisMock axis(Qt::AlignBottom);
QObject::connect(&axis,SIGNAL(rangeChanged(qreal,qreal)),&domain,SLOT(handleHorizontalAxisRangeChanged(qreal,qreal)));
axis.setRange(min,max);
QVERIFY(qFuzzyCompare(domain.minX(), min));
QVERIFY(qFuzzyCompare(domain.maxX(), max));
QList<QVariant> arg1 = spy1.first();
QVERIFY(qFuzzyCompare(arg1.at(0).toReal(), min));
QVERIFY(qFuzzyCompare(arg1.at(1).toReal(), max));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 1);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::handleVerticalAxisRangeChanged_data()
{
QTest::addColumn<qreal>("min");
QTest::addColumn<qreal>("max");
QTest::newRow("-1 1") << -1.0 << 1.0;
QTest::newRow("0 1") << 0.0 << 1.0;
QTest::newRow("-1 0") << -1.0 << 0.0;
}
void tst_Domain::handleVerticalAxisRangeChanged()
{
QFETCH(qreal, min);
QFETCH(qreal, max);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
AxisMock axis(Qt::AlignLeft);
QObject::connect(&axis, SIGNAL(rangeChanged(qreal,qreal)), &domain, SLOT(handleVerticalAxisRangeChanged(qreal,qreal)));
axis.setRange(min,max);
QVERIFY(qFuzzyCompare(domain.minY(), min));
QVERIFY(qFuzzyCompare(domain.maxY(), max));
QList<QVariant> arg1 = spy2.first();
QVERIFY(qFuzzyCompare(arg1.at(0).toReal(), min));
QVERIFY(qFuzzyCompare(arg1.at(1).toReal(), max));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), 1);
}
void tst_Domain::isEmpty_data()
{
QTest::addColumn<qreal>("minX");
QTest::addColumn<qreal>("maxX");
QTest::addColumn<qreal>("minY");
QTest::addColumn<qreal>("maxY");
QTest::addColumn<QSizeF>("size");
QTest::addColumn<bool>("isEmpty");
QTest::newRow("0 0 0 0") << 0.0 << 0.0 << 0.0 << 0.0 << QSizeF(1,1) << true;
QTest::newRow("0 1 0 0") << 0.0 << 1.0 << 0.0 << 0.0 << QSizeF(1,1) << true;
QTest::newRow("0 0 0 1") << 0.0 << 1.0 << 0.0 << 0.0 << QSizeF(1,1) << true;
QTest::newRow("0 1 0 1") << 0.0 << 1.0 << 0.0 << 1.0 << QSizeF(1,1) << false;
QTest::newRow("0 1 0 1") << 0.0 << 1.0 << 0.0 << 1.0 << QSizeF(-11,1) << true;
}
void tst_Domain::isEmpty()
{
QFETCH(qreal, minX);
QFETCH(qreal, maxX);
QFETCH(qreal, minY);
QFETCH(qreal, maxY);
QFETCH(QSizeF, size);
QFETCH(bool, isEmpty);
XYDomain domain;
domain.setRange(minX, maxX, minY, maxY);
domain.setSize(size);
QCOMPARE(domain.isEmpty(), isEmpty);
}
void tst_Domain::maxX_data()
{
QTest::addColumn<qreal>("maxX1");
QTest::addColumn<qreal>("maxX2");
QTest::addColumn<int>("count");
QTest::newRow("1") << 0.0 << 1.0 << 1;
QTest::newRow("1.0") << 1.0 << 1.0 << 1;
QTest::newRow("2.0") << 1.0 << 0.0 << 2;
}
void tst_Domain::maxX()
{
QFETCH(qreal, maxX1);
QFETCH(qreal, maxX2);
QFETCH(int, count);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setMaxX(maxX1);
QCOMPARE(domain.maxX(), maxX1);
domain.setMaxX(maxX2);
QCOMPARE(domain.maxX(), maxX2);
TRY_COMPARE(spy0.count(), count);
TRY_COMPARE(spy1.count(), count);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::maxY_data()
{
QTest::addColumn<qreal>("maxY1");
QTest::addColumn<qreal>("maxY2");
QTest::addColumn<int>("count");
QTest::newRow("1") << 0.0 << 1.0 << 1;
QTest::newRow("1.0") << 1.0 << 1.0 << 1;
QTest::newRow("2.0") << 1.0 << 0.0 << 2;
}
void tst_Domain::maxY()
{
QFETCH(qreal, maxY1);
QFETCH(qreal, maxY2);
QFETCH(int, count);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setMaxY(maxY1);
QCOMPARE(domain.maxY(), maxY1);
domain.setMaxY(maxY2);
QCOMPARE(domain.maxY(), maxY2);
TRY_COMPARE(spy0.count(), count);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), count);
}
void tst_Domain::minX_data()
{
QTest::addColumn<qreal>("minX1");
QTest::addColumn<qreal>("minX2");
QTest::addColumn<int>("count");
QTest::newRow("1") << 0.0 << 1.0 << 1;
QTest::newRow("1.0") << 1.0 << 1.0 << 1;
QTest::newRow("2.0") << 1.0 << 0.0 << 2;
}
void tst_Domain::minX()
{
QFETCH(qreal, minX1);
QFETCH(qreal, minX2);
QFETCH(int, count);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setMinX(minX1);
QCOMPARE(domain.minX(), minX1);
domain.setMinX(minX2);
QCOMPARE(domain.minX(), minX2);
TRY_COMPARE(spy0.count(), count);
TRY_COMPARE(spy1.count(), count);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::minY_data()
{
QTest::addColumn<qreal>("minY1");
QTest::addColumn<qreal>("minY2");
QTest::addColumn<int>("count");
QTest::newRow("1") << 0.0 << 1.0 << 1;
QTest::newRow("1.0") << 1.0 << 1.0 << 1;
QTest::newRow("2.0") << 1.0 << 0.0 << 2;
}
void tst_Domain::minY()
{
QFETCH(qreal, minY1);
QFETCH(qreal, minY2);
QFETCH(int, count);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setMinY(minY1);
QCOMPARE(domain.minY(), minY1);
domain.setMinY(minY2);
QCOMPARE(domain.minY(), minY2);
TRY_COMPARE(spy0.count(), count);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), count);
}
void tst_Domain::operatorEquals_data()
{
QTest::addColumn<XYDomain*>("domain1");
QTest::addColumn<XYDomain*>("domain2");
QTest::addColumn<bool>("equals");
QTest::addColumn<bool>("notEquals");
XYDomain* a;
XYDomain* b;
a = new XYDomain();
a->setRange(0, 100, 0, 100);
b = new XYDomain();
b->setRange(0, 100, 0, 100);
QTest::newRow("equals") << a << b << true << false;
a = new XYDomain();
a->setRange(0, 100, 0, 100);
b = new XYDomain();
b->setRange(0, 100, 0, 1);
QTest::newRow("equals") << a << b << false << true;
a = new XYDomain();
a->setRange(0, 100, 0, 100);
b = new XYDomain();
b->setRange(0, 1, 0, 100);
QTest::newRow("equals") << a << b << false << true;
}
void tst_Domain::operatorEquals()
{
QFETCH(XYDomain*, domain1);
QFETCH(XYDomain*, domain2);
QFETCH(bool, equals);
QFETCH(bool, notEquals);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
QCOMPARE(*domain1==*domain2, equals);
QCOMPARE(*domain1!=*domain2, notEquals);
TRY_COMPARE(spy0.count(), 0);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::setRange_data()
{
QTest::addColumn<qreal>("minX");
QTest::addColumn<qreal>("maxX");
QTest::addColumn<qreal>("minY");
QTest::addColumn<qreal>("maxY");
QTest::newRow("1,2,1,2") << 1.0 << 2.0 << 1.0 << 2.0;
QTest::newRow("1,3,1,3") << 1.0 << 3.0 << 1.0 << 3.0;
QTest::newRow("-1,5,-2,-1") << -1.0 << 5.0 << -2.0 << -1.0;
}
void tst_Domain::setRange()
{
QFETCH(qreal, minX);
QFETCH(qreal, maxX);
QFETCH(qreal, minY);
QFETCH(qreal, maxY);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setRange(minX, maxX, minY, maxY);
QCOMPARE(domain.minX(), minX);
QCOMPARE(domain.maxX(), maxX);
QCOMPARE(domain.minY(), minY);
QCOMPARE(domain.maxY(), maxY);
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 1);
TRY_COMPARE(spy2.count(), 1);
}
void tst_Domain::setRangeX_data()
{
QTest::addColumn<qreal>("min");
QTest::addColumn<qreal>("max");
QTest::newRow("-1 1") << -1.0 << 1.0;
QTest::newRow("0 1") << 0.0 << 1.0;
QTest::newRow("-1 0") << -1.0 << 0.0;
}
void tst_Domain::setRangeX()
{
QFETCH(qreal, min);
QFETCH(qreal, max);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setRangeX(min, max);
QVERIFY(qFuzzyCompare(domain.minX(), min));
QVERIFY(qFuzzyCompare(domain.maxX(), max));
QList<QVariant> arg1 = spy1.first();
QVERIFY(qFuzzyCompare(arg1.at(0).toReal(), min));
QVERIFY(qFuzzyCompare(arg1.at(1).toReal(), max));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 1);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::setRangeY_data()
{
QTest::addColumn<qreal>("min");
QTest::addColumn<qreal>("max");
QTest::newRow("-1 1") << -1.0 << 1.0;
QTest::newRow("0 1") << 0.0 << 1.0;
QTest::newRow("-1 0") << -1.0 << 0.0;
}
void tst_Domain::setRangeY()
{
QFETCH(qreal, min);
QFETCH(qreal, max);
XYDomain domain;
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.setRangeY(min, max);
QVERIFY(qFuzzyCompare(domain.minY(), min));
QVERIFY(qFuzzyCompare(domain.maxY(), max));
QList<QVariant> arg1 = spy2.first();
QVERIFY(qFuzzyCompare(arg1.at(0).toReal(), min));
QVERIFY(qFuzzyCompare(arg1.at(1).toReal(), max));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), 1);
}
void tst_Domain::spanX_data()
{
QTest::addColumn<qreal>("minX");
QTest::addColumn<qreal>("maxX");
QTest::addColumn<qreal>("spanX");
QTest::newRow("1 2 1") << 1.0 << 2.0 << 1.0;
QTest::newRow("0 2 2") << 1.0 << 2.0 << 1.0;
}
void tst_Domain::spanX()
{
QFETCH(qreal, minX);
QFETCH(qreal, maxX);
QFETCH(qreal, spanX);
XYDomain domain;
domain.setRangeX(minX, maxX);
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
QCOMPARE(domain.spanX(), spanX);
TRY_COMPARE(spy0.count(), 0);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::spanY_data()
{
QTest::addColumn<qreal>("minY");
QTest::addColumn<qreal>("maxY");
QTest::addColumn<qreal>("spanY");
QTest::newRow("1 2 1") << 1.0 << 2.0 << 1.0;
QTest::newRow("0 2 2") << 1.0 << 2.0 << 1.0;
}
void tst_Domain::spanY()
{
QFETCH(qreal, minY);
QFETCH(qreal, maxY);
QFETCH(qreal, spanY);
XYDomain domain;
domain.setRangeY(minY, maxY);
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
QCOMPARE(domain.spanY(), spanY);
TRY_COMPARE(spy0.count(), 0);
TRY_COMPARE(spy1.count(), 0);
TRY_COMPARE(spy2.count(), 0);
}
void tst_Domain::zoomIn_data()
{
QTest::addColumn<QMargins>("range");
QTest::addColumn<QSizeF>("size");
QTest::addColumn<QMargins>("zoom");
QTest::addColumn<QMargins>("result");
QTest::newRow("first") << QMargins(0,0,1000,1000) << QSizeF(1000, 1000) <<
QMargins(100, 100, 900, 900) << QMargins(100,100,900,900);
QTest::newRow("second") << QMargins(0,0,2000,2000) << QSizeF(1000, 1000) <<
QMargins(100, 100, 900, 900) << QMargins(200,200,1800,1800);
}
void tst_Domain::zoomIn()
{
QFETCH(QMargins, range);
QFETCH(QSizeF, size);
QFETCH(QMargins, zoom);
QFETCH(QMargins, result);
XYDomain domain;
domain.setRange(range.left(), range.right(), range.top(),range.bottom());
domain.setSize(size);
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.zoomIn(QRectF(zoom.left(),zoom.top(),zoom.right()-zoom.left(),zoom.bottom()-zoom.top()));
QCOMPARE(domain.minX(),qreal(result.left()));
QCOMPARE(domain.maxX(),qreal(result.right()));
QCOMPARE(domain.minY(),qreal(result.top()));
QCOMPARE(domain.maxY(),qreal(result.bottom()));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 1);
TRY_COMPARE(spy2.count(), 1);
}
void tst_Domain::zoomOut_data()
{
QTest::addColumn<QMargins>("range");
QTest::addColumn<QSizeF>("size");
QTest::addColumn<QMargins>("zoom");
QTest::addColumn<QMargins>("result");
QTest::newRow("first") << QMargins(100,100,900,900) << QSizeF(1000, 1000) <<
QMargins(100, 100, 900, 900) << QMargins(0,0,1000,1000);
QTest::newRow("second") << QMargins(200,200,1800,1800) << QSizeF(1000, 1000) <<
QMargins(100, 100, 900, 900) << QMargins(0,0,2000,2000);
}
void tst_Domain::zoomOut()
{
QFETCH(QMargins, range);
QFETCH(QSizeF, size);
QFETCH(QMargins, zoom);
QFETCH(QMargins, result);
XYDomain domain;
domain.setRange(range.left(), range.right(), range.top(),range.bottom());
domain.setSize(size);
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.zoomOut(QRectF(zoom.left(),zoom.top(),zoom.right()-zoom.left(),zoom.bottom()-zoom.top()));
QCOMPARE(domain.minX(),qreal(result.left()));
QCOMPARE(domain.maxX(),qreal(result.right()));
QCOMPARE(domain.minY(),qreal(result.top()));
QCOMPARE(domain.maxY(),qreal(result.bottom()));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), 1);
TRY_COMPARE(spy2.count(), 1);
}
void tst_Domain::move_data()
{
QTest::addColumn<QMargins>("range");
QTest::addColumn<QSizeF>("size");
QTest::addColumn<int>("dx");
QTest::addColumn<int>("dy");
QTest::addColumn<QMargins>("result");
QTest::newRow("first") << QMargins(0,0,1000,1000) << QSizeF(1000, 1000) <<
10 << 10 << QMargins(10,10,1010,1010);
QTest::newRow("second") << QMargins(0,0,1000,1000) << QSizeF(1000, 1000) <<
-10 << -10 << QMargins(-10,-10,990,990);
}
void tst_Domain::move()
{
QFETCH(QMargins, range);
QFETCH(QSizeF, size);
QFETCH(int, dx);
QFETCH(int, dy);
QFETCH(QMargins, result);
XYDomain domain;
domain.setRange(range.left(), range.right(), range.top(),range.bottom());
domain.setSize(size);
QSignalSpy spy0(&domain, SIGNAL(updated()));
QSignalSpy spy1(&domain, SIGNAL(rangeHorizontalChanged(qreal,qreal)));
QSignalSpy spy2(&domain, SIGNAL(rangeVerticalChanged(qreal,qreal)));
domain.move(dx, dy);
QCOMPARE(domain.minX(),qreal(result.left()));
QCOMPARE(domain.maxX(),qreal(result.right()));
QCOMPARE(domain.minY(),qreal(result.top()));
QCOMPARE(domain.maxY(),qreal(result.bottom()));
TRY_COMPARE(spy0.count(), 1);
TRY_COMPARE(spy1.count(), (dx != 0 ? 1 : 0));
TRY_COMPARE(spy2.count(), (dy != 0 ? 1 : 0));
}
QTEST_MAIN(tst_Domain)
#include "tst_domain.moc"
#endif