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:
Christian Stenger
2020-08-14 15:02:46 +02:00
parent 2ac60ac66e
commit e9c27cca34
9 changed files with 126 additions and 2 deletions

View File

@@ -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();

View File

@@ -297,7 +297,7 @@ public:
void saveGeometry()
{
SessionManager::setValue("DebuggerSeparateWidgetGeometry", geometry());
SessionManager::setValue("DebuggerSeparateWidgetGeometry", QVariant(geometry()));
}
~SeparatedView() override

View File

@@ -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)

View File

@@ -0,0 +1,4 @@
add_qtc_test(tst_utils_persistentsettings
DEPENDS Utils
SOURCES tst_persistentsettings.cpp
)

View File

@@ -0,0 +1,4 @@
QTC_LIB_DEPENDS += utils
include(../../qttest.pri)
SOURCES += tst_persistentsettings.cpp

View File

@@ -0,0 +1,7 @@
import qbs
QtcAutotest {
name: "PersistentSettings autotest"
Depends { name: "Utils" }
files: "tst_persistentsettings.cpp"
}

View 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"

View File

@@ -4,6 +4,7 @@ SUBDIRS = \
fileutils \
ansiescapecodehandler \
fuzzymatcher \
persistentsettings \
settings \
stringutils \
templateengine \

View File

@@ -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",