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;
|
QString result;
|
||||||
QTextStream str(&result);
|
QTextStream str(&result);
|
||||||
str << r.width() << 'x' << r.height() << r.x() << r.y();
|
str << r.width() << 'x' << r.height();
|
||||||
if (r.x() >= 0)
|
if (r.x() >= 0)
|
||||||
str << '+';
|
str << '+';
|
||||||
str << r.x();
|
str << r.x();
|
||||||
|
@@ -297,7 +297,7 @@ public:
|
|||||||
|
|
||||||
void saveGeometry()
|
void saveGeometry()
|
||||||
{
|
{
|
||||||
SessionManager::setValue("DebuggerSeparateWidgetGeometry", geometry());
|
SessionManager::setValue("DebuggerSeparateWidgetGeometry", QVariant(geometry()));
|
||||||
}
|
}
|
||||||
|
|
||||||
~SeparatedView() override
|
~SeparatedView() override
|
||||||
|
@@ -1,6 +1,7 @@
|
|||||||
add_subdirectory(ansiescapecodehandler)
|
add_subdirectory(ansiescapecodehandler)
|
||||||
add_subdirectory(fileutils)
|
add_subdirectory(fileutils)
|
||||||
add_subdirectory(fuzzymatcher)
|
add_subdirectory(fuzzymatcher)
|
||||||
|
add_subdirectory(persistentsettings)
|
||||||
add_subdirectory(settings)
|
add_subdirectory(settings)
|
||||||
add_subdirectory(stringutils)
|
add_subdirectory(stringutils)
|
||||||
add_subdirectory(templateengine)
|
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 \
|
fileutils \
|
||||||
ansiescapecodehandler \
|
ansiescapecodehandler \
|
||||||
fuzzymatcher \
|
fuzzymatcher \
|
||||||
|
persistentsettings \
|
||||||
settings \
|
settings \
|
||||||
stringutils \
|
stringutils \
|
||||||
templateengine \
|
templateengine \
|
||||||
|
@@ -6,6 +6,7 @@ Project {
|
|||||||
"fileutils/fileutils.qbs",
|
"fileutils/fileutils.qbs",
|
||||||
"ansiescapecodehandler/ansiescapecodehandler.qbs",
|
"ansiescapecodehandler/ansiescapecodehandler.qbs",
|
||||||
"fuzzymatcher/fuzzymatcher.qbs",
|
"fuzzymatcher/fuzzymatcher.qbs",
|
||||||
|
"persistentsettings/persistentsettings.qbs",
|
||||||
"settings/settings.qbs",
|
"settings/settings.qbs",
|
||||||
"stringutils/stringutils.qbs",
|
"stringutils/stringutils.qbs",
|
||||||
"templateengine/templateengine.qbs",
|
"templateengine/templateengine.qbs",
|
||||||
|
Reference in New Issue
Block a user