[mutter] tests: Add KMS device tests
- From: Marge Bot <marge-bot src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter] tests: Add KMS device tests
- Date: Tue, 25 Jan 2022 16:25:06 +0000 (UTC)
commit 43a1ba34329d151f08193bdf0abf90b0ef9b8ccb
Author: Jonas Ã…dahl <jadahl gmail com>
Date: Wed Jun 23 10:10:35 2021 +0200
tests: Add KMS device tests
As other KMS tests, depends on being DRM master and vkms being loaded.
Currently consists of a sanity check that checks for the expected set of
connectors, CRTCs, planes, etc.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2159>
src/backends/native/meta-kms-connector.h | 1 +
src/backends/native/meta-kms-crtc.h | 1 +
src/backends/native/meta-kms-device.h | 3 +
src/backends/native/meta-kms-plane.h | 3 +
src/tests/meson.build | 12 ++++
src/tests/native-kms-device.c | 111 +++++++++++++++++++++++++++++++
6 files changed, 131 insertions(+)
---
diff --git a/src/backends/native/meta-kms-connector.h b/src/backends/native/meta-kms-connector.h
index 98abe85f23..02f74d9f6a 100644
--- a/src/backends/native/meta-kms-connector.h
+++ b/src/backends/native/meta-kms-connector.h
@@ -61,6 +61,7 @@ typedef struct _MetaKmsConnectorState
MetaMonitorTransform panel_orientation_transform;
} MetaKmsConnectorState;
+META_EXPORT_TEST
MetaKmsDevice * meta_kms_connector_get_device (MetaKmsConnector *connector);
uint32_t meta_kms_connector_get_connector_type (MetaKmsConnector *connector);
diff --git a/src/backends/native/meta-kms-crtc.h b/src/backends/native/meta-kms-crtc.h
index 78c210f6a6..1a64eadf55 100644
--- a/src/backends/native/meta-kms-crtc.h
+++ b/src/backends/native/meta-kms-crtc.h
@@ -60,6 +60,7 @@ G_DECLARE_FINAL_TYPE (MetaKmsCrtc, meta_kms_crtc,
META, KMS_CRTC,
GObject)
+META_EXPORT_TEST
MetaKmsDevice * meta_kms_crtc_get_device (MetaKmsCrtc *crtc);
const MetaKmsCrtcState * meta_kms_crtc_get_current_state (MetaKmsCrtc *crtc);
diff --git a/src/backends/native/meta-kms-device.h b/src/backends/native/meta-kms-device.h
index 74551b1b1a..c504c2f480 100644
--- a/src/backends/native/meta-kms-device.h
+++ b/src/backends/native/meta-kms-device.h
@@ -37,6 +37,7 @@ MetaKms * meta_kms_device_get_kms (MetaKmsDevice *device);
META_EXPORT_TEST
const char * meta_kms_device_get_path (MetaKmsDevice *device);
+META_EXPORT_TEST
const char * meta_kms_device_get_driver_name (MetaKmsDevice *device);
const char * meta_kms_device_get_driver_description (MetaKmsDevice *device);
@@ -49,6 +50,7 @@ gboolean meta_kms_device_get_cursor_size (MetaKmsDevice *device,
gboolean meta_kms_device_prefers_shadow_buffer (MetaKmsDevice *device);
+META_EXPORT_TEST
gboolean meta_kms_device_uses_monotonic_clock (MetaKmsDevice *device);
META_EXPORT_TEST
@@ -57,6 +59,7 @@ GList * meta_kms_device_get_connectors (MetaKmsDevice *device);
META_EXPORT_TEST
GList * meta_kms_device_get_crtcs (MetaKmsDevice *device);
+META_EXPORT_TEST
GList * meta_kms_device_get_planes (MetaKmsDevice *device);
META_EXPORT_TEST
diff --git a/src/backends/native/meta-kms-plane.h b/src/backends/native/meta-kms-plane.h
index 941c166808..51f0a9fc55 100644
--- a/src/backends/native/meta-kms-plane.h
+++ b/src/backends/native/meta-kms-plane.h
@@ -38,10 +38,12 @@ enum _MetaKmsPlaneType
G_DECLARE_FINAL_TYPE (MetaKmsPlane, meta_kms_plane,
META, KMS_PLANE, GObject)
+META_EXPORT_TEST
MetaKmsDevice * meta_kms_plane_get_device (MetaKmsPlane *plane);
uint32_t meta_kms_plane_get_id (MetaKmsPlane *plane);
+META_EXPORT_TEST
MetaKmsPlaneType meta_kms_plane_get_plane_type (MetaKmsPlane *plane);
gboolean meta_kms_plane_is_transform_handled (MetaKmsPlane *plane,
@@ -55,6 +57,7 @@ GArray * meta_kms_plane_copy_drm_format_list (MetaKmsPlane *plane);
gboolean meta_kms_plane_is_format_supported (MetaKmsPlane *plane,
uint32_t format);
+META_EXPORT_TEST
gboolean meta_kms_plane_is_usable_with (MetaKmsPlane *plane,
MetaKmsCrtc *crtc);
diff --git a/src/tests/meson.build b/src/tests/meson.build
index c5cb3ed564..d07099844a 100644
--- a/src/tests/meson.build
+++ b/src/tests/meson.build
@@ -298,6 +298,17 @@ if have_native_tests
install_dir: mutter_installed_tests_libexecdir,
)
+ native_kms_device_tests = executable('mutter-native-kms-device',
+ sources: [
+ 'native-kms-device.c',
+ ],
+ include_directories: tests_includes,
+ c_args: tests_c_args,
+ dependencies: libmutter_test_dep,
+ install: have_installed_tests,
+ install_dir: mutter_installed_tests_libexecdir,
+ )
+
native_kms_update_tests = executable('mutter-native-kms-update-tests',
sources: [
'meta-kms-test-utils.c',
@@ -429,6 +440,7 @@ endif
if have_kvm_tests or have_tty_tests
privileged_tests = [
[ 'kms-render', native_kms_render_tests ],
+ [ 'kms-device', native_kms_device_tests ],
[ 'kms-update', native_kms_update_tests ],
]
diff --git a/src/tests/native-kms-device.c b/src/tests/native-kms-device.c
new file mode 100644
index 0000000000..c14579ff81
--- /dev/null
+++ b/src/tests/native-kms-device.c
@@ -0,0 +1,111 @@
+/*
+ * 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 "backends/native/meta-backend-native-private.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-plane.h"
+#include "backends/native/meta-kms.h"
+#include "meta-test/meta-context-test.h"
+
+static MetaContext *test_context;
+
+static void
+meta_test_kms_device_sanity (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;
+ MetaKmsDevice *device;
+ GList *connectors;
+ MetaKmsConnector *connector;
+ GList *crtcs;
+ MetaKmsCrtc *crtc;
+ GList *planes;
+ MetaKmsPlane *primary_plane;
+ MetaKmsPlane *cursor_plane;
+
+ devices = meta_kms_get_devices (kms);
+ g_assert_cmpuint (g_list_length (devices), ==, 1);
+ device = META_KMS_DEVICE (devices->data);
+
+ g_assert (meta_kms_device_get_kms (device) == kms);
+ g_assert_cmpstr (meta_kms_device_get_driver_name (device), ==, "vkms");
+ g_assert_true (meta_kms_device_uses_monotonic_clock (device));
+
+ connectors = meta_kms_device_get_connectors (device);
+ g_assert_cmpuint (g_list_length (connectors), ==, 1);
+ connector = META_KMS_CONNECTOR (connectors->data);
+ g_assert (meta_kms_connector_get_device (connector) == device);
+
+ crtcs = meta_kms_device_get_crtcs (device);
+ g_assert_cmpuint (g_list_length (crtcs), ==, 1);
+ crtc = META_KMS_CRTC (crtcs->data);
+ g_assert (meta_kms_crtc_get_device (crtc) == device);
+
+ planes = meta_kms_device_get_planes (device);
+ g_assert_cmpuint (g_list_length (planes), ==, 2);
+ primary_plane = meta_kms_device_get_primary_plane_for (device, crtc);
+ g_assert_nonnull (primary_plane);
+ cursor_plane = meta_kms_device_get_cursor_plane_for (device, crtc);
+ g_assert_nonnull (cursor_plane);
+ g_assert (cursor_plane != primary_plane);
+ g_assert_nonnull (g_list_find (planes, primary_plane));
+ g_assert_nonnull (g_list_find (planes, cursor_plane));
+ g_assert (meta_kms_plane_get_device (primary_plane) == device);
+ g_assert (meta_kms_plane_get_device (cursor_plane) == device);
+ g_assert_true (meta_kms_plane_is_usable_with (primary_plane, crtc));
+ g_assert_true (meta_kms_plane_is_usable_with (cursor_plane, crtc));
+ g_assert_cmpint (meta_kms_plane_get_plane_type (primary_plane),
+ ==,
+ META_KMS_PLANE_TYPE_PRIMARY);
+ g_assert_cmpint (meta_kms_plane_get_plane_type (cursor_plane),
+ ==,
+ META_KMS_PLANE_TYPE_CURSOR);
+}
+
+static void
+init_tests (void)
+{
+ g_test_add_func ("/backends/native/kms/device/sanity",
+ meta_test_kms_device_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]