Merge pull request #2744 from alfunx/multi_keygrabber_test

keygrabber: Add test for multiple instance creation (#2712)
This commit is contained in:
mergify[bot] 2019-04-08 17:58:12 +00:00 committed by GitHub
commit 44e5a497c1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 73 additions and 0 deletions

73
tests/test-keygrabber.lua Normal file
View File

@ -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