kde4_add_unit_test(kstandarditemmodeltest TEST ${kstandarditemmodeltest_SRCS})
target_link_libraries(kstandarditemmodeltest dolphinprivate ${KDE4_KIO_LIBS} ${QT_QTTEST_LIBRARY})
+# ViewPropertiesTest
+set(viewpropertiestest_SRCS
+ viewpropertiestest.cpp
+ testdir.cpp
+ ../views/viewproperties.cpp
+)
+kde4_add_kcfg_files(viewpropertiestest_SRCS
+ ../settings/dolphin_generalsettings.kcfgc
+ ../settings/dolphin_directoryviewpropertysettings.kcfgc
+)
+kde4_add_unit_test(viewpropertiestest TEST ${viewpropertiestest_SRCS})
+target_link_libraries(viewpropertiestest dolphinprivate ${KDE4_KIO_LIBS} ${QT_QTTEST_LIBRARY})
#include <sys/utime.h>
#endif
-TestDir::TestDir()
+TestDir::TestDir(const QString& directoryPrefix) :
+ KTempDir(directoryPrefix)
{
}
{
public:
- TestDir();
+ TestDir(const QString& directoryPrefix = QString());
virtual ~TestDir();
KUrl url() const;
--- /dev/null
+/***************************************************************************
+ * Copyright (C) 2012 by Peter Penz <peter.penz19@gmail.com> *
+ * *
+ * This program 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 2 of the License, or *
+ * (at your option) any later version. *
+ * *
+ * This program 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 this program; if not, write to the *
+ * Free Software Foundation, Inc., *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
+ ***************************************************************************/
+
+#include <qtest_kde.h>
+
+#include "dolphin_generalsettings.h"
+#include "views/viewproperties.h"
+#include "testdir.h"
+
+#include <QDebug>
+#include <QDir>
+
+class ViewPropertiesTest : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void init();
+ void cleanup();
+
+ void testReadOnlyBehavior();
+ void testAutoSave();
+
+private:
+ bool m_globalViewProps;
+ TestDir* m_testDir;
+};
+
+void ViewPropertiesTest::init()
+{
+ m_globalViewProps = GeneralSettings::self()->globalViewProps();
+ GeneralSettings::self()->setGlobalViewProps(false);
+
+ // It is mandatory to create the test-directory inside the home-directory
+ // of the user: ViewProperties does not write inside directories
+ // outside the home-directory to prevent overwriting other user-settings
+ // in case if write-permissions are given.
+ m_testDir = new TestDir(QDir::homePath() + "/.viewPropertiesTest-");
+}
+
+void ViewPropertiesTest::cleanup()
+{
+ delete m_testDir;
+ m_testDir = 0;
+
+ GeneralSettings::self()->setGlobalViewProps(m_globalViewProps);
+}
+
+/**
+ * Test whether only reading properties won't result in creating
+ * a .directory file when destructing the ViewProperties instance
+ * and autosaving is enabled.
+ */
+void ViewPropertiesTest::testReadOnlyBehavior()
+{
+ QString dotDirectoryFile = m_testDir->url().toLocalFile() + ".directory";
+ QVERIFY(!QFile::exists(dotDirectoryFile));
+
+ ViewProperties* props = new ViewProperties(m_testDir->url());
+ QVERIFY(props->isAutoSaveEnabled());
+ const QByteArray sortRole = props->sortRole();
+ Q_UNUSED(sortRole);
+ delete props;
+ props = 0;
+
+ QVERIFY(!QFile::exists(dotDirectoryFile));
+}
+
+void ViewPropertiesTest::testAutoSave()
+{
+ QString dotDirectoryFile = m_testDir->url().toLocalFile() + ".directory";
+ QVERIFY(!QFile::exists(dotDirectoryFile));
+
+ ViewProperties* props = new ViewProperties(m_testDir->url());
+ QVERIFY(props->isAutoSaveEnabled());
+ props->setSortRole("someNewSortRole");
+ delete props;
+ props = 0;
+
+ QVERIFY(QFile::exists(dotDirectoryFile));
+}
+
+QTEST_KDEMAIN(ViewPropertiesTest, NoGUI)
+
+#include "viewpropertiestest.moc"
m_changedProps = false;
}
}
+
+ if (m_node->version() < CurrentViewPropertiesVersion) {
+ // The view-properties have an outdated version. Convert the properties
+ // to the changes of the current version.
+ if (m_node->version() < AdditionalInfoViewPropertiesVersion) {
+ convertAdditionalInfo();
+ Q_ASSERT(m_node->version() == AdditionalInfoViewPropertiesVersion);
+ }
+
+ if (m_node->version() < NameRolePropertiesVersion) {
+ convertNameRoleToTextRole();
+ Q_ASSERT(m_node->version() == NameRolePropertiesVersion);
+ }
+
+ m_node->setVersion(CurrentViewPropertiesVersion);
+ }
}
ViewProperties::~ViewProperties()
QByteArray ViewProperties::sortRole() const
{
- if (m_node->version() <= NameRolePropertiesVersion) {
- const_cast<ViewProperties*>(this)->convertNameRoleToTextRole();
- }
-
return m_node->sortRole().toLatin1();
}
void ViewProperties::setVisibleRoles(const QList<QByteArray>& roles)
{
+ if (roles == visibleRoles()) {
+ return;
+ }
+
// See ViewProperties::visibleRoles() for the storage format
// of the additional information.
const QString prefix = viewModePrefix();
const int prefixLength = prefix.length();
- QStringList visibleRoles = m_node->visibleRoles();
- const int version = m_node->version();
- if (visibleRoles.isEmpty() && version <= AdditionalInfoViewPropertiesVersion) {
- // Convert the obsolete additionalInfo-property from older versions into the
- // visibleRoles-property
- const_cast<ViewProperties*>(this)->convertAdditionalInfo();
- visibleRoles = m_node->visibleRoles();
- } else if (version <= NameRolePropertiesVersion) {
- const_cast<ViewProperties*>(this)->convertNameRoleToTextRole();
- visibleRoles = m_node->visibleRoles();
- }
-
+ const QStringList visibleRoles = m_node->visibleRoles();
foreach (const QString& visibleRole, visibleRoles) {
if (visibleRole.startsWith(prefix)) {
const QByteArray role = visibleRole.right(visibleRole.length() - prefixLength).toLatin1();
setSortFoldersFirst(props.sortFoldersFirst());
setVisibleRoles(props.visibleRoles());
setHeaderColumnWidths(props.headerColumnWidths());
+ m_node->setVersion(props.m_node->version());
}
void ViewProperties::setAutoSaveEnabled(bool autoSave)
void ViewProperties::save()
{
+ kDebug() << "Saving view-properties to" << m_filePath;
KStandardDirs::makeDir(m_filePath);
m_node->setVersion(CurrentViewPropertiesVersion);
m_node->writeConfig();
m_node->setAdditionalInfo(QStringList());
m_node->setVisibleRoles(visibleRoles);
+ m_node->setVersion(AdditionalInfoViewPropertiesVersion);
update();
}
m_node->setVisibleRoles(visibleRoles);
m_node->setSortRole(sortRole);
+ m_node->setVersion(NameRolePropertiesVersion);
update();
}