2022-02-19 00:47:54 +03:00
|
|
|
import ./make-test-python.nix ({ pkgs, ... }:
|
|
|
|
|
|
|
|
{
|
|
|
|
name = "input-remapper";
|
|
|
|
meta = {
|
|
|
|
maintainers = with pkgs.lib.maintainers; [ LunNova ];
|
|
|
|
};
|
|
|
|
|
2022-03-21 02:15:30 +03:00
|
|
|
nodes.machine = { config, ... }:
|
2022-02-19 00:47:54 +03:00
|
|
|
let user = config.users.users.sybil; in
|
|
|
|
{
|
|
|
|
imports = [
|
|
|
|
./common/user-account.nix
|
|
|
|
./common/x11.nix
|
|
|
|
];
|
|
|
|
|
|
|
|
services.xserver.enable = true;
|
|
|
|
services.input-remapper.enable = true;
|
|
|
|
users.users.sybil = { isNormalUser = true; group = "wheel"; };
|
|
|
|
test-support.displayManager.auto.user = user.name;
|
2022-03-07 19:39:15 +03:00
|
|
|
# workaround for pkexec not working in the test environment
|
|
|
|
# Error creating textual authentication agent:
|
|
|
|
# Error opening current controlling terminal for the process (`/dev/tty'):
|
|
|
|
# No such device or address
|
|
|
|
# passwordless pkexec with polkit module also doesn't work
|
|
|
|
# to allow the program to run, we replace pkexec with sudo
|
|
|
|
# and turn on passwordless sudo
|
|
|
|
# this is not correct in general but good enough for this test
|
2022-02-19 00:47:54 +03:00
|
|
|
security.sudo = { enable = true; wheelNeedsPassword = false; };
|
|
|
|
security.wrappers.pkexec = pkgs.lib.mkForce
|
|
|
|
{
|
|
|
|
setuid = true;
|
|
|
|
owner = "root";
|
|
|
|
group = "root";
|
|
|
|
source = "${pkgs.sudo}/bin/sudo";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
enableOCR = true;
|
|
|
|
|
|
|
|
testScript = { nodes, ... }: ''
|
|
|
|
start_all()
|
|
|
|
machine.wait_for_x()
|
|
|
|
|
|
|
|
machine.succeed("systemctl status input-remapper.service")
|
|
|
|
machine.execute("su - sybil -c input-remapper-gtk >&2 &")
|
|
|
|
|
|
|
|
machine.wait_for_text("Input Remapper")
|
|
|
|
machine.wait_for_text("Preset")
|
|
|
|
machine.wait_for_text("Change Key")
|
|
|
|
'';
|
|
|
|
})
|