diff options
author | Lars Knoll <lars.knoll@nokia.com> | 2009-03-23 09:18:55 (GMT) |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2009-03-23 09:18:55 (GMT) |
commit | e5fcad302d86d316390c6b0f62759a067313e8a9 (patch) | |
tree | c2afbf6f1066b6ce261f14341cf6d310e5595bc1 /tests/auto/qtimeline/tst_qtimeline.cpp | |
download | Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.zip Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.tar.gz Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.tar.bz2 |
Long live Qt 4.5!
Diffstat (limited to 'tests/auto/qtimeline/tst_qtimeline.cpp')
-rw-r--r-- | tests/auto/qtimeline/tst_qtimeline.cpp | 709 |
1 files changed, 709 insertions, 0 deletions
diff --git a/tests/auto/qtimeline/tst_qtimeline.cpp b/tests/auto/qtimeline/tst_qtimeline.cpp new file mode 100644 index 0000000..e35f406 --- /dev/null +++ b/tests/auto/qtimeline/tst_qtimeline.cpp @@ -0,0 +1,709 @@ +/**************************************************************************** +** +** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). +** Contact: Qt Software Information (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** No Commercial Usage +** This file contains pre-release code and may not be distributed. +** You may use this file in accordance with the terms and conditions +** contained in the either Technology Preview License Agreement or the +** Beta Release License Agreement. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain +** additional rights. These rights are described in the Nokia Qt LGPL +** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this +** package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** If you are unsure which license is appropriate for your use, please +** contact the sales department at qt-sales@nokia.com. +** $QT_END_LICENSE$ +** +****************************************************************************/ + + +#include <QtTest/QtTest> + +#if QT_VERSION < 0x040200 +QTEST_NOOP_MAIN +#else + +#include <qtimeline.h> + +//TESTED_CLASS= +//TESTED_FILES= + +class tst_QTimeLine : public QObject { + Q_OBJECT + +public: + tst_QTimeLine(); + virtual ~tst_QTimeLine(); + +public Q_SLOTS: + void init(); + void cleanup(); + +private slots: + void range(); + void currentTime(); + void duration(); + void frameRate(); + void value(); + void currentFrame(); + void loopCount(); + void interpolation(); + void reverse_data(); + void reverse(); + //void toggle(); + //void reset(); ### todo + void frameChanged(); + void stopped(); + void finished(); + void isRunning(); + void multipleTimeLines(); + void sineCurve(); + void cosineCurve(); + void outOfRange(); + void stateInFinishedSignal(); + void resume(); + +protected slots: + void finishedSlot(); + +protected: + QTimeLine::State state; + QTimeLine * view; +}; + +tst_QTimeLine::tst_QTimeLine() +{ +} + +tst_QTimeLine::~tst_QTimeLine() +{ +} + +void tst_QTimeLine::init() +{ +} + +void tst_QTimeLine::cleanup() +{ +} +#include <qdebug.h> + +void tst_QTimeLine::range() +{ +#ifdef Q_OS_WINCE //On WinCE timer resolution is bad - using longer times instead + QTimeLine timeLine(2000); +#else + QTimeLine timeLine(200); +#endif + QCOMPARE(timeLine.startFrame(), 0); + QCOMPARE(timeLine.endFrame(), 0); + timeLine.setFrameRange(0, 1); + QCOMPARE(timeLine.startFrame(), 0); + QCOMPARE(timeLine.endFrame(), 1); + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.startFrame(), 10); + QCOMPARE(timeLine.endFrame(), 20); + + timeLine.setStartFrame(6); + QCOMPARE(timeLine.startFrame(), 6); + timeLine.setEndFrame(16); + QCOMPARE(timeLine.endFrame(), 16); + + // Verify that you can change the range in the timeLine + timeLine.setFrameRange(10, 20); + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + timeLine.start(); +#ifdef Q_OS_WINCE + QTest::qWait(1000); +#else + QTest::qWait(100); +#endif + QCOMPARE(timeLine.state(), QTimeLine::Running); + int oldValue = timeLine.currentFrame(); + timeLine.setFrameRange(0, 5); + QVERIFY(timeLine.currentFrame() < oldValue); + timeLine.setEndFrame(100); + timeLine.setStartFrame(50); + QVERIFY(timeLine.currentFrame() > oldValue); + timeLine.setFrameRange(0, 5); +#ifdef Q_OS_WINCE + QTest::qWait(500); +#else + QTest::qWait(50); +#endif + QVERIFY(spy.count() > 1); + QVERIFY(timeLine.currentFrame() < oldValue); +} + +void tst_QTimeLine::currentTime() +{ + QTimeLine timeLine(2000); + timeLine.setUpdateInterval((timeLine.duration()/2) / 33); + qRegisterMetaType<qreal>("qreal"); + QSignalSpy spy(&timeLine, SIGNAL(valueChanged(qreal))); + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.currentTime(), 0); + timeLine.start(); + QTest::qWait(timeLine.duration()/2); + QCOMPARE(timeLine.state(), QTimeLine::Running); + QVERIFY(timeLine.currentTime() > timeLine.duration()/2 - timeLine.duration()/10); + QVERIFY(timeLine.currentTime() < timeLine.duration()/2 + timeLine.duration()/10); + QTest::qWait(timeLine.duration()/4 + timeLine.duration()); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QCOMPARE(timeLine.currentTime(), timeLine.duration()); + + spy.clear(); + timeLine.setCurrentTime(timeLine.duration()/2); + timeLine.setCurrentTime(timeLine.duration()/2); + QCOMPARE(spy.count(), 1); + spy.clear(); + QCOMPARE(timeLine.currentTime(), timeLine.duration()/2); + timeLine.start(); + // Let it update on its own + QTest::qWait(timeLine.duration()/4); + QCOMPARE(timeLine.state(), QTimeLine::Running); + QVERIFY(timeLine.currentTime() > timeLine.duration()/2); + QVERIFY(timeLine.currentTime() < timeLine.duration()); + QTest::qWait(timeLine.duration()/4 + timeLine.duration()); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QVERIFY(timeLine.currentTime() == timeLine.duration()); + + // Reverse should decrease the currentTime + timeLine.setCurrentTime(timeLine.duration()/2); + timeLine.start(); + // Let it update on its own + QTest::qWait(timeLine.duration()/4); + QCOMPARE(timeLine.state(), QTimeLine::Running); + int currentTime = timeLine.currentTime(); + timeLine.setDirection(QTimeLine::Backward); + QTest::qWait(timeLine.duration()/4); + QVERIFY(timeLine.currentTime() < currentTime); + timeLine.stop(); +} + +void tst_QTimeLine::duration() +{ + QTimeLine timeLine(200); + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.duration(), 200); + timeLine.setDuration(1000); + QCOMPARE(timeLine.duration(), 1000); + + timeLine.start(); + QTest::qWait(999); + QCOMPARE(timeLine.state(), QTimeLine::Running); + QVERIFY(timeLine.currentTime() > 0.9); + QTest::qWait(50); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + // The duration shouldn't change + QCOMPARE(timeLine.duration(), 1000); +} + +void tst_QTimeLine::frameRate() +{ + QTimeLine timeLine; + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.updateInterval(), 1000 / 25); + timeLine.setUpdateInterval(1000 / 60); + QCOMPARE(timeLine.updateInterval(), 1000 / 60); + + // Default speed + timeLine.setUpdateInterval(1000 / 33); + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + int slowCount = spy.count(); + + // Faster!! + timeLine.setUpdateInterval(1000 / 100); + spy.clear(); + timeLine.setCurrentTime(0); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QVERIFY(slowCount < spy.count()); +} + +void tst_QTimeLine::value() +{ +#ifdef Q_OS_WINCE //On WinCE timer resolution is bad - use longer times + QTimeLine timeLine(2000); +#else + QTimeLine timeLine(200); +#endif + QVERIFY(timeLine.currentValue() == 0.0); + + // Default speed + qRegisterMetaType<qreal>("qreal"); + QSignalSpy spy(&timeLine, SIGNAL(valueChanged(qreal))); + timeLine.start(); + QTest::qWait(timeLine.duration()/3); + QVERIFY(timeLine.currentValue() > 0); + QTest::qWait(timeLine.duration()); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + qreal currentValue = timeLine.currentValue(); + QVERIFY(currentValue == 1); + QVERIFY(spy.count() > 0); + + // Reverse should decrease the value + timeLine.setCurrentTime(100); + timeLine.start(); + // Let it update on its own +#ifdef Q_OS_WINCE + QTest::qWait(500); +#else + QTest::qWait(50); +#endif + QCOMPARE(timeLine.state(), QTimeLine::Running); + qreal value = timeLine.currentValue(); + timeLine.setDirection(QTimeLine::Backward); +#ifdef Q_OS_WINCE + QTest::qWait(1000); +#else + QTest::qWait(100); +#endif + QVERIFY(timeLine.currentValue() < value); + timeLine.stop(); +} + +void tst_QTimeLine::currentFrame() +{ + QTimeLine timeLine(2000); + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.currentFrame(), 10); + + // Default speed + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + timeLine.start(); + QTest::qWait(timeLine.duration()/3); + QVERIFY(timeLine.currentFrame() > 10); + QTest::qWait(timeLine.duration()); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QCOMPARE(timeLine.currentFrame(), 20); + + // Reverse should decrease the value + timeLine.setCurrentTime(timeLine.duration()/2); + timeLine.start(); + // Let it update on its own + QTest::qWait(timeLine.duration()/4); + QCOMPARE(timeLine.state(), QTimeLine::Running); + int value = timeLine.currentFrame(); + timeLine.setDirection(QTimeLine::Backward); + QTest::qWait(timeLine.duration()/2); + QVERIFY(timeLine.currentFrame() < value); + timeLine.stop(); +} + +void tst_QTimeLine::loopCount() +{ + QTimeLine timeLine(200); + QCOMPARE(timeLine.loopCount(), 1); + timeLine.setFrameRange(10, 20); + QCOMPARE(timeLine.loopCount(), 1); + timeLine.setLoopCount(0); + QCOMPARE(timeLine.loopCount(), 0); + + // Default speed infiniti looping + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + timeLine.start(); + QTest::qWait(timeLine.duration()); + QCOMPARE(timeLine.state(), QTimeLine::Running); + //QCOMPARE(timeLine.currentFrame(), 20); + QTest::qWait(timeLine.duration()*6); + QCOMPARE(timeLine.state(), QTimeLine::Running); + QVERIFY(timeLine.currentTime() >= 0); + QVERIFY(timeLine.currentFrame() >= 10); + QVERIFY(timeLine.currentFrame() <= 20); + QCOMPARE(timeLine.state(), QTimeLine::Running); + timeLine.stop(); + + timeLine.setDuration(2500); // ### some platforms have a very low resolution timer + timeLine.setFrameRange(0, 2); + timeLine.setLoopCount(4); + + QSignalSpy finishedSpy(&timeLine, SIGNAL(finished())); + QSignalSpy frameChangedSpy(&timeLine, SIGNAL(frameChanged(int))); + QEventLoop loop; + connect(&timeLine, SIGNAL(finished()), &loop, SLOT(quit())); + + + for(int i=0;i<2;i++) { + + timeLine.start(); + //we clear te list after the start so we don't catch + //a frameChanged signal for the frame 0 at the beginning + finishedSpy.clear(); + frameChangedSpy.clear(); + + loop.exec(); + + QCOMPARE(finishedSpy.count(), 1); + QCOMPARE(frameChangedSpy.count(), 11); + for (int i = 0; i < 11; ++i) { + QCOMPARE(frameChangedSpy.at(i).at(0).toInt(), (i+1) % 3); + } + } + + timeLine.setDirection(QTimeLine::Backward); + timeLine.start(); + loop.exec(); + + QCOMPARE(finishedSpy.count(), 2); + QCOMPARE(frameChangedSpy.count(), 22); + for (int i = 11; i < 22; ++i) { + QCOMPARE(frameChangedSpy.at(i).at(0).toInt(), 2 - (i+2) % 3); + } +} + +void tst_QTimeLine::interpolation() +{ + QTimeLine timeLine(400); + QCOMPARE(timeLine.curveShape(), QTimeLine::EaseInOutCurve); + timeLine.setFrameRange(100, 200); + timeLine.setCurveShape(QTimeLine::LinearCurve); + QCOMPARE(timeLine.curveShape(), QTimeLine::LinearCurve); + + // smooth + timeLine.setCurveShape(QTimeLine::EaseInOutCurve); + timeLine.start(); + QTest::qWait(100); + QCOMPARE(timeLine.state(), QTimeLine::Running); + int firstValue = timeLine.currentFrame(); + QTest::qWait(200); + int endValue = timeLine.currentFrame(); + timeLine.stop(); // ### todo reset? + timeLine.setCurrentTime(0); // ### todo reset? + + // linear + timeLine.setCurveShape(QTimeLine::LinearCurve); + timeLine.start(); + QTest::qWait(100); + QCOMPARE(timeLine.state(), QTimeLine::Running); + + // Smooth accellerates slowly so in the beginning so it is farther behind + QVERIFY(firstValue < timeLine.currentFrame()); + QTest::qWait(200); + QVERIFY(endValue > timeLine.currentFrame()); + timeLine.stop(); +} + +void tst_QTimeLine::reverse_data() +{ + QTest::addColumn<int>("duration"); + QTest::addColumn<int>("start"); + QTest::addColumn<int>("end"); + QTest::addColumn<int>("direction"); + QTest::addColumn<int>("direction2"); + QTest::addColumn<int>("direction3"); + QTest::addColumn<int>("startTime"); + QTest::addColumn<int>("currentFrame"); + QTest::addColumn<qreal>("currentValue"); + QTest::addColumn<int>("wait"); + QTest::addColumn<int>("state"); + QTest::addColumn<int>("wait2"); + + QTest::newRow("start at end") << 200 << 1000 << 2000 << (int)QTimeLine::Backward << (int)QTimeLine::Forward << (int)QTimeLine::Backward << 200 << 2000 << qreal(1.0) << 40 << (int)QTimeLine::Running << 140; + QTest::newRow("start at half") << 200 << 1000 << 2000 << (int)QTimeLine::Backward << (int)QTimeLine::Forward << (int)QTimeLine::Backward << 100 << 1500 << qreal(0.5) << 40 << (int)QTimeLine::Running << 140; + QTest::newRow("start at quarter") << 200 << 1000 << 2000 << (int)QTimeLine::Backward << (int)QTimeLine::Forward << (int)QTimeLine::Backward << 50 << 1250 << qreal(0.25) << 40 << (int)QTimeLine::Running << 140; +} + +void tst_QTimeLine::reverse() +{ + QFETCH(int, duration); + QFETCH(int, start); + QFETCH(int, end); + QFETCH(int, direction); + QFETCH(int, direction2); + QFETCH(int, direction3); + QFETCH(int, startTime); + QFETCH(int, currentFrame); + QFETCH(qreal, currentValue); + QFETCH(int, wait); + QFETCH(int, state); + QFETCH(int, wait2); + + QTimeLine timeLine(duration); + timeLine.setCurveShape(QTimeLine::LinearCurve); + timeLine.setFrameRange(start, end); + + timeLine.setDirection((QTimeLine::Direction)direction); + timeLine.setDirection((QTimeLine::Direction)direction2); + timeLine.setDirection((QTimeLine::Direction)direction3); + QCOMPARE(timeLine.direction(), ((QTimeLine::Direction)direction)); + + timeLine.setCurrentTime(startTime); + timeLine.setDirection((QTimeLine::Direction)direction); + timeLine.setDirection((QTimeLine::Direction)direction2); + timeLine.setDirection((QTimeLine::Direction)direction3); + + QCOMPARE(timeLine.currentFrame(), currentFrame); + QCOMPARE(timeLine.currentValue(), currentValue); + timeLine.start(); + + QTest::qWait(wait); + QCOMPARE(timeLine.state(), (QTimeLine::State)state); + int firstValue = timeLine.currentFrame(); + timeLine.setDirection((QTimeLine::Direction)direction2); + timeLine.setDirection((QTimeLine::Direction)direction3); + timeLine.setDirection((QTimeLine::Direction)direction2); + timeLine.setDirection((QTimeLine::Direction)direction3); + QTest::qWait(wait2); + int endValue = timeLine.currentFrame(); + QVERIFY(endValue < firstValue); + + +} + +/* +void tst_QTimeLine::toggle() +{ + QTimeLine timeLine; + QCOMPARE(timeLine.isReverse(), false); + timeLine.toggle(); + QCOMPARE(timeLine.isReverse(), true); + timeLine.toggle(); + QCOMPARE(timeLine.isReverse(), false); +} +*/ +/* +void tst_QTimeLine::reset() +{ + QTimeLine timeLine; + timeLine.setFrameRange(10,100); + + timeLine.setLoopCount(-1); + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + timeLine.start(); + QCOMPARE(timeLine.state(), QTimeLine::Running); + int wait = timeLine.duration()*5/3; + QTest::qWait(wait); + QVERIFY(spy.count() >= 1 ); + QCOMPARE(timeLine.state(), QTimeLine::Running); + timeLine.setDirection(QTimeLine::Backward); + QVERIFY(timeLine.currentFrame() != 10); + QVERIFY(timeLine.currentTime() != 0); + QVERIFY(timeLine.state() != QTimeLine::Forward); + QVERIFY(timeLine.loopCount() != 0); + + timeLine.reset(); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QCOMPARE(timeLine.currentFrame(), timeLine.startFrame()); + QCOMPARE(timeLine.currentTime(), 0); + timeLine.setDirection(QTimeLine::Backward); + QCOMPARE(timeLine.loopCount(), 1); + QCOMPARE(timeLine.startFrame(), 10); + QCOMPARE(timeLine.endFrame(), 100); +} +*/ +void tst_QTimeLine::frameChanged() +{ + QTimeLine timeLine; + timeLine.setFrameRange(0,9); + timeLine.setUpdateInterval(1000); + QSignalSpy spy(&timeLine, SIGNAL(frameChanged(int))); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + // Probably 10 + QVERIFY(spy.count() <= 10 && spy.count() > 0); + + //timeLine.reset(); ### todo + timeLine.setUpdateInterval(5); + spy.clear(); + timeLine.setCurrentTime(0); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + // Probably 1 + QVERIFY(spy.count() <= 10 && spy.count() > 0); +} + +void tst_QTimeLine::stopped() +{ + QTimeLine timeLine; + timeLine.setFrameRange(0, 9); + qRegisterMetaType<QTimeLine::State>("QTimeLine::State"); + QSignalSpy spy(&timeLine, SIGNAL(stateChanged(QTimeLine::State))); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QCOMPARE(spy.count(), 2); + // timeLine.reset(); ### todo + spy.clear(); + //int currentFrame = timeLine.currentFrame(); + //int currentCurrentTime = timeLine.currentTime(); + timeLine.start(); + timeLine.stop(); + QCOMPARE(spy.count(), 2); + //QCOMPARE(timeLine.currentFrame(), currentFrame); ### Behavioral change + //QCOMPARE(timeLine.currentTime(), currentCurrentTime); + timeLine.setDirection(QTimeLine::Backward); + QCOMPARE(timeLine.loopCount(), 1); +} + +void tst_QTimeLine::finished() +{ + QTimeLine timeLine; + timeLine.setFrameRange(0,9); + QSignalSpy spy(&timeLine, SIGNAL(finished())); + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + QCOMPARE(spy.count(), 1); + + spy.clear(); + timeLine.start(); + timeLine.stop(); + QCOMPARE(spy.count(), 0); +} + +void tst_QTimeLine::isRunning() +{ + QTimeLine timeLine; + timeLine.setFrameRange(0,9); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + timeLine.start(); + QCOMPARE(timeLine.state(), QTimeLine::Running); + timeLine.stop(); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); + + timeLine.start(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(timeLine.state(), QTimeLine::NotRunning); +} + +void tst_QTimeLine::multipleTimeLines() +{ + // Stopping a timer shouldn't affect the other timers + QTimeLine timeLine(200); + timeLine.setFrameRange(0,99); + QSignalSpy spy(&timeLine, SIGNAL(finished())); + + QTimeLine timeLineKiller; + timeLineKiller.setFrameRange(0,99); + + timeLineKiller.start(); + timeLine.start(); + timeLineKiller.stop(); + QTest::qWait(timeLine.duration()*2); + QCOMPARE(spy.count(), 1); +} + +void tst_QTimeLine::sineCurve() +{ + QTimeLine timeLine(1000); + timeLine.setCurveShape(QTimeLine::SineCurve); + QCOMPARE(timeLine.valueForTime(0), qreal(0)); + QCOMPARE(timeLine.valueForTime(250), qreal(0.5)); + QCOMPARE(timeLine.valueForTime(500), qreal(1)); + QCOMPARE(timeLine.valueForTime(750), qreal(0.5)); + QCOMPARE(timeLine.valueForTime(1000), qreal(0)); +} + +void tst_QTimeLine::cosineCurve() +{ + QTimeLine timeLine(1000); + timeLine.setCurveShape(QTimeLine::CosineCurve); + QCOMPARE(timeLine.valueForTime(0), qreal(0.5)); + QCOMPARE(timeLine.valueForTime(250), qreal(1)); + QCOMPARE(timeLine.valueForTime(500), qreal(0.5)); + QCOMPARE(timeLine.valueForTime(750), qreal(0)); + QCOMPARE(timeLine.valueForTime(1000), qreal(0.5)); +} + +void tst_QTimeLine::outOfRange() +{ + QTimeLine timeLine(1000); + QCOMPARE(timeLine.valueForTime(-100), qreal(0)); + QCOMPARE(timeLine.valueForTime(2000), qreal(1)); + + timeLine.setCurveShape(QTimeLine::SineCurve); + QCOMPARE(timeLine.valueForTime(2000), qreal(0)); +} + +void tst_QTimeLine::stateInFinishedSignal() +{ + QTimeLine timeLine(50); + + connect(&timeLine, SIGNAL(finished()), this, SLOT(finishedSlot())); + state = QTimeLine::State(-1); + + timeLine.start(); + QTest::qWait(250); + + QCOMPARE(state, QTimeLine::NotRunning); +} + +void tst_QTimeLine::finishedSlot() +{ + QTimeLine *timeLine = qobject_cast<QTimeLine *>(sender()); + if (timeLine) + state = timeLine->state(); +} + +void tst_QTimeLine::resume() +{ + QTimeLine timeLine(1000); + { + QCOMPARE(timeLine.currentTime(), 0); + timeLine.start(); + QTest::qWait(250); + timeLine.stop(); + int oldCurrentTime = timeLine.currentTime(); + QVERIFY(oldCurrentTime > 0); + QVERIFY(oldCurrentTime < 1000); + timeLine.resume(); + QTest::qWait(250); + timeLine.stop(); + int currentTime = timeLine.currentTime(); + QVERIFY(currentTime > oldCurrentTime); + QVERIFY(currentTime < 1000); + } + timeLine.setDirection(QTimeLine::Backward); + { + timeLine.setCurrentTime(1000); + QCOMPARE(timeLine.currentTime(), 1000); + timeLine.start(); + QTest::qWait(250); + timeLine.stop(); + int oldCurrentTime = timeLine.currentTime(); + QVERIFY(oldCurrentTime < 1000); + QVERIFY(oldCurrentTime > 0); + timeLine.resume(); + QTest::qWait(250); + timeLine.stop(); + int currentTime = timeLine.currentTime(); + QVERIFY(currentTime < oldCurrentTime); + QVERIFY(currentTime > 0); + } +} + +QTEST_MAIN(tst_QTimeLine) +#include "tst_qtimeline.moc" + +#endif //QT_VERSION |