2016-01-09 17:16:03 +01:00
|
|
|
/************************************************************************
|
|
|
|
**
|
|
|
|
** @file tst_vdetail.cpp
|
|
|
|
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
|
|
|
** @date 9 1, 2016
|
|
|
|
**
|
|
|
|
** @brief
|
|
|
|
** @copyright
|
2017-10-05 11:20:01 +02:00
|
|
|
** This source code is part of the Valentina project, a pattern making
|
2016-01-09 17:16:03 +01:00
|
|
|
** program, whose allow create and modeling patterns of clothing.
|
|
|
|
** Copyright (C) 2016 Valentina project
|
|
|
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
|
|
|
**
|
|
|
|
** Valentina is free software: you can redistribute it and/or modify
|
|
|
|
** it under the terms of the GNU General Public License as published by
|
|
|
|
** the Free Software Foundation, either version 3 of the License, or
|
|
|
|
** (at your option) any later version.
|
|
|
|
**
|
|
|
|
** Valentina is distributed in the hope that it will be useful,
|
|
|
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
** GNU General Public License for more details.
|
|
|
|
**
|
|
|
|
** You should have received a copy of the GNU General Public License
|
|
|
|
** along with Valentina. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
**
|
|
|
|
*************************************************************************/
|
|
|
|
|
2017-01-22 14:29:23 +01:00
|
|
|
#include "tst_vpiece.h"
|
2016-01-09 17:16:03 +01:00
|
|
|
#include "../vpatterndb/vcontainer.h"
|
2017-01-21 18:12:57 +01:00
|
|
|
#include "../vpatterndb/vpiece.h"
|
2019-05-08 14:19:03 +02:00
|
|
|
#include "../vpatterndb/vpassmark.h"
|
2017-01-21 18:12:57 +01:00
|
|
|
#include "../vpatterndb/vpiecenode.h"
|
|
|
|
#include "../vpatterndb/vpiecepath.h"
|
2016-01-09 17:16:03 +01:00
|
|
|
#include "../vgeometry/vsplinepath.h"
|
2017-02-06 16:19:59 +01:00
|
|
|
#include "../vmisc/vabstractapplication.h"
|
2016-01-09 17:16:03 +01:00
|
|
|
|
|
|
|
#include <QtTest>
|
2019-01-09 16:46:02 +01:00
|
|
|
#include "../vpatterndb/vpiece.h"
|
|
|
|
|
2016-01-09 17:16:03 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-01-22 14:29:23 +01:00
|
|
|
TST_VPiece::TST_VPiece(QObject *parent)
|
2016-01-09 17:16:03 +01:00
|
|
|
:AbstractTest(parent)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-02-06 16:19:59 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void TST_VPiece::Issue620()
|
|
|
|
{
|
|
|
|
// See file <root>/src/app/share/collection/bugs/Issue_#620.vit
|
|
|
|
// Check main path
|
|
|
|
const Unit unit = Unit::Cm;
|
2019-08-29 14:01:27 +02:00
|
|
|
QSharedPointer<VContainer> data(new VContainer(nullptr, &unit, VContainer::UniqueNamespace()));
|
2017-02-06 16:19:59 +01:00
|
|
|
qApp->setPatternUnit(unit);
|
|
|
|
|
|
|
|
VPiece detail;
|
2019-08-29 14:01:27 +02:00
|
|
|
AbstractTest::PieceFromJson(QStringLiteral("://Issue_620/input.json"), detail, data);
|
2017-02-06 16:19:59 +01:00
|
|
|
|
2017-04-19 11:48:13 +02:00
|
|
|
const QVector<QPointF> pointsEkv = detail.MainPathPoints(data.data());
|
2017-02-06 16:19:59 +01:00
|
|
|
|
|
|
|
QVector<QPointF> origPoints;
|
2019-08-29 14:01:27 +02:00
|
|
|
AbstractTest::VectorFromJson(QStringLiteral("://Issue_620/output.json"), origPoints);
|
2017-02-06 16:19:59 +01:00
|
|
|
|
|
|
|
// Begin comparison
|
|
|
|
Comparison(pointsEkv, origPoints);
|
|
|
|
}
|
2019-01-09 16:46:02 +01:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void TST_VPiece::TestSAPassmark_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<VPiecePassmarkData>("passmarkData");
|
|
|
|
QTest::addColumn<QVector<QPointF>>("seamAllowance");
|
|
|
|
QTest::addColumn<QVector<QLineF>>("expectedResult");
|
|
|
|
|
2019-09-05 13:13:22 +02:00
|
|
|
auto ASSERT_TEST_CASE = [this](const char *title, const QString &passmarkData, const QString &seamAllowance,
|
|
|
|
const QString &shape)
|
|
|
|
{
|
|
|
|
VPiecePassmarkData inputPassmarkData;
|
|
|
|
AbstractTest::PassmarkDataFromJson(passmarkData, inputPassmarkData);
|
2019-01-09 16:46:02 +01:00
|
|
|
|
2019-09-05 13:13:22 +02:00
|
|
|
QVector<QPointF> inputSeamAllowance;
|
|
|
|
AbstractTest::VectorFromJson(seamAllowance, inputSeamAllowance);
|
2019-01-09 16:46:02 +01:00
|
|
|
|
2019-09-05 13:13:22 +02:00
|
|
|
QVector<QLineF> inputOutputShape;
|
|
|
|
AbstractTest::PassmarkShapeFromJson(shape, inputOutputShape);
|
2019-01-09 16:46:02 +01:00
|
|
|
|
2019-09-05 13:13:22 +02:00
|
|
|
QTest::newRow(title) << inputPassmarkData << inputSeamAllowance << inputOutputShape;
|
|
|
|
};
|
2019-01-09 16:46:02 +01:00
|
|
|
|
|
|
|
// See file src/app/share/collection/bugs/Issue_#924.val
|
2019-09-05 13:13:22 +02:00
|
|
|
ASSERT_TEST_CASE("Test 1.",
|
|
|
|
QStringLiteral("://Issue_924_Test_1/passmarkData.json"),
|
|
|
|
QStringLiteral("://Issue_924_Test_1/seamAllowance.json"),
|
|
|
|
QStringLiteral("://Issue_924_Test_1/passmarkShape.json"));
|
2019-01-09 16:46:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void TST_VPiece::TestSAPassmark()
|
|
|
|
{
|
|
|
|
QFETCH(VPiecePassmarkData, passmarkData);
|
|
|
|
QFETCH(QVector<QPointF>, seamAllowance);
|
|
|
|
QFETCH(QVector<QLineF>, expectedResult);
|
|
|
|
|
2019-05-08 14:19:03 +02:00
|
|
|
VPassmark passmark(passmarkData);
|
|
|
|
|
|
|
|
Comparison(passmark.SAPassmark(seamAllowance, PassmarkSide::All), expectedResult);
|
2019-01-09 16:46:02 +01:00
|
|
|
}
|