From 1a0c0fb2e2ff95e3327783bb9af69131d3a004e0 Mon Sep 17 00:00:00 2001 From: Alphonse Mariya Date: Sun, 7 Apr 2019 22:59:00 +0200 Subject: [PATCH] keygrabber: Add test for multiple instance creation (#2712) --- tests/test-keygrabber.lua | 73 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 tests/test-keygrabber.lua diff --git a/tests/test-keygrabber.lua b/tests/test-keygrabber.lua new file mode 100644 index 000000000..4070d22a9 --- /dev/null +++ b/tests/test-keygrabber.lua @@ -0,0 +1,73 @@ +-- Test for #2712: It should be possible to create multiple instances of +-- keygrabber during the same loop. + +local runner = require("_runner") +local awful = require("awful") + +local keygrabber_a_active = false +local keygrabber_b_active = false + +local steps = { + function() + awful.keygrabber { + keybindings = { + {{}, "a", function() keygrabber_a_active = true end}, + }, + stop_key = "Escape", + stop_callback = function() keygrabber_a_active = false end, + export_keybindings = true, + } + awful.keygrabber { + keybindings = { + {{}, "b", function() keygrabber_b_active = true end}, + }, + stop_key = "Escape", + stop_callback = function() keygrabber_b_active = false end, + export_keybindings = true, + } + return true + end, + + function(count) + if count == 1 then + root.fake_input("key_press" , "a") + root.fake_input("key_release", "a") + end + if keygrabber_a_active and not keygrabber_b_active then + return true + end + end, + + function(count) + if count == 1 then + root.fake_input("key_press" , "Escape") + root.fake_input("key_release", "Escape") + end + if not keygrabber_a_active and not keygrabber_b_active then + return true + end + end, + + function(count) + if count == 1 then + root.fake_input("key_press" , "b") + root.fake_input("key_release", "b") + end + if not keygrabber_a_active and keygrabber_b_active then + return true + end + end, + + function(count) + if count == 1 then + root.fake_input("key_press" , "Escape") + root.fake_input("key_release", "Escape") + end + if not keygrabber_a_active and not keygrabber_b_active then + return true + end + end, +} +runner.run_steps(steps) + +-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80