Ensure panel, desktop and onscreendisplay windows cannot be moved/resized
Summary: A user shouldn't be able to manually move/resize a desktop window or a panel. So far this wasn't ensured. Reviewers: #plasma Subscribers: plasma-devel Projects: #plasma Differential Revision: https://phabricator.kde.org/D1155
This commit is contained in:
parent
f9da3fb0eb
commit
23c505d71e
2 changed files with 63 additions and 0 deletions
|
@ -32,6 +32,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#include <KWayland/Client/compositor.h>
|
#include <KWayland/Client/compositor.h>
|
||||||
#include <KWayland/Client/event_queue.h>
|
#include <KWayland/Client/event_queue.h>
|
||||||
#include <KWayland/Client/registry.h>
|
#include <KWayland/Client/registry.h>
|
||||||
|
#include <KWayland/Client/plasmashell.h>
|
||||||
#include <KWayland/Client/shell.h>
|
#include <KWayland/Client/shell.h>
|
||||||
#include <KWayland/Client/shm_pool.h>
|
#include <KWayland/Client/shm_pool.h>
|
||||||
#include <KWayland/Client/surface.h>
|
#include <KWayland/Client/surface.h>
|
||||||
|
@ -62,12 +63,15 @@ private Q_SLOTS:
|
||||||
void testGrowShrink();
|
void testGrowShrink();
|
||||||
void testPointerMoveEnd_data();
|
void testPointerMoveEnd_data();
|
||||||
void testPointerMoveEnd();
|
void testPointerMoveEnd();
|
||||||
|
void testPlasmaShellSurfaceMovable_data();
|
||||||
|
void testPlasmaShellSurfaceMovable();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
KWayland::Client::ConnectionThread *m_connection = nullptr;
|
KWayland::Client::ConnectionThread *m_connection = nullptr;
|
||||||
KWayland::Client::Compositor *m_compositor = nullptr;
|
KWayland::Client::Compositor *m_compositor = nullptr;
|
||||||
KWayland::Client::ShmPool *m_shm = nullptr;
|
KWayland::Client::ShmPool *m_shm = nullptr;
|
||||||
KWayland::Client::Shell *m_shell = nullptr;
|
KWayland::Client::Shell *m_shell = nullptr;
|
||||||
|
KWayland::Client::PlasmaShell *m_plasmaShell = nullptr;
|
||||||
KWayland::Client::EventQueue *m_queue = nullptr;
|
KWayland::Client::EventQueue *m_queue = nullptr;
|
||||||
QThread *m_thread = nullptr;
|
QThread *m_thread = nullptr;
|
||||||
};
|
};
|
||||||
|
@ -132,6 +136,8 @@ void MoveResizeWindowTest::init()
|
||||||
QVERIFY(m_shm->isValid());
|
QVERIFY(m_shm->isValid());
|
||||||
m_shell = registry.createShell(shellSpy.first().first().value<quint32>(), shellSpy.first().last().value<quint32>(), this);
|
m_shell = registry.createShell(shellSpy.first().first().value<quint32>(), shellSpy.first().last().value<quint32>(), this);
|
||||||
QVERIFY(m_shell->isValid());
|
QVERIFY(m_shell->isValid());
|
||||||
|
m_plasmaShell = registry.createPlasmaShell(registry.interface(Registry::Interface::PlasmaShell).name, registry.interface(Registry::Interface::PlasmaShell).version, this);
|
||||||
|
QVERIFY(m_plasmaShell->isValid());
|
||||||
|
|
||||||
screens()->setCurrent(0);
|
screens()->setCurrent(0);
|
||||||
}
|
}
|
||||||
|
@ -144,6 +150,8 @@ void MoveResizeWindowTest::cleanup()
|
||||||
m_shm = nullptr;
|
m_shm = nullptr;
|
||||||
delete m_shell;
|
delete m_shell;
|
||||||
m_shell = nullptr;
|
m_shell = nullptr;
|
||||||
|
delete m_plasmaShell;
|
||||||
|
m_plasmaShell = nullptr;
|
||||||
delete m_queue;
|
delete m_queue;
|
||||||
m_queue = nullptr;
|
m_queue = nullptr;
|
||||||
if (m_thread) {
|
if (m_thread) {
|
||||||
|
@ -517,6 +525,52 @@ void MoveResizeWindowTest::testPointerMoveEnd()
|
||||||
QVERIFY(!c->isMove());
|
QVERIFY(!c->isMove());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MoveResizeWindowTest::testPlasmaShellSurfaceMovable_data()
|
||||||
|
{
|
||||||
|
QTest::addColumn<KWayland::Client::PlasmaShellSurface::Role>("role");
|
||||||
|
QTest::addColumn<bool>("movable");
|
||||||
|
QTest::addColumn<bool>("movableAcrossScreens");
|
||||||
|
QTest::addColumn<bool>("resizable");
|
||||||
|
|
||||||
|
QTest::newRow("normal") << KWayland::Client::PlasmaShellSurface::Role::Normal << true << true << true;
|
||||||
|
QTest::newRow("desktop") << KWayland::Client::PlasmaShellSurface::Role::Desktop << false << false << false;
|
||||||
|
QTest::newRow("panel") << KWayland::Client::PlasmaShellSurface::Role::Panel << false << false << false;
|
||||||
|
QTest::newRow("osd") << KWayland::Client::PlasmaShellSurface::Role::OnScreenDisplay << false << false << false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MoveResizeWindowTest::testPlasmaShellSurfaceMovable()
|
||||||
|
{
|
||||||
|
// this test verifies that certain window types from PlasmaShellSurface are not moveable or resizable
|
||||||
|
using namespace KWayland::Client;
|
||||||
|
QSignalSpy clientAddedSpy(waylandServer(), &WaylandServer::shellClientAdded);
|
||||||
|
QVERIFY(clientAddedSpy.isValid());
|
||||||
|
|
||||||
|
QScopedPointer<Surface> surface(m_compositor->createSurface());
|
||||||
|
QVERIFY(!surface.isNull());
|
||||||
|
|
||||||
|
QScopedPointer<ShellSurface> shellSurface(m_shell->createSurface(surface.data()));
|
||||||
|
QVERIFY(!shellSurface.isNull());
|
||||||
|
// and a PlasmaShellSurface
|
||||||
|
QScopedPointer<PlasmaShellSurface> plasmaSurface(m_plasmaShell->createSurface(surface.data()));
|
||||||
|
QVERIFY(!plasmaSurface.isNull());
|
||||||
|
QFETCH(KWayland::Client::PlasmaShellSurface::Role, role);
|
||||||
|
plasmaSurface->setRole(role);
|
||||||
|
// let's render
|
||||||
|
QImage img(QSize(100, 50), QImage::Format_ARGB32);
|
||||||
|
img.fill(Qt::blue);
|
||||||
|
surface->attachBuffer(m_shm->createBuffer(img));
|
||||||
|
surface->damage(QRect(0, 0, 100, 50));
|
||||||
|
surface->commit(Surface::CommitFlag::None);
|
||||||
|
|
||||||
|
m_connection->flush();
|
||||||
|
QVERIFY(clientAddedSpy.wait());
|
||||||
|
AbstractClient *c = clientAddedSpy.first().first().value<AbstractClient*>();
|
||||||
|
QVERIFY(c);
|
||||||
|
QTEST(c->isMovable(), "movable");
|
||||||
|
QTEST(c->isMovableAcrossScreens(), "movableAcrossScreens");
|
||||||
|
QTEST(c->isResizable(), "resizable");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
WAYLANDTEST_MAIN(KWin::MoveResizeWindowTest)
|
WAYLANDTEST_MAIN(KWin::MoveResizeWindowTest)
|
||||||
|
|
|
@ -502,16 +502,25 @@ QRect ShellClient::iconGeometry() const
|
||||||
|
|
||||||
bool ShellClient::isMovable() const
|
bool ShellClient::isMovable() const
|
||||||
{
|
{
|
||||||
|
if (m_plasmaShellSurface) {
|
||||||
|
return m_plasmaShellSurface->role() == PlasmaShellSurfaceInterface::Role::Normal;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShellClient::isMovableAcrossScreens() const
|
bool ShellClient::isMovableAcrossScreens() const
|
||||||
{
|
{
|
||||||
|
if (m_plasmaShellSurface) {
|
||||||
|
return m_plasmaShellSurface->role() == PlasmaShellSurfaceInterface::Role::Normal;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShellClient::isResizable() const
|
bool ShellClient::isResizable() const
|
||||||
{
|
{
|
||||||
|
if (m_plasmaShellSurface) {
|
||||||
|
return m_plasmaShellSurface->role() == PlasmaShellSurfaceInterface::Role::Normal;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue