123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.commontk.org/LICENSE
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- // Qt includes
- #include <QApplication>
- #include <QTest>
- // CTK includes
- #include "ctkDoubleRangeSlider.h"
- #include "ctkLinearValueProxy.h"
- #include "ctkTest.h"
- #include "ctkValueProxy.h"
- // STD includes
- #include <limits>
- namespace
- {
- //-----------------------------------------------------------------------------
- void getSpyReport(QSignalSpy& spy, double expectedValue)
- {
- QCOMPARE(spy.count(), 1);
- QList<QVariant> arguments = spy.takeFirst(); // take the first signal
- ctkTest::COMPARE(arguments.at(0).toDouble(), expectedValue);
- }
- //-----------------------------------------------------------------------------
- class CustomSpy : public QObject
- {
- Q_OBJECT
- public:
- CustomSpy()
- {
- this->AcknowledgedSignals = 0;
- }
- public slots:
- void onValuesChanged(double min, double max)
- {
- ++this->AcknowledgedSignals;
- this->MinSpyData.append(min);
- this->MaxSpyData.append(max);
- }
- public:
- void getSpyReport(double min, double max)
- {
- QCOMPARE(this->AcknowledgedSignals, 1);
- QCOMPARE(this->MinSpyData.size(), 1);
- ctkTest::COMPARE(this->MinSpyData[0], min);
- QCOMPARE(this->MaxSpyData.size(), 1);
- ctkTest::COMPARE(this->MaxSpyData[0], max);
- }
- QList<double> MinSpyData;
- QList<double> MaxSpyData;
- int AcknowledgedSignals;
- };
- } // end namespace
- //-----------------------------------------------------------------------------
- class ctkDoubleRangeSliderValueProxyTester: public QObject
- {
- Q_OBJECT
- private slots:
- void testSetValues();
- void testSetValues_data();
- void testSetMinValue();
- void testSetMinValue_data() { testSetValueCommonData(); };
- void testSetMaxValue();
- void testSetMaxValue_data(){ testSetValueCommonData(); };
- void testSetMinPosition();
- void testSetMinPosition_data() { testSetPositionCommonData(); };
- void testSetMaxPosition();
- void testSetMaxPosition_data() { testSetPositionCommonData(); };
- private:
- void testSetValueCommonData();
- void testSetPositionCommonData();
- };
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetValues()
- {
- // Setup
- ctkDoubleRangeSlider slider;
- slider.setMinimum(-200);
- slider.setMaximum(200);
- slider.setSingleStep(0.01);
- slider.setMinimumValue(-32.6);
- slider.setMaximumValue(32.6);
- QFETCH(double, coefficient);
- QFETCH(double, offset);
- ctkLinearValueProxy proxy;
- proxy.setCoefficient(coefficient);
- proxy.setOffset(offset);
- slider.setValueProxy(&proxy);
- // Spy
- CustomSpy valuesSpy();
- QObject::connect(&slider, SIGNAL(valuesChanged(double, double)),
- &valuesSpy, SLOT(onValuesChanged(double, double)));
- // Test
- QFETCH(double, min);
- QFETCH(double, max);
- slider.setValues(min, max);
- QFETCH(double, expectedMin);
- QFETCH(double, expectedMax);
- valuesSpy.getSpyReport(expectedMin, expectedMax);
- ctkTest::COMPARE(slider.minimumValue(), expectedMin);
- ctkTest::COMPARE(slider.maximumValue(), expectedMax);
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetValues_data()
- {
- QTest::addColumn<double>("coefficient");
- QTest::addColumn<double>("offset");
- QTest::addColumn<double>("min");
- QTest::addColumn<double>("expectedMin");
- QTest::addColumn<double>("max");
- QTest::addColumn<double>("expectedMax");
- //---------------------------------------------------------------------------
- // Offset
- QTest::newRow("Offset only") << 1.0 << 42.19176 << 0.1 << 0.1 << 0.2 << 0.2;
- QTest::newRow("Offset only: max+offset < min+offset < -200") << 1.0 << -42.19
- << -160.0 << -157.81
- << -190.9 << -157.81;
- QTest::newRow("Offset only: max+offset < -200 < min+offset") << 1.0 << -42.19
- << -0.1 << -157.81
- << -160.9 << -0.1;
- QTest::newRow("Offset only: -200 < max+offset < min+offset") << 1.0 << 42.19
- << -0.1 << -130.9
- << -130.9 << -0.1;
- QTest::newRow("Offset only: 200 < max+offset < min+offset") << 1.0 << 42.19
- << 160.0 << 157.81
- << 190.9 << 157.81;
- QTest::newRow("Offset only: max+offset < 200 < min+offset") << 1.0 << 42.19
- << 160.9 << -0.9
- << -0.9 << 157.81;
- QTest::newRow("Offset only: max+offset < min+offset < 200") << 1.0 << 42.19
- << 130.6 << -13.9
- << -13.9 << 130.6;
- QTest::newRow("Offset only: 200 < max = max_double = min = max_double")
- << 1.0 << 42.19
- << std::numeric_limits<double>::max() << 157.81
- << std::numeric_limits<double>::max() << 157.81;
- QTest::newRow("Offset only: max = -max_double < -200 < 200 < min = max_double")
- << 1.0 << 42.19
- << std::numeric_limits<double>::max() << -242.19
- << -std::numeric_limits<double>::max() << 157.81;
- QTest::newRow("Offset only: max = -max_double = min = -max_double < -200")
- << 1.0 << 42.19
- << - std::numeric_limits<double>::max() << -242.19
- << - std::numeric_limits<double>::max() << -242.19;
- QTest::newRow("Offset only: 200 < max = infinity = min = infinity")
- << 1.0 << 42.19
- << std::numeric_limits<double>::infinity() << 157.81
- << std::numeric_limits<double>::infinity() << 157.81;
- QTest::newRow("Offset only: max = -infinity < -200 < 200 < min = infinity")
- << 1.0 << 42.19
- << std::numeric_limits<double>::infinity() << -242.19
- << -std::numeric_limits<double>::infinity() << 157.81;
- QTest::newRow("Offset only: max = -infinity = min = -infinity < -200")
- << 1.0 << 42.19
- << - std::numeric_limits<double>::infinity() << -242.19
- << - std::numeric_limits<double>::infinity() << -242.19;
- QTest::newRow("Offset only: max = min = NaN")
- << 1.0 << 42.19
- << std::numeric_limits<double>::quiet_NaN() << -242.19
- << std::numeric_limits<double>::quiet_NaN() << -242.19;
- QTest::newRow("Offset only: max = NaN && min > 200")
- << 1.0 << 42.19
- << 630.0 << -242.19
- << std::numeric_limits<double>::quiet_NaN() << 157.81;
- QTest::newRow("Offset only: min = NaN && max < -200")
- << 1.0 << 42.19
- << std::numeric_limits<double>::quiet_NaN() << -242.19
- << -794348.12 << -242.19;
- //---------------------------------------------------------------------------
- // Coefficient
- QTest::newRow("Coeff only") << 5.0 << 0.0 << 0.1 << 0.1 << 0.2 << 0.2;
- QTest::newRow("Coeff only: max*coeff < min*coeff < -200") << 5.0 << 0.0
- << -160.0 << -40.0
- << -190.9 << -40.0;
- QTest::newRow("Coeff only: max*coeff < -200 < min*coeff") << 5.0 << 0.0
- << -0.1 << -40.0
- << -160.9 << -0.1;
- QTest::newRow("Coeff only: -200 < max*coeff < min*coeff") << 5.0 << 0.0
- << -0.1 << -20.9
- << -20.9 << -0.1;
- QTest::newRow("Coeff only: 200 < max*coeff < min*coeff") << 5.0 << 0.0
- << 160.0 << 40.0
- << 190.9 << 40.0;
- QTest::newRow("Coeff only: max*coeff < 200 < min*coeff") << 5.0 << 0.0
- << 160.9 << -0.9
- << -0.9 << 40.00;
- QTest::newRow("Coeff only: max*coeff < min*coeff < 200") << 5.0 << 0.0
- << 13.6 << -13.9
- << -13.9 << 13.6;
- QTest::newRow("Coeff only: 200 < max = max_double = min = max_double")
- << 5.0 << 0.0
- << std::numeric_limits<double>::max() << 40.0
- << std::numeric_limits<double>::max() << 40.0;
- QTest::newRow("Coeff only: max = -max_double < -200 < 200 < min = max_double")
- << 5.0 << 0.0
- << std::numeric_limits<double>::max() << -40.0
- << - std::numeric_limits<double>::max() << 40.0;
- QTest::newRow("Coeff only: max = -max_double = min = -max_double < -200")
- << 5.0 << 0.0
- << -std::numeric_limits<double>::max() << -40.0
- << -std::numeric_limits<double>::max() << -40.0;
- QTest::newRow("Coeff only: 200 < max = infinity = min = infinity")
- << 5.0 << 0.0
- << std::numeric_limits<double>::infinity() << 40.0
- << std::numeric_limits<double>::infinity() << 40.0;
- QTest::newRow("Coeff only: max = -infinity < -200 < 200 < min = infinity")
- << 5.0 << 0.0
- << std::numeric_limits<double>::infinity() << -40.0
- << -std::numeric_limits<double>::infinity() << 40.0;
- QTest::newRow("Coeff only: max = -infinity = min = -infinity < -200")
- << 5.0 << 0.0
- << - std::numeric_limits<double>::infinity() << -40.0
- << - std::numeric_limits<double>::infinity() << -40.0;
- QTest::newRow("Coeff only: max = min = NaN")
- << 5.0 << 0.0
- << std::numeric_limits<double>::quiet_NaN() << -40.0
- << std::numeric_limits<double>::quiet_NaN() << -40.0;
- QTest::newRow("Coeff only: max = NaN && min > 200")
- << 5.0 << 0.0
- << 630.0 << -40.0
- << std::numeric_limits<double>::quiet_NaN() << 40.0;
- QTest::newRow("Coeff only: min = NaN && max < -200")
- << 5.0 << 0.0
- << std::numeric_limits<double>::quiet_NaN() << -40.0
- << -794348.12 << -40.0;
- //---------------------------------------------------------------------------
- // Linear
- QTest::newRow("Linear") << 5.0 << 12.0 << 0.1 << 0.1 << 0.2 << 0.2;
- QTest::newRow("Linear:f(max) < f(min) < -200") << 5.0 << 12.0
- << -160.0 << -42.4
- << -190.9 << -42.4;
- QTest::newRow("Linear: f(max) < -200 < f(min)") << 5.0 << 12.0
- << -0.1 << -42.4
- << -160.9 << -0.1;
- QTest::newRow("Linear: -200 < f(max) < f(min)") << 5.0 << 12.0
- << -0.1 << -20.9
- << -20.9 << -0.1;
- QTest::newRow("Linear: 200 < f(max) < f(min)") << 5.0 << 12.0
- << 160.0 << 37.6
- << 190.9 << 37.6;
- QTest::newRow("Linear: f(max) < 200 < f(min)") << 5.0 << 12.0
- << 160.9 << -0.9
- << -0.9 << 37.6;
- QTest::newRow("Linear: f(max) < f(min) < 200") << 5.0 << 12.0
- << 13.6 << -13.9
- << -13.9 << 13.6;
- QTest::newRow("Linear: 200 < max = max_double = min = max_double")
- << 5.0 << 12.0
- << std::numeric_limits<double>::max() << 37.6
- << std::numeric_limits<double>::max() << 37.6;
- QTest::newRow("Linear: max = -max_double < -200 < 200 < min = max_double")
- << 5.0 << 12.0
- << std::numeric_limits<double>::max() << -42.4
- << - std::numeric_limits<double>::max() << 37.6;
- QTest::newRow("Linear: max = -max_double = min = -max_double < -200")
- << 5.0 << 12.0
- << -std::numeric_limits<double>::max() << -42.4
- << -std::numeric_limits<double>::max() << -42.4;
- QTest::newRow("Linear: 200 < max = infinity = min = infinity")
- << 5.0 << 12.0
- << std::numeric_limits<double>::infinity() << 37.6
- << std::numeric_limits<double>::infinity() << 37.6;
- QTest::newRow("Linear: max = -infinity < -200 < 200 < min = infinity")
- << 5.0 << 12.0
- << std::numeric_limits<double>::infinity() << -42.4
- << -std::numeric_limits<double>::infinity() << 37.6;
- QTest::newRow("Linear: max = -infinity = min = -infinity < -200")
- << 5.0 << 12.0
- << - std::numeric_limits<double>::infinity() << -42.4
- << - std::numeric_limits<double>::infinity() << -42.4;
- QTest::newRow("Linear: max = min = NaN")
- << 5.0 << 12.0
- << std::numeric_limits<double>::quiet_NaN() << -42.4
- << std::numeric_limits<double>::quiet_NaN() << -42.4;
- QTest::newRow("Linear: max = NaN && f(min) > 200")
- << 5.0 << 12.0
- << 630.0 << -42.4
- << std::numeric_limits<double>::quiet_NaN() << 37.6;
- QTest::newRow("Linear: min = NaN && f(max) < -200")
- << 5.0 << 12.0
- << std::numeric_limits<double>::quiet_NaN() << -42.4
- << -794348.12 << -42.4;
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetMinValue()
- {
- // Setup
- ctkDoubleRangeSlider slider;
- slider.setMinimum(-200);
- slider.setMaximum(200);
- slider.setSingleStep(0.01);
- slider.setMinimumValue(-32.6);
- QFETCH(double, coefficient);
- QFETCH(double, offset);
- ctkLinearValueProxy proxy;
- proxy.setCoefficient(coefficient);
- proxy.setOffset(offset);
- slider.setValueProxy(&proxy);
- // Spy
- QSignalSpy valueSpy(&slider, SIGNAL(minimumValueChanged(double)));
- // Test
- QFETCH(double, value);
- slider.setMinimumValue(value);
- QFETCH(double, expectedValue);
- getSpyReport(valueSpy, expectedValue);
- ctkTest::COMPARE(slider.minimumValue(), expectedValue);
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetMaxValue()
- {
- // Setup
- ctkDoubleRangeSlider slider;
- slider.setMinimum(-200);
- slider.setMaximum(200);
- slider.setSingleStep(0.01);
- slider.setMaximumValue(-32.6);
- QFETCH(double, coefficient);
- QFETCH(double, offset);
- ctkLinearValueProxy proxy;
- proxy.setCoefficient(coefficient);
- proxy.setOffset(offset);
- slider.setValueProxy(&proxy);
- // Spy
- QSignalSpy valueSpy(&slider, SIGNAL(maximumValueChanged(double)));
- // Test
- QFETCH(double, value);
- slider.setMaximumValue(value);
- QFETCH(double, expectedValue);
- getSpyReport(valueSpy, expectedValue);
- ctkTest::COMPARE(slider.maximumValue(), expectedValue);
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetValueCommonData()
- {
- QTest::addColumn<double>("coefficient");
- QTest::addColumn<double>("offset");
- QTest::addColumn<double>("value");
- QTest::addColumn<double>("expectedValue");
- //---------------------------------------------------------------------------
- // Offset
- QTest::newRow("Offset only") << 1.0 << 42.19176 << 0.1 << 0.1;
- QTest::newRow("Offset only: less than min")
- << 1.0 << 42.19 << -510.0 << -242.19;
- QTest::newRow("Offset only: less than min but ok with offset")
- << 1.0 << 42.19 << -230.0 << -230.0;
- QTest::newRow("Offset only: less than min with offset")
- << 1.0 << -42.19 << -190.0 << -157.81;
- QTest::newRow("Offset only: more than max with offset")
- << 1.0 << 42.19 << 160.0 << 157.81;
- QTest::newRow("Offset only: more than max")
- << 1.0 << -42.19 << 65010.0 << 242.19;
- QTest::newRow("Offset only: less than max but ok with offset")
- << 1.0 << -42.19 << 229.1 << 229.1;
- QTest::newRow("Offset only: max")
- << 1.0 << 42.19 << std::numeric_limits<double>::max() << 157.81;
- QTest::newRow("Offset only: min")
- << 1.0 << 42.19 << -std::numeric_limits<double>::max() << -242.19;
- QTest::newRow("Offset only: infinity")
- << 1.0 << 42.19 << std::numeric_limits<double>::infinity() << 157.81;
- QTest::newRow("Offset only: - infinity")
- << 1.0 << 42.19 << -std::numeric_limits<double>::infinity() << -242.19;
- QTest::newRow("Offset only: Nan")
- << 1.0 << 42.19 << std::numeric_limits<double>::quiet_NaN() << -242.19;
- //---------------------------------------------------------------------------
- // Coefficient
- QTest::newRow("Coeff only") << 5.0 << 0.0 << 0.1 << 0.1;
- QTest::newRow("Coeff only: less than min")
- << 5.0 << 0.0 << -510.0 << -40.0;
- QTest::newRow("Coeff only: less than min but ok with coeff")
- << 0.5 << 0.0 << -230.0 << -230.0;
- QTest::newRow("Coeff only: less than min with coeff")
- << 5.0 << 0.0 << -190.0 << -40.0;
- QTest::newRow("Coeff only: more than max with coeff")
- << 5.0 << 0.0 << 160.0 << 40.0;
- QTest::newRow("Coeff only: more than max")
- << 5.0 << 0.0 << 65010.0 << 40.0;
- QTest::newRow("Offset only: less than max but ok with coeff")
- << 0.5 << 0.0 << 229.2 << 229.2;
- QTest::newRow("Coeff only: max")
- << 5.0 << 0.0 << std::numeric_limits<double>::max() << 40.0;
- QTest::newRow("Coeff only: min")
- << 5.0 << 0.0 << -std::numeric_limits<double>::max() << -40.0;
- QTest::newRow("Coeff only: infinity")
- << 5.0 << 0.0 << std::numeric_limits<double>::infinity() << 40.0;
- QTest::newRow("Coeff only: - infinity")
- << 5.0 << 0.0 << -std::numeric_limits<double>::infinity() << -40.0;
- QTest::newRow("Coeff only: Nan")
- << 5.0 << 0.0 << std::numeric_limits<double>::quiet_NaN() << -40.0;
- //---------------------------------------------------------------------------
- // Linear
- QTest::newRow("Linear") << 5.0 << 0.0 << 0.1 << 0.1;
- QTest::newRow("Linear: less than min")
- << 5.0 << 12.0 << -510.0 << -42.4;
- QTest::newRow("Linear: less than min but ok with function")
- << 0.5 << 12.0 << -230.0 << -230.0;
- QTest::newRow("Linear: less than min with function")
- << 5.0 << 12.0 << -61.5 << -42.4;
- QTest::newRow("Linear: more than max with function")
- << 5.0 << 12.0 << 160.0 << 37.6;
- QTest::newRow("Linear: more than max")
- << 5.0 << 12.0 << 65010.0 << 37.6;
- QTest::newRow("Offset only: less than max but ok with function")
- << 0.5 << 12.0 << 229.2 << 229.2;
- QTest::newRow("Linear: max")
- << 5.0 << 12.0 << std::numeric_limits<double>::max() << 37.6;
- QTest::newRow("Linear: min")
- << 5.0 << 12.0 << -std::numeric_limits<double>::max() << -42.4;
- QTest::newRow("Linear: infinity")
- << 5.0 << 12.0 << std::numeric_limits<double>::infinity() << 37.6;
- QTest::newRow("Linear: - infinity")
- << 5.0 << 12.0 << -std::numeric_limits<double>::infinity() << -42.4;
- QTest::newRow("Linear: Nan")
- << 5.0 << 12.0 << std::numeric_limits<double>::quiet_NaN() << -42.4;
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetMinPosition()
- {
- // Setup
- ctkDoubleRangeSlider slider;
- slider.setMinimum(-200);
- slider.setMaximum(200);
- slider.setSingleStep(0.01);
- slider.setMinimumValue(-32.6);
- QFETCH(double, coefficient);
- QFETCH(double, offset);
- ctkLinearValueProxy proxy;
- proxy.setCoefficient(coefficient);
- proxy.setOffset(offset);
- slider.setValueProxy(&proxy);
- // Spy
- QSignalSpy valueSpy(&slider, SIGNAL(minimumValueChanged(double)));
- // Test
- QFETCH(double, sliderPosition);
- slider.setMinimumPosition(sliderPosition);
- QFETCH(double, expectedSliderPosition);
- QFETCH(double, expectedValue);
- getSpyReport(valueSpy, expectedValue);
- ctkTest::COMPARE(slider.minimumValue(), expectedValue);
- ctkTest::COMPARE(slider.minimumPosition(), expectedSliderPosition);
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetMaxPosition()
- {
- // Setup
- ctkDoubleRangeSlider slider;
- slider.setMinimum(-200);
- slider.setMaximum(200);
- slider.setSingleStep(0.01);
- slider.setMaximumValue(-32.6);
- QFETCH(double, coefficient);
- QFETCH(double, offset);
- ctkLinearValueProxy proxy;
- proxy.setCoefficient(coefficient);
- proxy.setOffset(offset);
- slider.setValueProxy(&proxy);
- // Spy
- QSignalSpy valueSpy(&slider, SIGNAL(maximumValueChanged(double)));
- // Test
- QFETCH(double, sliderPosition);
- slider.setMaximumPosition(sliderPosition);
- QFETCH(double, expectedSliderPosition);
- QFETCH(double, expectedValue);
- getSpyReport(valueSpy, expectedValue);
- ctkTest::COMPARE(slider.maximumValue(), expectedValue);
- ctkTest::COMPARE(slider.maximumPosition(), expectedSliderPosition);
- }
- //-----------------------------------------------------------------------------
- void ctkDoubleRangeSliderValueProxyTester::testSetPositionCommonData()
- {
- QTest::addColumn<double>("coefficient");
- QTest::addColumn<double>("offset");
- QTest::addColumn<double>("sliderPosition");
- QTest::addColumn<double>("expectedValue");
- QTest::addColumn<double>("expectedSliderPosition");
- //---------------------------------------------------------------------------
- // Offset
- QTest::newRow("Offset only") << 1.0 << 42.19 << 0.1 << -42.09 << 0.1;
- QTest::newRow("Offset only: less than min")
- << 1.0 << 42.19 << -510.0 << -242.19 << -200.0;
- QTest::newRow("Offset only: more than max")
- << 1.0 << -42.19 << 65010.0 << 242.19 << 200.0;
- QTest::newRow("Offset only: max")
- << 1.0 << 42.19 << std::numeric_limits<double>::max()
- << 157.81 << 200.0;
- QTest::newRow("Offset only: min")
- << 1.0 << 42.19 << -std::numeric_limits<double>::max()
- << -242.19 << -200.0;
- QTest::newRow("Offset only: infinity")
- << 1.0 << 42.19 << std::numeric_limits<double>::infinity()
- << 157.81 << 200.0;
- QTest::newRow("Offset only: - infinity")
- << 1.0 << 42.19 << -std::numeric_limits<double>::infinity()
- << -242.19 << -200.0;
- QTest::newRow("Offset only: Nan")
- << 1.0 << 42.19 << std::numeric_limits<double>::quiet_NaN()
- << -242.19 << -200.0;
- //---------------------------------------------------------------------------
- // Coefficient
- QTest::newRow("Coeff only") << 5.0 << 0.0 << 5.0 << 1.0 << 5.0;
- QTest::newRow("Coeff only: less than min")
- << 5.0 << 0.0 << -1010.0 << -40.0 << -200.0;
- QTest::newRow("Coeff only: more than max")
- << 5.0 << 0.0 << 65010.0 << 40.0 << 200.0;
- QTest::newRow("Coeff only: max")
- << 5.0 << 0.0 << std::numeric_limits<double>::max() << 40.0 << 200.0;
- QTest::newRow("Coeff only: min")
- << 5.0 << 0.0 << -std::numeric_limits<double>::max() << -40.0 << -200.0;
- QTest::newRow("Coeff only: infinity")
- << 5.0 << 0.0 << std::numeric_limits<double>::infinity() << 40.0 << 200.0;
- QTest::newRow("Coeff only: - infinity")
- << 5.0 << 0.0 << -std::numeric_limits<double>::infinity()
- << -40.0 << -200.0;
- QTest::newRow("Coeff only: Nan")
- << 5.0 << 0.0 << std::numeric_limits<double>::quiet_NaN()
- << -40.0 << -200.0;
- //---------------------------------------------------------------------------
- // Linear
- QTest::newRow("Linear") << 5.0 << 12.0 << 42.0 << 6.0 << 42.0;
- QTest::newRow("Linear: less than min")
- << 5.0 << 12.0 << -5010.0 << -42.4 << -200.0;
- QTest::newRow("Linear: more than max")
- << 5.0 << 12.0 << 65010.0 << 37.6 << 200.0;
- QTest::newRow("Linear: max")
- << 5.0 << 12.0 << std::numeric_limits<double>::max() << 37.6 << 200.0;
- QTest::newRow("Linear: min")
- << 5.0 << 12.0 << -std::numeric_limits<double>::max() << -42.4 << -200.0;
- QTest::newRow("Linear: infinity")
- << 5.0 << 12.0 << std::numeric_limits<double>::infinity() << 37.6 << 200.0;
- QTest::newRow("Linear: - infinity")
- << 5.0 << 12.0 << -std::numeric_limits<double>::infinity()
- << -42.4 << -200.0;
- QTest::newRow("Linear: Nan")
- << 5.0 << 12.0 << std::numeric_limits<double>::quiet_NaN()
- << -42.4 << -200.0;
- }
- // ----------------------------------------------------------------------------
- CTK_TEST_MAIN(ctkDoubleRangeSliderValueProxyTest)
- #include "moc_ctkDoubleRangeSliderValueProxyTest.cpp"
|