[mutter] tests: Add some basic MetaKmsUpdate unit tests
- From: Marge Bot <marge-bot src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter] tests: Add some basic MetaKmsUpdate unit tests
- Date: Tue, 25 Jan 2022 16:25:06 +0000 (UTC)
commit acd51a7e694b4bdf8720f513d9f62e9a6fb77be7
Author: Jonas Ã…dahl <jadahl gmail com>
Date: Wed Jun 16 11:34:12 2021 +0200
tests: Add some basic MetaKmsUpdate unit tests
Mostly rudimentary sanity testing.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2159>
src/backends/native/meta-backend-native-private.h | 1 +
src/backends/native/meta-backend-native.h | 1 +
src/backends/native/meta-device-pool.h | 4 +
src/backends/native/meta-drm-buffer-dumb.h | 1 +
src/backends/native/meta-drm-buffer.h | 2 +
src/backends/native/meta-kms-connector.h | 2 +
src/backends/native/meta-kms-crtc.h | 2 +
src/backends/native/meta-kms-device.h | 8 ++
src/backends/native/meta-kms-mode.h | 2 +
src/backends/native/meta-kms-update-private.h | 10 ++
src/backends/native/meta-kms-update.h | 4 +
src/backends/native/meta-kms.h | 2 +
src/tests/meson.build | 12 +++
src/tests/native-kms-updates.c | 109 ++++++++++++++++++++++
14 files changed, 160 insertions(+)
---
diff --git a/src/backends/native/meta-backend-native-private.h
b/src/backends/native/meta-backend-native-private.h
index cd184685f0..904b052dad 100644
--- a/src/backends/native/meta-backend-native-private.h
+++ b/src/backends/native/meta-backend-native-private.h
@@ -30,6 +30,7 @@
MetaBarrierManagerNative *meta_backend_native_get_barrier_manager (MetaBackendNative *native);
+META_EXPORT_TEST
MetaDevicePool * meta_backend_native_get_device_pool (MetaBackendNative *native);
#endif /* META_BACKEND_NATIVE_PRIVATE_H */
diff --git a/src/backends/native/meta-backend-native.h b/src/backends/native/meta-backend-native.h
index fd867e5f76..821d2dfd39 100644
--- a/src/backends/native/meta-backend-native.h
+++ b/src/backends/native/meta-backend-native.h
@@ -48,6 +48,7 @@ MetaLauncher * meta_backend_native_get_launcher (MetaBackendNative *native);
MetaUdev * meta_backend_native_get_udev (MetaBackendNative *native);
+META_EXPORT_TEST
MetaKms * meta_backend_native_get_kms (MetaBackendNative *native);
const char * meta_backend_native_get_seat_id (MetaBackendNative *backend_native);
diff --git a/src/backends/native/meta-device-pool.h b/src/backends/native/meta-device-pool.h
index 0e9653bd6f..5ebe82d103 100644
--- a/src/backends/native/meta-device-pool.h
+++ b/src/backends/native/meta-device-pool.h
@@ -23,6 +23,8 @@
#include <glib-object.h>
#include <stdint.h>
+#include "core/util-private.h"
+
typedef enum _MetaDeviceFileFlags
{
META_DEVICE_FILE_FLAG_NONE = 0,
@@ -54,10 +56,12 @@ uint32_t meta_device_file_has_tag (MetaDeviceFile *device_file,
MetaDeviceFile * meta_device_file_acquire (MetaDeviceFile *file);
+META_EXPORT_TEST
void meta_device_file_release (MetaDeviceFile *device_file);
MetaDevicePool * meta_device_file_get_pool (MetaDeviceFile *device_file);
+META_EXPORT_TEST
MetaDeviceFile * meta_device_pool_open (MetaDevicePool *pool,
const char *path,
MetaDeviceFileFlags flags,
diff --git a/src/backends/native/meta-drm-buffer-dumb.h b/src/backends/native/meta-drm-buffer-dumb.h
index afc14660ba..3ab05727b7 100644
--- a/src/backends/native/meta-drm-buffer-dumb.h
+++ b/src/backends/native/meta-drm-buffer-dumb.h
@@ -31,6 +31,7 @@ G_DECLARE_FINAL_TYPE (MetaDrmBufferDumb,
META, DRM_BUFFER_DUMB,
MetaDrmBuffer)
+META_EXPORT_TEST
MetaDrmBufferDumb * meta_drm_buffer_dumb_new (MetaDeviceFile *device,
int width,
int height,
diff --git a/src/backends/native/meta-drm-buffer.h b/src/backends/native/meta-drm-buffer.h
index 441473aca1..801156cecf 100644
--- a/src/backends/native/meta-drm-buffer.h
+++ b/src/backends/native/meta-drm-buffer.h
@@ -27,6 +27,7 @@
#include <stdint.h>
#include "cogl/cogl.h"
+#include "core/util-private.h"
typedef enum _MetaDrmBufferFlags
{
@@ -35,6 +36,7 @@ typedef enum _MetaDrmBufferFlags
} MetaDrmBufferFlags;
#define META_TYPE_DRM_BUFFER (meta_drm_buffer_get_type ())
+META_EXPORT_TEST
G_DECLARE_DERIVABLE_TYPE (MetaDrmBuffer,
meta_drm_buffer,
META, DRM_BUFFER,
diff --git a/src/backends/native/meta-kms-connector.h b/src/backends/native/meta-kms-connector.h
index 397753b433..98abe85f23 100644
--- a/src/backends/native/meta-kms-connector.h
+++ b/src/backends/native/meta-kms-connector.h
@@ -28,6 +28,7 @@
#include "backends/native/meta-kms-types.h"
#define META_TYPE_KMS_CONNECTOR (meta_kms_connector_get_type ())
+META_EXPORT_TEST
G_DECLARE_FINAL_TYPE (MetaKmsConnector, meta_kms_connector,
META, KMS_CONNECTOR, GObject)
@@ -71,6 +72,7 @@ const char * meta_kms_connector_get_name (MetaKmsConnector *connector);
gboolean meta_kms_connector_can_clone (MetaKmsConnector *connector,
MetaKmsConnector *other_connector);
+META_EXPORT_TEST
const MetaKmsConnectorState * meta_kms_connector_get_current_state (MetaKmsConnector *connector);
gboolean meta_kms_connector_is_underscanning_supported (MetaKmsConnector *connector);
diff --git a/src/backends/native/meta-kms-crtc.h b/src/backends/native/meta-kms-crtc.h
index 406ca3ac1e..78c210f6a6 100644
--- a/src/backends/native/meta-kms-crtc.h
+++ b/src/backends/native/meta-kms-crtc.h
@@ -25,6 +25,7 @@
#include <xf86drmMode.h>
#include "backends/native/meta-kms-types.h"
+#include "core/util-private.h"
#include "meta/boxes.h"
typedef struct _MetaKmsCrtcState
@@ -54,6 +55,7 @@ typedef struct _MetaKmsCrtcGamma
} MetaKmsCrtcGamma;
#define META_TYPE_KMS_CRTC (meta_kms_crtc_get_type ())
+META_EXPORT_TEST
G_DECLARE_FINAL_TYPE (MetaKmsCrtc, meta_kms_crtc,
META, KMS_CRTC,
GObject)
diff --git a/src/backends/native/meta-kms-device.h b/src/backends/native/meta-kms-device.h
index 58dda61362..74551b1b1a 100644
--- a/src/backends/native/meta-kms-device.h
+++ b/src/backends/native/meta-kms-device.h
@@ -23,14 +23,18 @@
#include <glib-object.h>
#include "backends/native/meta-kms-types.h"
+#include "core/util-private.h"
#define META_TYPE_KMS_DEVICE (meta_kms_device_get_type ())
+META_EXPORT_TEST
G_DECLARE_FINAL_TYPE (MetaKmsDevice, meta_kms_device,
META, KMS_DEVICE,
GObject)
+META_EXPORT_TEST
MetaKms * meta_kms_device_get_kms (MetaKmsDevice *device);
+META_EXPORT_TEST
const char * meta_kms_device_get_path (MetaKmsDevice *device);
const char * meta_kms_device_get_driver_name (MetaKmsDevice *device);
@@ -47,15 +51,19 @@ gboolean meta_kms_device_prefers_shadow_buffer (MetaKmsDevice *device);
gboolean meta_kms_device_uses_monotonic_clock (MetaKmsDevice *device);
+META_EXPORT_TEST
GList * meta_kms_device_get_connectors (MetaKmsDevice *device);
+META_EXPORT_TEST
GList * meta_kms_device_get_crtcs (MetaKmsDevice *device);
GList * meta_kms_device_get_planes (MetaKmsDevice *device);
+META_EXPORT_TEST
MetaKmsPlane * meta_kms_device_get_primary_plane_for (MetaKmsDevice *device,
MetaKmsCrtc *crtc);
+META_EXPORT_TEST
MetaKmsPlane * meta_kms_device_get_cursor_plane_for (MetaKmsDevice *device,
MetaKmsCrtc *crtc);
diff --git a/src/backends/native/meta-kms-mode.h b/src/backends/native/meta-kms-mode.h
index f9a4477a44..e017dc9f29 100644
--- a/src/backends/native/meta-kms-mode.h
+++ b/src/backends/native/meta-kms-mode.h
@@ -25,6 +25,7 @@
#include <xf86drmMode.h>
#include "backends/native/meta-kms-types.h"
+#include "core/util-private.h"
typedef enum _MetaKmsModeFlag
{
@@ -37,6 +38,7 @@ const char * meta_kms_mode_get_name (MetaKmsMode *mode);
MetaKmsModeFlag meta_kms_mode_get_flags (MetaKmsMode *mode);
+META_EXPORT_TEST
const drmModeModeInfo * meta_kms_mode_get_drm_mode (MetaKmsMode *mode);
gboolean meta_kms_mode_equal (MetaKmsMode *mode,
diff --git a/src/backends/native/meta-kms-update-private.h b/src/backends/native/meta-kms-update-private.h
index 4fcc170c23..b7a0753857 100644
--- a/src/backends/native/meta-kms-update-private.h
+++ b/src/backends/native/meta-kms-update-private.h
@@ -124,33 +124,43 @@ void meta_kms_update_lock (MetaKmsUpdate *update);
void meta_kms_update_unlock (MetaKmsUpdate *update);
+META_EXPORT_TEST
gboolean meta_kms_update_is_locked (MetaKmsUpdate *update);
uint64_t meta_kms_update_get_sequence_number (MetaKmsUpdate *update);
+META_EXPORT_TEST
MetaKmsDevice * meta_kms_update_get_device (MetaKmsUpdate *update);
void meta_kms_plane_assignment_set_rotation (MetaKmsPlaneAssignment *plane_assignment,
uint64_t rotation);
+META_EXPORT_TEST
MetaKmsPlaneAssignment * meta_kms_update_get_primary_plane_assignment (MetaKmsUpdate *update,
MetaKmsCrtc *crtc);
+META_EXPORT_TEST
MetaKmsPlaneAssignment * meta_kms_update_get_cursor_plane_assignment (MetaKmsUpdate *update,
MetaKmsCrtc *crtc);
+META_EXPORT_TEST
GList * meta_kms_update_get_plane_assignments (MetaKmsUpdate *update);
+META_EXPORT_TEST
GList * meta_kms_update_get_mode_sets (MetaKmsUpdate *update);
+META_EXPORT_TEST
GList * meta_kms_update_get_page_flip_listeners (MetaKmsUpdate *update);
void meta_kms_update_drop_defunct_page_flip_listeners (MetaKmsUpdate *update);
+META_EXPORT_TEST
GList * meta_kms_update_get_connector_updates (MetaKmsUpdate *update);
+META_EXPORT_TEST
GList * meta_kms_update_get_crtc_gammas (MetaKmsUpdate *update);
+META_EXPORT_TEST
gboolean meta_kms_update_is_power_save (MetaKmsUpdate *update);
MetaKmsCustomPageFlip * meta_kms_update_take_custom_page_flip_func (MetaKmsUpdate *update);
diff --git a/src/backends/native/meta-kms-update.h b/src/backends/native/meta-kms-update.h
index 0c3028b52a..70febb5663 100644
--- a/src/backends/native/meta-kms-update.h
+++ b/src/backends/native/meta-kms-update.h
@@ -89,8 +89,10 @@ GList * meta_kms_feedback_get_failed_planes (const MetaKmsFeedback *feedback);
const GError * meta_kms_feedback_get_error (const MetaKmsFeedback *feedback);
+META_EXPORT_TEST
MetaKmsUpdate * meta_kms_update_new (MetaKmsDevice *device);
+META_EXPORT_TEST
void meta_kms_update_free (MetaKmsUpdate *update);
void meta_kms_update_set_underscanning (MetaKmsUpdate *update,
@@ -123,6 +125,7 @@ void meta_kms_plane_assignment_set_fb_damage (MetaKmsPlaneAssignment *plane_assi
const int *rectangles,
int n_rectangles);
+META_EXPORT_TEST
MetaKmsPlaneAssignment * meta_kms_update_assign_plane (MetaKmsUpdate *update,
MetaKmsCrtc *crtc,
MetaKmsPlane *plane,
@@ -146,6 +149,7 @@ void meta_kms_update_set_custom_page_flip (MetaKmsUpdate *update,
MetaKmsCustomPageFlipFunc func,
gpointer user_data);
+META_EXPORT_TEST
void meta_kms_plane_assignment_set_cursor_hotspot (MetaKmsPlaneAssignment *plane_assignment,
int x,
int y);
diff --git a/src/backends/native/meta-kms.h b/src/backends/native/meta-kms.h
index 218cb71463..c95a2c4449 100644
--- a/src/backends/native/meta-kms.h
+++ b/src/backends/native/meta-kms.h
@@ -60,8 +60,10 @@ void meta_kms_discard_pending_page_flips (MetaKms *kms);
void meta_kms_notify_modes_set (MetaKms *kms);
+META_EXPORT_TEST
MetaBackend * meta_kms_get_backend (MetaKms *kms);
+META_EXPORT_TEST
GList * meta_kms_get_devices (MetaKms *kms);
void meta_kms_resume (MetaKms *kms);
diff --git a/src/tests/meson.build b/src/tests/meson.build
index 6f790f9f3d..5b3bf11084 100644
--- a/src/tests/meson.build
+++ b/src/tests/meson.build
@@ -297,6 +297,17 @@ if have_native_tests
install: have_installed_tests,
install_dir: mutter_installed_tests_libexecdir,
)
+
+ native_kms_update_tests = executable('mutter-native-kms-update-tests',
+ sources: [
+ 'native-kms-updates.c',
+ ],
+ include_directories: tests_includes,
+ c_args: tests_c_args,
+ dependencies: libmutter_test_dep,
+ install: have_installed_tests,
+ install_dir: mutter_installed_tests_libexecdir,
+ )
endif
stacking_tests = [
@@ -416,6 +427,7 @@ endif
if have_kvm_tests or have_tty_tests
privileged_tests = [
[ 'kms-render', native_kms_render_tests ],
+ [ 'kms-update', native_kms_update_tests ],
]
if have_kvm_tests
diff --git a/src/tests/native-kms-updates.c b/src/tests/native-kms-updates.c
new file mode 100644
index 0000000000..28799c7120
--- /dev/null
+++ b/src/tests/native-kms-updates.c
@@ -0,0 +1,109 @@
+/*
+ * Copyright (C) 2021 Red Hat Inc.
+ *
+ * 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., 59 Temple Place - Suite 330, Boston, MA
+ * 02111-1307, USA.
+ *
+ */
+
+#include "config.h"
+
+#include <gbm.h>
+
+#include "backends/native/meta-backend-native-private.h"
+#include "backends/native/meta-device-pool.h"
+#include "backends/native/meta-drm-buffer-dumb.h"
+#include "backends/native/meta-kms-connector.h"
+#include "backends/native/meta-kms-crtc.h"
+#include "backends/native/meta-kms-device.h"
+#include "backends/native/meta-kms-mode.h"
+#include "backends/native/meta-kms-update-private.h"
+#include "backends/native/meta-kms.h"
+#include "meta-test/meta-context-test.h"
+#include "meta/meta-backend.h"
+
+static MetaContext *test_context;
+
+static MetaKmsDevice *
+get_test_kms_device (void)
+{
+ MetaBackend *backend = meta_context_get_backend (test_context);
+ MetaBackendNative *backend_native = META_BACKEND_NATIVE (backend);
+ MetaKms *kms = meta_backend_native_get_kms (backend_native);
+ GList *devices;
+
+ devices = meta_kms_get_devices (kms);
+ g_assert_cmpuint (g_list_length (devices), ==, 1);
+ return META_KMS_DEVICE (devices->data);
+}
+
+static MetaKmsCrtc *
+get_test_crtc (MetaKmsDevice *device)
+{
+ GList *crtcs;
+
+ crtcs = meta_kms_device_get_crtcs (device);
+ g_assert_cmpuint (g_list_length (crtcs), ==, 1);
+
+ return META_KMS_CRTC (crtcs->data);
+}
+
+static void
+meta_test_kms_update_sanity (void)
+{
+ MetaKmsDevice *device;
+ MetaKmsCrtc *crtc;
+ MetaKmsUpdate *update;
+
+ device = get_test_kms_device ();
+ crtc = get_test_crtc (device);
+
+ update = meta_kms_update_new (device);
+ g_assert (meta_kms_update_get_device (update) == device);
+ g_assert_false (meta_kms_update_is_locked (update));
+ g_assert_false (meta_kms_update_is_power_save (update));
+ g_assert_null (meta_kms_update_get_primary_plane_assignment (update, crtc));
+ g_assert_null (meta_kms_update_get_plane_assignments (update));
+ g_assert_null (meta_kms_update_get_mode_sets (update));
+ g_assert_null (meta_kms_update_get_page_flip_listeners (update));
+ g_assert_null (meta_kms_update_get_connector_updates (update));
+ g_assert_null (meta_kms_update_get_crtc_gammas (update));
+ meta_kms_update_free (update);
+}
+
+static void
+init_tests (void)
+{
+ g_test_add_func ("/backends/native/kms/update/sanity",
+ meta_test_kms_update_sanity);
+}
+
+int
+main (int argc,
+ char **argv)
+{
+ g_autoptr (MetaContext) context = NULL;
+ g_autoptr (GError) error = NULL;
+
+ context = test_context =
+ meta_create_test_context (META_CONTEXT_TEST_TYPE_VKMS,
+ META_CONTEXT_TEST_FLAG_NO_X11);
+ g_assert (meta_context_configure (context, &argc, &argv, NULL));
+
+ init_tests ();
+
+ return meta_context_test_run_tests (META_CONTEXT_TEST (context),
+ META_TEST_RUN_FLAG_CAN_SKIP);
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]