From 2cc758045e322873ad58f675a70c8d8366b5c318 Mon Sep 17 00:00:00 2001 From: Paul Olav Tvete Date: Fri, 5 Aug 2016 11:53:43 +0200 Subject: Fix autotest directory structure The client and server parts are separate modules, so they need separate top-level directories under tests/auto. This also makes it easier to add new tests later. Change-Id: I393341b6f4e8fc3afa480653f3482192e002e425 Reviewed-by: Giulio Camuffo --- tests/auto/client/mockcompositor.h | 208 ------------------------------------- 1 file changed, 208 deletions(-) delete mode 100644 tests/auto/client/mockcompositor.h (limited to 'tests/auto/client/mockcompositor.h') diff --git a/tests/auto/client/mockcompositor.h b/tests/auto/client/mockcompositor.h deleted file mode 100644 index 2f0df4a0f..000000000 --- a/tests/auto/client/mockcompositor.h +++ /dev/null @@ -1,208 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2015 The Qt Company Ltd. -** Contact: http://www.qt.io/licensing/ -** -** This file is part of the test suite of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL21$ -** 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 http://www.qt.io/terms-conditions. For further -** information use the contact form at http://www.qt.io/contact-us. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 or version 3 as published by the Free -** Software Foundation and appearing in the file LICENSE.LGPLv21 and -** LICENSE.LGPLv3 included in the packaging of this file. Please review the -** following information to ensure the GNU Lesser General Public License -** requirements will be met: https://www.gnu.org/licenses/lgpl.html and -** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** As a special exception, The Qt Company gives you certain additional -** rights. These rights are described in The Qt Company LGPL Exception -** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. -** -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef MOCKCOMPOSITOR_H -#define MOCKCOMPOSITOR_H - -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include - -namespace Impl { - -typedef void (**Implementation)(void); - -class Keyboard; -class Pointer; -class Touch; -class Seat; -class DataDeviceManager; -class Surface; - -class Compositor -{ -public: - Compositor(); - ~Compositor(); - - int fileDescriptor() const { return m_fd; } - void dispatchEvents(int timeout = 0); - - uint32_t nextSerial(); - uint32_t time() { return ++m_time; } - - static void setOutputGeometry(void *compositor, const QList ¶meters); - - QVector surfaces() const; - - void addSurface(Surface *surface); - void removeSurface(Surface *surface); - - static void setKeyboardFocus(void *data, const QList ¶meters); - static void sendMousePress(void *data, const QList ¶meters); - static void sendMouseRelease(void *data, const QList ¶meters); - static void sendKeyPress(void *data, const QList ¶meters); - static void sendKeyRelease(void *data, const QList ¶meters); - static void sendTouchDown(void *data, const QList ¶meters); - static void sendTouchUp(void *data, const QList ¶meters); - static void sendTouchMotion(void *data, const QList ¶meters); - static void sendTouchFrame(void *data, const QList ¶meters); - static void sendDataDeviceDataOffer(void *data, const QList ¶meters); - static void sendDataDeviceEnter(void *data, const QList ¶meters); - static void sendDataDeviceMotion(void *data, const QList ¶meters); - static void sendDataDeviceDrop(void *data, const QList ¶meters); - static void sendDataDeviceLeave(void *data, const QList ¶meters); - static void waitForStartDrag(void *data, const QList ¶meters); - -public: - bool m_startDragSeen; - -private: - static void bindCompositor(wl_client *client, void *data, uint32_t version, uint32_t id); - static void bindOutput(wl_client *client, void *data, uint32_t version, uint32_t id); - static void bindShell(wl_client *client, void *data, uint32_t version, uint32_t id); - - void initShm(); - - void sendOutputGeometry(wl_resource *resource); - void sendOutputMode(wl_resource *resource); - - QRect m_outputGeometry; - - wl_display *m_display; - wl_event_loop *m_loop; - wl_shm *m_shm; - int m_fd; - - wl_list m_outputResources; - uint32_t m_time; - - QScopedPointer m_seat; - Pointer *m_pointer; - Keyboard *m_keyboard; - Touch *m_touch; - QScopedPointer m_data_device_manager; - QVector m_surfaces; -}; - -void registerResource(wl_list *list, wl_resource *resource); - -} - -class MockSurface -{ -public: - Impl::Surface *handle() const { return m_surface; } - - QImage image; - -private: - MockSurface(Impl::Surface *surface); - friend class Impl::Compositor; - friend class Impl::Surface; - - Impl::Surface *m_surface; -}; - -Q_DECLARE_METATYPE(QSharedPointer) - -class MockCompositor -{ -public: - MockCompositor(); - ~MockCompositor(); - - void applicationInitialized(); - - int waylandFileDescriptor() const; - void processWaylandEvents(); - - void setOutputGeometry(const QRect &rect); - void setKeyboardFocus(const QSharedPointer &surface); - void sendMousePress(const QSharedPointer &surface, const QPoint &pos); - void sendMouseRelease(const QSharedPointer &surface); - void sendKeyPress(const QSharedPointer &surface, uint code); - void sendKeyRelease(const QSharedPointer &surface, uint code); - void sendTouchDown(const QSharedPointer &surface, const QPoint &position, int id); - void sendTouchMotion(const QSharedPointer &surface, const QPoint &position, int id); - void sendTouchUp(const QSharedPointer &surface, int id); - void sendTouchFrame(const QSharedPointer &surface); - void sendDataDeviceDataOffer(const QSharedPointer &surface); - void sendDataDeviceEnter(const QSharedPointer &surface, const QPoint &position); - void sendDataDeviceMotion(const QPoint &position); - void sendDataDeviceDrop(const QSharedPointer &surface); - void sendDataDeviceLeave(const QSharedPointer &surface); - void waitForStartDrag(); - - QSharedPointer surface(); - - void lock(); - void unlock(); - -private: - struct Command - { - typedef void (*Callback)(void *target, const QList ¶meters); - - Callback callback; - void *target; - QList parameters; - }; - - static Command makeCommand(Command::Callback callback, void *target); - - void processCommand(const Command &command); - void dispatchCommands(); - - static void *run(void *data); - - bool m_alive; - bool m_ready; - pthread_t m_thread; - QMutex m_mutex; - QWaitCondition m_waitCondition; - - Impl::Compositor *m_compositor; - - QList m_commandQueue; -}; - -#endif -- cgit v1.2.3