forked from qt-creator/qt-creator
Utils: Fix persisting of QRect
And pass explicitly a QVariant to the writer to avoid unexpected behavior when trying to store the geometry of a widget. This resulted in a warning for any session where the user had used the debugger at least once. Change-Id: I5cb2352ab29ff7d2a64c84ffcdf040efe6d04b94 Reviewed-by: Eike Ziller <eike.ziller@qt.io> Reviewed-by: hjk <hjk@qt.io>
This commit is contained in:
@@ -47,7 +47,7 @@ static QString rectangleToString(const QRect &r)
|
||||
{
|
||||
QString result;
|
||||
QTextStream str(&result);
|
||||
str << r.width() << 'x' << r.height() << r.x() << r.y();
|
||||
str << r.width() << 'x' << r.height();
|
||||
if (r.x() >= 0)
|
||||
str << '+';
|
||||
str << r.x();
|
||||
|
@@ -297,7 +297,7 @@ public:
|
||||
|
||||
void saveGeometry()
|
||||
{
|
||||
SessionManager::setValue("DebuggerSeparateWidgetGeometry", geometry());
|
||||
SessionManager::setValue("DebuggerSeparateWidgetGeometry", QVariant(geometry()));
|
||||
}
|
||||
|
||||
~SeparatedView() override
|
||||
|
@@ -1,6 +1,7 @@
|
||||
add_subdirectory(ansiescapecodehandler)
|
||||
add_subdirectory(fileutils)
|
||||
add_subdirectory(fuzzymatcher)
|
||||
add_subdirectory(persistentsettings)
|
||||
add_subdirectory(settings)
|
||||
add_subdirectory(stringutils)
|
||||
add_subdirectory(templateengine)
|
||||
|
4
tests/auto/utils/persistentsettings/CMakeLists.txt
Normal file
4
tests/auto/utils/persistentsettings/CMakeLists.txt
Normal file
@@ -0,0 +1,4 @@
|
||||
add_qtc_test(tst_utils_persistentsettings
|
||||
DEPENDS Utils
|
||||
SOURCES tst_persistentsettings.cpp
|
||||
)
|
@@ -0,0 +1,4 @@
|
||||
QTC_LIB_DEPENDS += utils
|
||||
include(../../qttest.pri)
|
||||
|
||||
SOURCES += tst_persistentsettings.cpp
|
@@ -0,0 +1,7 @@
|
||||
import qbs
|
||||
|
||||
QtcAutotest {
|
||||
name: "PersistentSettings autotest"
|
||||
Depends { name: "Utils" }
|
||||
files: "tst_persistentsettings.cpp"
|
||||
}
|
106
tests/auto/utils/persistentsettings/tst_persistentsettings.cpp
Normal file
106
tests/auto/utils/persistentsettings/tst_persistentsettings.cpp
Normal file
@@ -0,0 +1,106 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2020 The Qt Company Ltd.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** This file is part of Qt Creator.
|
||||
**
|
||||
** Commercial License Usage
|
||||
** Licensees holding valid commercial Qt licenses may use this file in
|
||||
** accordance with the commercial license agreement provided with the
|
||||
** Software or, alternatively, in accordance with the terms contained in
|
||||
** a written agreement between you and The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#include <utils/persistentsettings.h>
|
||||
|
||||
#include <QTemporaryDir>
|
||||
|
||||
#include <QtTest>
|
||||
|
||||
using namespace Utils;
|
||||
|
||||
class PersistentSettingsTest : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
PersistentSettingsTest() = default;
|
||||
|
||||
private slots:
|
||||
void tst_readwrite();
|
||||
};
|
||||
|
||||
static const QVariantMap generateData()
|
||||
{
|
||||
QVariantMap result;
|
||||
QByteArray barr("I am a byte array.");
|
||||
QString str("I am a string.");
|
||||
QColor color("#8b00d1");
|
||||
QRect rect(0, 0, 400, 600);
|
||||
QRect rect2(10, 10, 40, 40);
|
||||
QVariantList varList{barr, color, rect2};
|
||||
result.insert("barr", barr);
|
||||
result.insert("str", str);
|
||||
result.insert("color", color);
|
||||
result.insert("rect", rect);
|
||||
result.insert("varList", varList);
|
||||
return result;
|
||||
}
|
||||
|
||||
void PersistentSettingsTest::tst_readwrite()
|
||||
{
|
||||
QTemporaryDir tmpDir("qtc_test_persistentXXXXXX");
|
||||
tmpDir.setAutoRemove(false);
|
||||
const QFileInfo fi(QDir(tmpDir.path()), "settings.xml");
|
||||
qDebug() << "using" << fi.absoluteFilePath();
|
||||
const FilePath filePath = FilePath::fromFileInfo(fi);
|
||||
PersistentSettingsWriter writer(filePath, "Narf");
|
||||
const QVariantMap originalData = generateData();
|
||||
QString error;
|
||||
bool success = writer.save(originalData, &error);
|
||||
QVERIFY2(success, error.toLocal8Bit());
|
||||
|
||||
// verify written data
|
||||
PersistentSettingsReader reader;
|
||||
success = reader.load(filePath);
|
||||
QVERIFY(success);
|
||||
|
||||
const QVariantMap restored = reader.restoreValues();
|
||||
QCOMPARE(restored.size(), originalData.size());
|
||||
auto restoredEnd = restored.end();
|
||||
for (auto it = originalData.cbegin(), end = originalData.cend(); it != end; ++it) {
|
||||
auto found = restored.find(it.key());
|
||||
QVERIFY(found != restoredEnd);
|
||||
QVERIFY(found.value().isValid());
|
||||
if (it.value().type() == QVariant::List) {
|
||||
const QVariantList origList = it.value().toList();
|
||||
const QVariantList foundList = found.value().toList();
|
||||
|
||||
QCOMPARE(foundList.size(), origList.size());
|
||||
for (int i = 0, vEnd = foundList.size(); i < vEnd; ++i) {
|
||||
if (foundList.at(i).type() == QVariant::Rect)
|
||||
qDebug() << foundList.at(i).toRect() << origList.at(i).toRect();
|
||||
QCOMPARE(foundList.at(i), origList.at(i));
|
||||
}
|
||||
}
|
||||
if (it.value().type() == QVariant::Rect)
|
||||
qDebug() << found.value().toRect() << "vs" << it.value().toRect();
|
||||
QCOMPARE(found.value(), it.value());
|
||||
}
|
||||
tmpDir.setAutoRemove(!QTest::currentTestFailed());
|
||||
}
|
||||
|
||||
QTEST_MAIN(PersistentSettingsTest)
|
||||
|
||||
#include "tst_persistentsettings.moc"
|
@@ -4,6 +4,7 @@ SUBDIRS = \
|
||||
fileutils \
|
||||
ansiescapecodehandler \
|
||||
fuzzymatcher \
|
||||
persistentsettings \
|
||||
settings \
|
||||
stringutils \
|
||||
templateengine \
|
||||
|
@@ -6,6 +6,7 @@ Project {
|
||||
"fileutils/fileutils.qbs",
|
||||
"ansiescapecodehandler/ansiescapecodehandler.qbs",
|
||||
"fuzzymatcher/fuzzymatcher.qbs",
|
||||
"persistentsettings/persistentsettings.qbs",
|
||||
"settings/settings.qbs",
|
||||
"stringutils/stringutils.qbs",
|
||||
"templateengine/templateengine.qbs",
|
||||
|
Reference in New Issue
Block a user