ConfigModel: Don't try to resolve empty source path from package

ConfigModel may contain ConfigCategory for both QML pages and KCM pages.
The source property will be empty for KCM pages.  This fixes correctly
returning empty source for KCM pages.
Also return the same value from get().

REVIEW: 127702
This commit is contained in:
David Rosca 2016-05-04 17:33:18 +02:00
parent 18af870303
commit f336f80039
9 changed files with 225 additions and 7 deletions

View File

@ -28,7 +28,8 @@ MACRO(PLASMA_UNIT_TESTS)
KF5::I18n KF5::I18n
KF5::KIOCore KF5::KIOCore
KF5::Service KF5::Service
KF5::IconThemes) KF5::IconThemes
KF5::Declarative)
if(QT_QTOPENGL_FOUND) if(QT_QTOPENGL_FOUND)
target_link_libraries(${_testname} Qt5::OpenGL) target_link_libraries(${_testname} Qt5::OpenGL)
endif() endif()
@ -46,6 +47,7 @@ PLASMA_UNIT_TESTS(
framesvgtest framesvgtest
iconitemtest iconitemtest
themetest themetest
configmodeltest
# plasmoidpackagetest # plasmoidpackagetest
) )

View File

@ -0,0 +1,124 @@
/******************************************************************************
* Copyright 2016 David Rosca <nowrep@gmail.com> *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library 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 *
* Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public License *
* along with this library; see the file COPYING.LIB. If not, write to *
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, *
* Boston, MA 02110-1301, USA. *
*******************************************************************************/
#include "configmodeltest.h"
#include "plasma/applet.h"
#include "plasma/package.h"
#include "plasmaquick/configmodel.h"
#include "plasmaquick/private/configcategory_p.cpp"
#include <KConfigLoader>
#include <QQmlEngine>
#include <QQmlComponent>
void ConfigModelTest::configSchemeFromPackage()
{
Plasma::Applet *applet = Plasma::Applet::loadPlasmoid(QFINDTESTDATA("data/testconfigpackage"));
QCOMPARE(applet->configScheme()->groupList(), QStringList() << QStringLiteral("General"));
QCOMPARE(applet->configScheme()->findItemByName("testIntEntry")->property().toInt(), 23);
QCOMPARE(applet->configScheme()->findItemByName("testStringEntry")->property().toString(), QStringLiteral("string-value"));
qmlRegisterType<PlasmaQuick::ConfigModel>("org.kde.plasma.configuration", 2, 0, "ConfigModel");
qmlRegisterType<PlasmaQuick::ConfigCategory>("org.kde.plasma.configuration", 2, 0, "ConfigCategory");
QQmlEngine engine;
QQmlComponent *component = new QQmlComponent(&engine, QUrl::fromLocalFile(applet->package().filePath("configmodel")), this);
QObject *object = component->create(engine.rootContext());
PlasmaQuick::ConfigModel *configModel = qobject_cast<PlasmaQuick::ConfigModel *>(object);
QCOMPARE(configModel->rowCount(), 1);
QCOMPARE(configModel->get(0).toMap().value(QStringLiteral("name")).toString(), QStringLiteral("General"));
QCOMPARE(configModel->get(0).toMap().value(QStringLiteral("icon")).toString(), QStringLiteral("plasma"));
QCOMPARE(configModel->get(0).toMap().value(QStringLiteral("source")).toString(), QStringLiteral("ConfigGeneral.qml"));
QCOMPARE(configModel->get(0).toMap().value(QStringLiteral("pluginName")).toString(), QString());
QVERIFY(!configModel->get(0).toMap().value(QStringLiteral("kcm")).value<void*>());
delete component;
delete applet;
}
void ConfigModelTest::emptySourceWithApplet()
{
Plasma::Applet *applet = Plasma::Applet::loadPlasmoid(QFINDTESTDATA("data/testconfigpackage"));
PlasmaQuick::ConfigModel model;
model.appendCategory(QStringLiteral("plasma"), QStringLiteral("name"), QString(), QString());
QVERIFY(model.hasIndex(0, 0));
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toString(), QString());
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toString(), QString());
model.setApplet(applet);
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toString(), QString());
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toString(), QString());
delete applet;
}
void ConfigModelTest::notEmptySourceWithApplet()
{
const QString pkgPath = QFINDTESTDATA("data/testconfigpackage");
{
Plasma::Applet *applet = Plasma::Applet::loadPlasmoid(pkgPath);
PlasmaQuick::ConfigModel model;
// Relative source
model.appendCategory(QStringLiteral("plasma"), QStringLiteral("name"), QStringLiteral("ConfigGeneral.qml"), QString());
QVERIFY(model.hasIndex(0, 0));
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toString(), QStringLiteral("ConfigGeneral.qml"));
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toString(), QStringLiteral("ConfigGeneral.qml"));
model.setApplet(applet);
const QUrl fullPath = QUrl::fromLocalFile(pkgPath + QStringLiteral("/contents/ui/ConfigGeneral.qml"));
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toUrl(), fullPath);
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toUrl(), fullPath);
delete applet;
}
{
Plasma::Applet *applet = Plasma::Applet::loadPlasmoid(pkgPath);
PlasmaQuick::ConfigModel model;
// Absolute source
const QString source = QStringLiteral("/test/contents/ui/ConfigGeneral.qml");
model.appendCategory(QStringLiteral("plasma"), QStringLiteral("name"), source, QString());
QVERIFY(model.hasIndex(0, 0));
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toString(), source);
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toString(), source);
model.setApplet(applet);
QCOMPARE(model.data(model.index(0, 0), PlasmaQuick::ConfigModel::SourceRole).toString(), source);
QCOMPARE(model.get(0).toMap().value(QStringLiteral("source")).toString(), source);
delete applet;
}
}
QTEST_MAIN(ConfigModelTest)

View File

@ -0,0 +1,39 @@
/******************************************************************************
* Copyright 2016 David Rosca <nowrep@gmail.com> *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library 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 *
* Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public License *
* along with this library; see the file COPYING.LIB. If not, write to *
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, *
* Boston, MA 02110-1301, USA. *
*******************************************************************************/
#pragma once
#include <QtTest/QtTest>
namespace Plasma
{
class Applet;
}
class ConfigModelTest : public QObject
{
Q_OBJECT
private Q_SLOTS:
void configSchemeFromPackage();
void emptySourceWithApplet();
void notEmptySourceWithApplet();
};

View File

@ -0,0 +1,10 @@
import QtQuick 2.0
import org.kde.plasma.configuration 2.0
ConfigModel {
ConfigCategory {
name: "General"
icon: "plasma"
source: "ConfigGeneral.qml"
}
}

View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<kcfg xmlns="http://www.kde.org/standards/kcfg/1.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.kde.org/standards/kcfg/1.0
http://www.kde.org/standards/kcfg/1.0/kcfg.xsd" >
<kcfgfile name=""/>
<group name="General">
<entry name="testIntEntry" type="Int">
<default>23</default>
</entry>
<entry name="testStringEntry" type="String">
<default>string-value</default>
</entry>
</group>
</kcfg>

View File

@ -0,0 +1,7 @@
import QtQuick 2.0
Rectangle {
id: root
color: "darkblue"
}

View File

@ -0,0 +1,7 @@
import QtQuick 2.0
Rectangle {
id: root
color: "darkblue"
}

View File

@ -0,0 +1,16 @@
[Desktop Entry]
Encoding=UTF-8
Keywords=
Name=Config Test Package
Type=Service
X-KDE-ParentApp=
X-KDE-PluginInfo-Author=Joe Blow
X-KDE-PluginInfo-Category=
X-KDE-PluginInfo-Email=jblow@kde.org
X-KDE-PluginInfo-License=GPLv2+
X-KDE-PluginInfo-Name=org.kde.configtestpackage
X-KDE-PluginInfo-Version=
X-KDE-PluginInfo-Website=
X-Plasma-MainScript=ui/main.qml
X-Plasma-API=declarativeappletscript

View File

@ -149,11 +149,7 @@ QVariant ConfigModelPrivate::get(int row) const
value[QStringLiteral("name")] = categories.at(row)->name(); value[QStringLiteral("name")] = categories.at(row)->name();
value[QStringLiteral("icon")] = categories.at(row)->icon(); value[QStringLiteral("icon")] = categories.at(row)->icon();
value[QStringLiteral("pluginName")] = categories.at(row)->pluginName(); value[QStringLiteral("pluginName")] = categories.at(row)->pluginName();
if (appletInterface) { value[QStringLiteral("source")] = q->data(q->index(row, 0), ConfigModel::SourceRole);
value[QStringLiteral("source")] = QUrl::fromLocalFile(appletInterface.data()->package().filePath("ui", categories.at(row)->source()));
} else {
value[QStringLiteral("source")] = categories.at(row)->source();
}
value[QStringLiteral("visible")] = categories.at(row)->visible(); value[QStringLiteral("visible")] = categories.at(row)->visible();
value[QStringLiteral("kcm")] = q->data(q->index(row, 0), ConfigModel::KCMRole); value[QStringLiteral("kcm")] = q->data(q->index(row, 0), ConfigModel::KCMRole);
@ -202,7 +198,7 @@ QVariant ConfigModel::data(const QModelIndex &index, int role) const
{ {
const QString source = d->categories.at(index.row())->source(); const QString source = d->categories.at(index.row())->source();
// Quick check if source is an absolute path or not // Quick check if source is an absolute path or not
if (d->appletInterface && !(source.startsWith('/') && source.endsWith(QLatin1String("qml")))) { if (d->appletInterface && !source.isEmpty() && !(source.startsWith('/') && source.endsWith(QLatin1String("qml")))) {
return QUrl::fromLocalFile(d->appletInterface.data()->package().filePath("ui", source)); return QUrl::fromLocalFile(d->appletInterface.data()->package().filePath("ui", source));
} else { } else {
return source; return source;