aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/nixos/tests/xrdp.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/nixos/tests/xrdp.nix')
-rw-r--r--nixpkgs/nixos/tests/xrdp.nix45
1 files changed, 45 insertions, 0 deletions
diff --git a/nixpkgs/nixos/tests/xrdp.nix b/nixpkgs/nixos/tests/xrdp.nix
new file mode 100644
index 00000000000..0106aefe831
--- /dev/null
+++ b/nixpkgs/nixos/tests/xrdp.nix
@@ -0,0 +1,45 @@
+import ./make-test.nix ({ pkgs, ...} : {
+ name = "xrdp";
+ meta = with pkgs.stdenv.lib.maintainers; {
+ maintainers = [ volth ];
+ };
+
+ nodes = {
+ server = { pkgs, ... }: {
+ imports = [ ./common/user-account.nix ];
+ services.xrdp.enable = true;
+ services.xrdp.defaultWindowManager = "${pkgs.xterm}/bin/xterm";
+ networking.firewall.allowedTCPPorts = [ 3389 ];
+ };
+
+ client = { pkgs, ... }: {
+ imports = [ ./common/x11.nix ./common/user-account.nix ];
+ services.xserver.displayManager.auto.user = "alice";
+ environment.systemPackages = [ pkgs.freerdp ];
+ services.xrdp.enable = true;
+ services.xrdp.defaultWindowManager = "${pkgs.icewm}/bin/icewm";
+ };
+ };
+
+ testScript = { ... }: ''
+ startAll;
+
+ $client->waitForX;
+ $client->waitForFile("/home/alice/.Xauthority");
+ $client->succeed("xauth merge ~alice/.Xauthority");
+
+ $client->sleep(5);
+
+ $client->execute("xterm &");
+ $client->sleep(1);
+ $client->sendChars("xfreerdp /cert-tofu /w:640 /h:480 /v:127.0.0.1 /u:alice /p:foobar\n");
+ $client->sleep(5);
+ $client->screenshot("localrdp");
+
+ $client->execute("xterm &");
+ $client->sleep(1);
+ $client->sendChars("xfreerdp /cert-tofu /w:640 /h:480 /v:server /u:alice /p:foobar\n");
+ $client->sleep(5);
+ $client->screenshot("remoterdp");
+ '';
+})