File indexing completed on 2024-09-08 06:35:20

0001 /*
0002     File                 : MultiRangeTest3.cpp
0003     Project              : LabPlot
0004     Description          : Third tests for multi ranges
0005     --------------------------------------------------------------------
0006     SPDX-FileCopyrightText: 2021 Martin Marmsoler <martin.marmsoler@gmail.com>
0007     SPDX-FileCopyrightText: 2021 Stefan Gerlach <stefan.gerlach@uni.kn>
0008 
0009     SPDX-License-Identifier: GPL-2.0-or-later
0010 */
0011 
0012 #include "MultiRangeTest3.h"
0013 #include "MultiRangeTest_macros.h"
0014 
0015 void MultiRangeTest3::baseDockSetAspects_NoPlotRangeChange() {
0016     LOAD_PROJECT
0017 
0018     const int sinCurveCSystemIndex = sinCurve->coordinateSystemIndex();
0019     const int tanCurveCSystemIndex = tanCurve->coordinateSystemIndex();
0020     QVERIFY(sinCurveCSystemIndex != tanCurveCSystemIndex);
0021     // checks directly the plot. In the basedock the element is used and not the plot, so do it here too
0022     QVERIFY(sinCurve->coordinateSystemCount() == 3);
0023 
0024     XYCurveDock dock(nullptr);
0025     dock.setupGeneral();
0026     dock.setCurves(QList<XYCurve*>({sinCurve, tanCurve}));
0027 
0028     dock.updatePlotRangeList();
0029 
0030     // The coordinatesystem indices shall not change
0031     QCOMPARE(sinCurveCSystemIndex, sinCurve->coordinateSystemIndex());
0032     QCOMPARE(tanCurveCSystemIndex, tanCurve->coordinateSystemIndex());
0033 }
0034 
0035 /*!
0036  * \brief MultiRangeTest3::curveRangeChange
0037  * When changing the coordinatesystem of an object like a curve, the
0038  * curve shall be updated accordingly also for undo/redo
0039  */
0040 void MultiRangeTest3::curveRangeChange() {
0041     Project project;
0042     auto* ws = new Worksheet(QStringLiteral("worksheet"));
0043     QVERIFY(ws != nullptr);
0044     project.addChild(ws);
0045 
0046     auto* plot = new CartesianPlot(QStringLiteral("plot"));
0047     QVERIFY(plot != nullptr);
0048     ws->addChild(plot);
0049 
0050     auto* curve{new XYEquationCurve(QStringLiteral("f(x)"))};
0051     curve->setCoordinateSystemIndex(plot->defaultCoordinateSystemIndex());
0052     plot->addChild(curve);
0053 
0054     XYEquationCurve::EquationData data;
0055     data.min = QStringLiteral("0");
0056     data.max = QStringLiteral("10");
0057     data.count = 100;
0058     data.expression1 = QStringLiteral("sin(x*2*pi*3)");
0059     curve->setEquationData(data);
0060     curve->recalculate();
0061 
0062     CHECK_RANGE(plot, curve, Dimension::X, 0., 10.);
0063     CHECK_RANGE(plot, curve, Dimension::Y, -1., 1.);
0064 
0065     // Create new cSystem
0066     Range<double> yRange;
0067     yRange.setFormat(RangeT::Format::Numeric);
0068     yRange.setAutoScale(false);
0069     yRange.setRange(0, 10);
0070     plot->addYRange(yRange);
0071     CartesianCoordinateSystem* cSystem = new CartesianCoordinateSystem(plot);
0072     cSystem->setIndex(Dimension::X, 0);
0073     cSystem->setIndex(Dimension::Y, 1);
0074     plot->addCoordinateSystem(cSystem);
0075 
0076     QCOMPARE(plot->coordinateSystemCount(), 2);
0077     QCOMPARE(plot->coordinateSystem(1), cSystem);
0078 
0079     CHECK_RANGE(plot, curve, Dimension::X, 0., 10.);
0080     CHECK_RANGE(plot, curve, Dimension::Y, -1., 1.);
0081 
0082     curve->setCoordinateSystemIndex(1);
0083 
0084     CHECK_RANGE(plot, curve, Dimension::X, 0., 10.);
0085     CHECK_RANGE(plot, curve, Dimension::Y, 0., 10.);
0086 
0087     curve->undoStack()->undo();
0088 
0089     QCOMPARE(curve->coordinateSystemIndex(), 0);
0090     CHECK_RANGE(plot, curve, Dimension::X, 0., 10.);
0091     CHECK_RANGE(plot, curve, Dimension::Y, -1., 1.);
0092 
0093     curve->undoStack()->redo();
0094 
0095     QCOMPARE(curve->coordinateSystemIndex(), 1);
0096     CHECK_RANGE(plot, curve, Dimension::X, 0., 10.);
0097     CHECK_RANGE(plot, curve, Dimension::Y, 0., 10.);
0098 }
0099 
0100 QTEST_MAIN(MultiRangeTest3)