[PATCH] gnu: tests: Add system tests for sddm

  • Done
  • quality assurance status badge
Details
2 participants
  • Christopher Baines
  • Richard Sent
Owner
unassigned
Submitted by
Richard Sent
Severity
normal

Debbugs page

R
R
Richard Sent wrote on 4 Apr 14:21 -0700
(address . guix-patches@gnu.org)(name . Richard Sent)(address . richard@freakingpenguin.com)
a6c2826b7d27b9ad5634bb64d669d4f2796f50ff.1712265713.git.richard@freakingpenguin.com
* gnu/tests/sddm.scm: Create a basic suite of tests to verify the display
manager starts.

Change-Id: Ia84926e9aab42c6781430c22aae0f892387d1a29
---
Hi Guix!

Given https://issues.guix.gnu.org/70194I figured it was prudent to
create a test suite for SDDM similar to GDM and LightDM.

I verified this on c9cd16c630, since SDDM seems to be broken since at
least 188d18fc47 (probably earlier). I imagine this should go in after
70194 is closed. Or perhaps there's something horribly wrong with my
machine and this does work on master.

Either way, the more tests the merrier, right?

gnu/tests/sddm.scm | 112 +++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 112 insertions(+)
create mode 100644 gnu/tests/sddm.scm

Toggle diff (122 lines)
diff --git a/gnu/tests/sddm.scm b/gnu/tests/sddm.scm
new file mode 100644
index 0000000000..87059112ee
--- /dev/null
+++ b/gnu/tests/sddm.scm
@@ -0,0 +1,112 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2024 Richard Sent <richard@freakingpenguin.com>.
+;;;
+;;; This file is part of GNU Guix.
+;;;
+;;; GNU Guix 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.
+;;;
+;;; GNU Guix 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 GNU Guix. If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (gnu tests sddm)
+ #:use-module (gnu bootloader)
+ #:use-module (gnu bootloader grub)
+ #:use-module (gnu packages)
+ #:use-module (gnu packages ocr)
+ #:use-module (gnu packages xorg)
+ #:use-module (gnu services)
+ #:use-module (gnu services desktop)
+ #:use-module (gnu services sddm)
+ #:use-module (gnu services xorg)
+ #:use-module (gnu system)
+ #:use-module (gnu system vm)
+ #:use-module (gnu tests)
+ #:use-module (guix gexp)
+ #:use-module (guix modules)
+ #:use-module (srfi srfi-1)
+ #:export (%test-sddm))
+
+(define %sddm-os
+ (operating-system
+ (inherit %simple-os)
+ (services
+ (cons* (service sddm-service-type)
+ (modify-services %desktop-services
+ (delete gdm-service-type))))))
+
+(define (run-sddm-test)
+ "Run tests in %SDDM-OS."
+
+ (define os (marionette-operating-system
+ %sddm-os
+ #:imported-modules (source-module-closure
+ '((gnu services herd)))))
+
+ (define vm (virtual-machine
+ (operating-system os)
+ ;; Test may nondeterministically fail with default memory size.
+ (memory-size 1024)))
+
+ (define test
+ (with-imported-modules (source-module-closure
+ '((gnu build marionette)))
+ #~(begin
+ (use-modules (gnu build marionette)
+ (srfi srfi-26)
+ (srfi srfi-64))
+
+ (let ((marionette (make-marionette (list #$vm))))
+
+ (test-runner-current (system-test-runner #$output))
+ (test-begin "sddm")
+
+ (test-assert "service is running"
+ (marionette-eval
+ '(begin
+ (use-modules (gnu services herd))
+ ;; sddm's shepherd service is called xorg-server
+ (start-service 'xorg-server))
+ marionette))
+
+ (test-assert "service can be stopped"
+ (marionette-eval
+ '(begin
+ (use-modules (gnu services herd))
+ (stop-service 'xorg-server))
+ marionette))
+
+ (test-assert "service can be restarted"
+ (marionette-eval
+ '(begin
+ (use-modules (gnu services herd))
+ (restart-service 'xorg-server))
+ marionette))
+
+ (test-assert "login screen up"
+ ;; GNU Ocrad fails to recognize any text, so use Tesseract.
+ (wait-for-screen-text marionette
+ ;; Login button not recognized, use SDDM's
+ ;; welcome message.
+ (cut string-contains <> (string-append "Welcome to "
+ #$(operating-system-host-name %sddm-os)))
+ #:ocr #$(file-append tesseract-ocr
+ "/bin/tesseract")
+ #:timeout 60))
+
+ (test-end)))))
+
+ (gexp->derivation "sddm-test" test))
+
+(define %test-sddm
+ (system-test
+ (name "sddm")
+ (description "Basic tests for the SDDM service.")
+ (value (run-sddm-test))))

base-commit: ade6845da6cec99f3bca46faac9b2bad6877817e
--
2.41.0
C
C
Christopher Baines wrote on 15 Apr 02:34 -0700
(name . Richard Sent)(address . richard@freakingpenguin.com)(address . 70203-done@debbugs.gnu.org)
87seznynog.fsf@cbaines.net
Richard Sent <richard@freakingpenguin.com> writes:

Toggle quote (21 lines)
> * gnu/tests/sddm.scm: Create a basic suite of tests to verify the display
> manager starts.
>
> Change-Id: Ia84926e9aab42c6781430c22aae0f892387d1a29
> ---
> Hi Guix!
>
> Given https://issues.guix.gnu.org/70194 I figured it was prudent to
> create a test suite for SDDM similar to GDM and LightDM.
>
> I verified this on c9cd16c630, since SDDM seems to be broken since at
> least 188d18fc47 (probably earlier). I imagine this should go in after
> 70194 is closed. Or perhaps there's something horribly wrong with my
> machine and this does work on master.
>
> Either way, the more tests the merrier, right?
>
> gnu/tests/sddm.scm | 112 +++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 112 insertions(+)
> create mode 100644 gnu/tests/sddm.scm

Looks good to me, I've pushed this to master as
027419626f171cdccf9c4a77686840141ea502eb.

Chris
-----BEGIN PGP SIGNATURE-----

iQKlBAEBCgCPFiEEPonu50WOcg2XVOCyXiijOwuE9XcFAmYc9J9fFIAAAAAALgAo
aXNzdWVyLWZwckBub3RhdGlvbnMub3BlbnBncC5maWZ0aGhvcnNlbWFuLm5ldDNF
ODlFRUU3NDU4RTcyMEQ5NzU0RTBCMjVFMjhBMzNCMEI4NEY1NzcRHG1haWxAY2Jh
aW5lcy5uZXQACgkQXiijOwuE9XcSNg//R3ogW5XbkYzd+tVSUsnr4moRs+JXjcox
2E2tugYV/BBnTYXmLlbKYUqgqkHSUuAyvcu1Si5GEH5uc5/QyiLHvar8phQu+edP
eulEK8NqWMqodI06MSmAyejPrhG6iS2Lts9WX4vP2gkUmz7f4hc7xNhqgjmmW8VD
YWXabkDttR5zALJ56XlrCbbzyIFEzV5qcjdqAofd715xTVGgDrE1+u4oqAXB8saT
679iOJqkacIERSrEauN9NcePfJDn+Kg7I0bwRRiYKbM8ly7V/BCzJvRWp9OR7FSf
E+azi2zoMoH8hEXV4lBo7T+LQqBGYiYph9ClYJz52n+ISBhGG46JCaQpzeBCxoqM
8qd8yBclRtlnHwW0h0hFQOdEIcRV6PucBJiCtEL7X6tahPGUjyuNXSTanHJzf3Yb
pDaEAH5RgV8NgN4TtlZzk4002bixJIBugSBHQ20T42I/g1sR+ZkbQh8izzGeua0I
+OyEQbG9wrMdyKiC19+sprvD6avnkwNGcpLALDBCFXb8atZe+dpVf8gBvs4yTyQq
fvyh3KDSKhZ+znS4bc7qWK3hTVrqPmOrIRk69GceMg4MxZqGTJXKQn7U9BnZ6SqO
9XafJt/Byl4Jzdd9GO7fW0hl1wf359aaoJ98FSR0Qr4tVZl5vkr3sh7B6bvLlYNX
LhSc6rav0EQ=
=O1WP
-----END PGP SIGNATURE-----

Closed
?
Your comment

This issue is archived.

To comment on this conversation send an email to 70203@patchwise.org

To respond to this issue using the mumi CLI, first switch to it
mumi current 70203
Then, you may apply the latest patchset in this issue (with sign off)
mumi am -- -s
Or, compose a reply to this issue
mumi compose
Or, send patches to this issue
mumi send-email *.patch