mirror of
https://invent.kde.org/network/falkon.git
synced 2024-11-13 10:32:11 +01:00
Added qml tabs api tests and improved qmll tabs api
This commit is contained in:
parent
28f639a203
commit
a9a65be17a
|
@ -59,4 +59,5 @@ falkon_qml_tests(
|
||||||
qmlhistoryapitest
|
qmlhistoryapitest
|
||||||
qmlcookiesapitest
|
qmlcookiesapitest
|
||||||
qmlclipboardapitest
|
qmlclipboardapitest
|
||||||
|
qmltabsapitest
|
||||||
)
|
)
|
||||||
|
|
117
autotests/qml/qmltabsapitest.cpp
Normal file
117
autotests/qml/qmltabsapitest.cpp
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
/* ============================================================
|
||||||
|
* Falkon - Qt web browser
|
||||||
|
* Copyright (C) 2018 Anmol Gautam <tarptaeya@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 3 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, see <http://www.gnu.org/licenses/>.
|
||||||
|
* ============================================================ */
|
||||||
|
#include "qmltabsapitest.h"
|
||||||
|
#include "autotests.h"
|
||||||
|
#include "qmltesthelper.h"
|
||||||
|
#include "mainapplication.h"
|
||||||
|
#include "tabwidget.h"
|
||||||
|
|
||||||
|
void QmlTabsApiTest::initTestCase()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void QmlTabsApiTest::cleanupTestCase()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void QmlTabsApiTest::testInitWindowCount()
|
||||||
|
{
|
||||||
|
QCOMPARE(mApp->windowCount(), 1);
|
||||||
|
QCOMPARE(mApp->getWindow()->tabCount(), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void QmlTabsApiTest::testTabsAPI()
|
||||||
|
{
|
||||||
|
// Tab Insertion
|
||||||
|
QmlTestHelper qmlTest;
|
||||||
|
QObject *qmlTabsObject = qmlTest.evaluateQObject("Falkon.Tabs");
|
||||||
|
QVERIFY(qmlTabsObject);
|
||||||
|
QSignalSpy qmlTabsInsertedSpy(qmlTabsObject, SIGNAL(tabInserted(QVariantMap)));
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.addTab({"
|
||||||
|
" url: 'https://example.com/'"
|
||||||
|
"})");
|
||||||
|
QCOMPARE(qmlTabsInsertedSpy.count(), 1);
|
||||||
|
QVariantMap retMap1 = QVariant(qmlTabsInsertedSpy.at(0).at(0)).toMap();
|
||||||
|
int index1 = retMap1.value(QSL("index"), -1).toInt();
|
||||||
|
int windowId1 = retMap1.value(QSL("windowId"), -1).toInt();
|
||||||
|
QCOMPARE(index1, 0);
|
||||||
|
QCOMPARE(windowId1, 0);
|
||||||
|
|
||||||
|
QObject *qmlTabObject1 = qmlTest.evaluateQObject("Falkon.Tabs.get({index: 0})");
|
||||||
|
QVERIFY(qmlTabObject1);
|
||||||
|
QCOMPARE(qmlTabObject1->property("url").toString(), "https://example.com/");
|
||||||
|
QCOMPARE(qmlTabObject1->property("index").toInt(), 0);
|
||||||
|
QCOMPARE(qmlTabObject1->property("pinned").toBool(), false);
|
||||||
|
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.addTab({"
|
||||||
|
" url: 'https://another-example.com/',"
|
||||||
|
"})");
|
||||||
|
QCOMPARE(qmlTabsInsertedSpy.count(), 2);
|
||||||
|
QVariantMap retMap2 = QVariant(qmlTabsInsertedSpy.at(1).at(0)).toMap();
|
||||||
|
int index2 = retMap2.value(QSL("index"), -1).toInt();
|
||||||
|
int windowId2 = retMap2.value(QSL("windowId"), -1).toInt();
|
||||||
|
QCOMPARE(index2, 1);
|
||||||
|
QCOMPARE(windowId2, 0);
|
||||||
|
|
||||||
|
bool pinnedTab = qmlTest.evaluate("Falkon.Tabs.pinTab({index: 1})").toBool();
|
||||||
|
QVERIFY(pinnedTab);
|
||||||
|
QObject *qmlTabObject2 = qmlTest.evaluateQObject("Falkon.Tabs.get({index: 0})");
|
||||||
|
QVERIFY(qmlTabObject2);
|
||||||
|
QCOMPARE(qmlTabObject2->property("url").toString(), "https://another-example.com/");
|
||||||
|
QCOMPARE(qmlTabObject2->property("index").toInt(), 0);
|
||||||
|
QCOMPARE(qmlTabObject2->property("pinned").toBool(), true);
|
||||||
|
|
||||||
|
bool unpinnedTab = qmlTest.evaluate("Falkon.Tabs.unpinTab({index: 0})").toBool();
|
||||||
|
QVERIFY(unpinnedTab);
|
||||||
|
QObject *qmlTabObject3 = qmlTest.evaluateQObject("Falkon.Tabs.get({index: 0})");
|
||||||
|
QVERIFY(qmlTabObject3);
|
||||||
|
QCOMPARE(qmlTabObject3->property("url").toString(), "https://another-example.com/");
|
||||||
|
QCOMPARE(qmlTabObject3->property("index").toInt(), 0);
|
||||||
|
QCOMPARE(qmlTabObject3->property("pinned").toBool(), false);
|
||||||
|
|
||||||
|
// TODO: when the windowId is different from current window
|
||||||
|
|
||||||
|
// Next-Previous-Current
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 0);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.nextTab()");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 1);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.nextTab()");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 0);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.previousTab()");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 1);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.previousTab()");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 0);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.setCurrentIndex({index: 1})");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 1);
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.setCurrentIndex({index: 0})");
|
||||||
|
QCOMPARE(mApp->getWindow()->tabWidget()->currentIndex(), 0);
|
||||||
|
|
||||||
|
// Move Tab
|
||||||
|
QSignalSpy qmlTabsMovedSpy(qmlTabsObject, SIGNAL(tabMoved(QVariantMap)));
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.moveTab({from: 0, to:1})");
|
||||||
|
QCOMPARE(qmlTabsMovedSpy.count(), 1);
|
||||||
|
|
||||||
|
// Tab Removal
|
||||||
|
QCOMPARE(mApp->getWindow()->tabCount(), 2);
|
||||||
|
QSignalSpy qmlTabsRemovedSpy(qmlTabsObject, SIGNAL(tabRemoved(QVariantMap)));
|
||||||
|
qmlTest.evaluate("Falkon.Tabs.closeTab({index: 0})");
|
||||||
|
QCOMPARE(qmlTabsRemovedSpy.count(), 1);
|
||||||
|
QCOMPARE(mApp->getWindow()->tabCount(), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
FALKONTEST_MAIN(QmlTabsApiTest)
|
32
autotests/qml/qmltabsapitest.h
Normal file
32
autotests/qml/qmltabsapitest.h
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
/* ============================================================
|
||||||
|
* Falkon - Qt web browser
|
||||||
|
* Copyright (C) 2018 Anmol Gautam <tarptaeya@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 3 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, see <http://www.gnu.org/licenses/>.
|
||||||
|
* ============================================================ */
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
|
||||||
|
class QmlTabsApiTest : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
private Q_SLOTS:
|
||||||
|
void initTestCase();
|
||||||
|
void cleanupTestCase();
|
||||||
|
|
||||||
|
void testInitWindowCount();
|
||||||
|
void testTabsAPI();
|
||||||
|
};
|
|
@ -22,35 +22,11 @@
|
||||||
QmlTabs::QmlTabs(QObject *parent)
|
QmlTabs::QmlTabs(QObject *parent)
|
||||||
: QObject(parent)
|
: QObject(parent)
|
||||||
{
|
{
|
||||||
connect(mApp->plugins(), &PluginProxy::mainWindowCreated, this, [this](BrowserWindow *window){
|
for (BrowserWindow *window : mApp->windows()) {
|
||||||
// FIXME: make it more efficient
|
windowCreated(window);
|
||||||
for (int i = 0; i < mApp->windowCount(); i++) {
|
}
|
||||||
windowIdHash[mApp->windows().at(i)] = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
connect(window->tabWidget(), &TabWidget::changed, this, [this, window]{
|
connect(mApp->plugins(), &PluginProxy::mainWindowCreated, this, &QmlTabs::windowCreated);
|
||||||
QVariantMap map;
|
|
||||||
int windowId = windowIdHash.value(window);
|
|
||||||
map.insert(QSL("windowId"), windowId);
|
|
||||||
emit changed(map);
|
|
||||||
});
|
|
||||||
|
|
||||||
connect(window->tabWidget(), &TabWidget::tabInserted, this, [this, window](int index){
|
|
||||||
QVariantMap map;
|
|
||||||
int windowId = windowIdHash.value(window);
|
|
||||||
map.insert(QSL("windowId"), windowId);
|
|
||||||
map.insert(QSL("index"), index);
|
|
||||||
emit tabInserted(map);
|
|
||||||
});
|
|
||||||
|
|
||||||
connect(window->tabWidget(), &TabWidget::tabRemoved, this, [this, window](int index){
|
|
||||||
QVariantMap map;
|
|
||||||
int windowId = windowIdHash.value(window);
|
|
||||||
map.insert(QSL("windowId"), windowId);
|
|
||||||
map.insert(QSL("index"), index);
|
|
||||||
emit tabRemoved(map);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
connect(mApp->plugins(), &PluginProxy::mainWindowDeleted, this, [this](BrowserWindow *window){
|
connect(mApp->plugins(), &PluginProxy::mainWindowDeleted, this, [this](BrowserWindow *window){
|
||||||
// FIXME: make it more efficient
|
// FIXME: make it more efficient
|
||||||
|
@ -143,11 +119,13 @@ bool QmlTabs::pinTab(const QVariantMap &map)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (window->tabWidget()->webTab(index)->isPinned()) {
|
WebTab *webTab = window->tabWidget()->webTab(index);
|
||||||
|
|
||||||
|
if (webTab->isPinned()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
window->tabWidget()->pinUnPinTab(index);
|
webTab->togglePinned();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,11 +143,13 @@ bool QmlTabs::unpinTab(const QVariantMap &map)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!window->tabWidget()->webTab(index)->isPinned()) {
|
WebTab *webTab = window->tabWidget()->webTab(index);
|
||||||
|
|
||||||
|
if (!webTab->isPinned()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
window->tabWidget()->pinUnPinTab(index);
|
webTab->togglePinned();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -360,3 +340,43 @@ BrowserWindow *QmlTabs::getWindow(const QVariantMap &map) const
|
||||||
|
|
||||||
return window;
|
return window;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QmlTabs::windowCreated(BrowserWindow *window)
|
||||||
|
{
|
||||||
|
// FIXME: make it more efficient
|
||||||
|
for (int i = 0; i < mApp->windowCount(); i++) {
|
||||||
|
windowIdHash[mApp->windows().at(i)] = i;
|
||||||
|
}
|
||||||
|
|
||||||
|
connect(window->tabWidget(), &TabWidget::changed, this, [this, window]{
|
||||||
|
QVariantMap map;
|
||||||
|
int windowId = windowIdHash.value(window);
|
||||||
|
map.insert(QSL("windowId"), windowId);
|
||||||
|
emit changed(map);
|
||||||
|
});
|
||||||
|
|
||||||
|
connect(window->tabWidget(), &TabWidget::tabInserted, this, [this, window](int index){
|
||||||
|
QVariantMap map;
|
||||||
|
int windowId = windowIdHash.value(window);
|
||||||
|
map.insert(QSL("windowId"), windowId);
|
||||||
|
map.insert(QSL("index"), index);
|
||||||
|
emit tabInserted(map);
|
||||||
|
});
|
||||||
|
|
||||||
|
connect(window->tabWidget(), &TabWidget::tabRemoved, this, [this, window](int index){
|
||||||
|
QVariantMap map;
|
||||||
|
int windowId = windowIdHash.value(window);
|
||||||
|
map.insert(QSL("windowId"), windowId);
|
||||||
|
map.insert(QSL("index"), index);
|
||||||
|
emit tabRemoved(map);
|
||||||
|
});
|
||||||
|
|
||||||
|
connect(window->tabWidget(), &TabWidget::tabMoved, this, [this, window](int from, int to){
|
||||||
|
QVariantMap map;
|
||||||
|
int windowId = windowIdHash.value(window);
|
||||||
|
map.insert(QSL("windowId"), windowId);
|
||||||
|
map.insert(QSL("from"), from);
|
||||||
|
map.insert(QSL("to"), to);
|
||||||
|
emit tabMoved(map);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
|
@ -47,7 +47,9 @@ Q_SIGNALS:
|
||||||
void changed(const QVariantMap &map);
|
void changed(const QVariantMap &map);
|
||||||
void tabInserted(const QVariantMap &map);
|
void tabInserted(const QVariantMap &map);
|
||||||
void tabRemoved(const QVariantMap &map);
|
void tabRemoved(const QVariantMap &map);
|
||||||
|
void tabMoved(const QVariantMap &map);
|
||||||
private:
|
private:
|
||||||
BrowserWindow *getWindow(const QVariantMap &map) const;
|
BrowserWindow *getWindow(const QVariantMap &map) const;
|
||||||
|
void windowCreated(BrowserWindow *window);
|
||||||
QHash<BrowserWindow*, int> windowIdHash;
|
QHash<BrowserWindow*, int> windowIdHash;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue
Block a user