test-naughty-legacy: Use GDBus instead of spawning dbus-send
This is inspired to be a correctness fix: The "hints" argument to notifications is supposed to have type a{sv}, i.e. this maps from string keys to some generic value. dbus-send does not support this and instead it sends an argument of type a{ss}, i.e. a mapping from string to string. This commit fixes this problem and uses the correct type. Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
parent
2d0a35c37d
commit
828ce1471e
|
@ -5,13 +5,35 @@ local naughty = require("naughty" )
|
||||||
local gdebug = require("gears.debug")
|
local gdebug = require("gears.debug")
|
||||||
local cairo = require("lgi" ).cairo
|
local cairo = require("lgi" ).cairo
|
||||||
local beautiful = require("beautiful")
|
local beautiful = require("beautiful")
|
||||||
|
local Gio = require("lgi" ).Gio
|
||||||
|
local GLib = require("lgi" ).GLib
|
||||||
|
|
||||||
-- This module test deprecated APIs
|
-- This module test deprecated APIs
|
||||||
require("gears.debug").deprecate = function() end
|
require("gears.debug").deprecate = function() end
|
||||||
|
|
||||||
|
local dbus_connection = assert(Gio.bus_get_sync(Gio.BusType.SESSION))
|
||||||
|
|
||||||
|
local function send_notify(app, id, icon, summary, body, actions, hints, timeout, callback)
|
||||||
|
local parameters = GLib.Variant("(susssasa{sv}i)", {
|
||||||
|
app, id, icon, summary, body, actions, hints, timeout
|
||||||
|
})
|
||||||
|
local reply_type = GLib.VariantType.new("(u)")
|
||||||
|
|
||||||
|
local function invoke_callback(conn, result)
|
||||||
|
local new_id = conn:call_finish(result).value[1]
|
||||||
|
if callback then
|
||||||
|
callback(new_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
dbus_connection:call("org.freedesktop.Notifications",
|
||||||
|
"/org/freedesktop/Notifications", "org.freedesktop.Notifications",
|
||||||
|
"Notify", parameters, reply_type, Gio.DBusCallFlags.NO_AUTO_START, -1,
|
||||||
|
nil, invoke_callback)
|
||||||
|
end
|
||||||
|
|
||||||
local steps = {}
|
local steps = {}
|
||||||
|
|
||||||
local has_cmd_notify, has_cmd_send = false
|
local has_cmd_notify = false
|
||||||
|
|
||||||
-- Use `notify-send` instead of the shimmed version to better test the dbus
|
-- Use `notify-send` instead of the shimmed version to better test the dbus
|
||||||
-- to notification code.
|
-- to notification code.
|
||||||
|
@ -30,25 +52,12 @@ local function check_cmd()
|
||||||
has_cmd_notify = true
|
has_cmd_notify = true
|
||||||
end
|
end
|
||||||
|
|
||||||
f = io.open(p.."dbus-send")
|
if has_cmd_notify then return end
|
||||||
if f then
|
|
||||||
f:close()
|
|
||||||
has_cmd_send = true
|
|
||||||
end
|
|
||||||
|
|
||||||
if has_cmd_notify and has_cmd_send then return end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
check_cmd()
|
check_cmd()
|
||||||
|
|
||||||
-- Can't test anything of value the documentation example tests don't already
|
|
||||||
-- hit.
|
|
||||||
if not has_cmd_send then
|
|
||||||
require("gears.debug").print_warning("Did not find dbus-send, skipping test")
|
|
||||||
require("_runner").run_steps {}
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if not has_cmd_notify then
|
if not has_cmd_notify then
|
||||||
require("gears.debug").print_warning("Did not find notify-send, skipping some tests")
|
require("gears.debug").print_warning("Did not find notify-send, skipping some tests")
|
||||||
end
|
end
|
||||||
|
@ -564,119 +573,87 @@ table.insert(steps, function()
|
||||||
end)
|
end)
|
||||||
|
|
||||||
-- Test more advanced features than what notify-send can provide.
|
-- Test more advanced features than what notify-send can provide.
|
||||||
if has_cmd_send then
|
|
||||||
|
|
||||||
local cmd = { 'dbus-send',
|
-- Test the actions.
|
||||||
'--type=method_call',
|
table.insert(steps, function()
|
||||||
'--print-reply=literal',
|
|
||||||
'--dest=org.freedesktop.Notifications',
|
|
||||||
'/org/freedesktop/Notifications',
|
|
||||||
'org.freedesktop.Notifications.Notify',
|
|
||||||
'string:"Awesome test"',
|
|
||||||
'uint32:0',
|
|
||||||
'string:""',
|
|
||||||
'string:"title"',
|
|
||||||
'string:"message body"',
|
|
||||||
'array:string:1,one,2,two,3,three',
|
|
||||||
'dict:string:string:"",""',
|
|
||||||
'int32:25000'
|
|
||||||
}
|
|
||||||
|
|
||||||
-- Test the actions.
|
assert(#active == 0)
|
||||||
table.insert(steps, function()
|
|
||||||
|
|
||||||
assert(#active == 0)
|
send_notify("Awesome test", 0, "", "title", "message body",
|
||||||
|
{ "1", "one", "2", "two", "3", "three" }, {}, 25000)
|
||||||
|
|
||||||
spawn(cmd)
|
return true
|
||||||
|
end)
|
||||||
|
|
||||||
return true
|
table.insert(steps, function()
|
||||||
end)
|
if #active == 0 then return end
|
||||||
|
|
||||||
table.insert(steps, function()
|
assert(#active == 1)
|
||||||
if #active == 0 then return end
|
local n = active[1]
|
||||||
|
|
||||||
assert(#active == 1)
|
assert(n.box)
|
||||||
local n = active[1]
|
assert(#n.actions == 3)
|
||||||
|
assert(n.actions[1].name == "one" )
|
||||||
|
assert(n.actions[2].name == "two" )
|
||||||
|
assert(n.actions[3].name == "three")
|
||||||
|
|
||||||
assert(n.box)
|
n:destroy()
|
||||||
assert(#n.actions == 3)
|
|
||||||
assert(n.actions[1].name == "one" )
|
|
||||||
assert(n.actions[2].name == "two" )
|
|
||||||
assert(n.actions[3].name == "three")
|
|
||||||
|
|
||||||
n:destroy()
|
return true
|
||||||
|
end)
|
||||||
|
|
||||||
return true
|
--TODO Test too many actions.
|
||||||
end)
|
|
||||||
|
|
||||||
--TODO Test too many actions.
|
--TODO Test action with long names.
|
||||||
|
|
||||||
--TODO Test action with long names.
|
local nid, name_u, message_u, actions_u = nil
|
||||||
|
|
||||||
local nid, name_u, message_u, actions_u = nil
|
-- Test updating a notification.
|
||||||
|
table.insert(steps, function()
|
||||||
-- Test updating a notification.
|
send_notify("Awesome test", 0, "", "title", "message body",
|
||||||
table.insert(steps, function()
|
{ "1", "one", "2", "two", "3", "three" }, {}, 25000, function(id)
|
||||||
spawn.easy_async(cmd, function(out)
|
nid = id
|
||||||
nid = tonumber(out:match(" [0-9]+"):match("[0-9]+"))
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
return true
|
return true
|
||||||
end)
|
end)
|
||||||
|
|
||||||
table.insert(steps, function()
|
table.insert(steps, function()
|
||||||
if #active == 0 or not nid then return end
|
if #active == 0 or not nid then return end
|
||||||
|
|
||||||
local n = active[1]
|
local n = active[1]
|
||||||
|
|
||||||
n:connect_signal("property::title" , function() name_u = true end)
|
n:connect_signal("property::title" , function() name_u = true end)
|
||||||
n:connect_signal("property::message", function() message_u = true end)
|
n:connect_signal("property::message", function() message_u = true end)
|
||||||
n:connect_signal("property::actions", function() actions_u = true end)
|
n:connect_signal("property::actions", function() actions_u = true end)
|
||||||
|
|
||||||
local update = { 'dbus-send',
|
send_notify("Awesome test", nid, "", "updated title", "updated message body",
|
||||||
'--type=method_call',
|
{ "1", "four", "2", "five", "3", "six" }, {}, 25000)
|
||||||
'--print-reply=literal',
|
|
||||||
'--dest=org.freedesktop.Notifications',
|
|
||||||
'/org/freedesktop/Notifications',
|
|
||||||
'org.freedesktop.Notifications.Notify',
|
|
||||||
'string:"Awesome test"',
|
|
||||||
'uint32:' .. nid,
|
|
||||||
'string:""',
|
|
||||||
'string:updated title',
|
|
||||||
'string:updated message body',
|
|
||||||
'array:string:1,four,2,five,3,six',
|
|
||||||
'dict:string:string:"",""',
|
|
||||||
'int32:25000',
|
|
||||||
}
|
|
||||||
|
|
||||||
spawn(update)
|
return true
|
||||||
|
end)
|
||||||
|
|
||||||
return true
|
-- Test if all properties have been updated.
|
||||||
end)
|
table.insert(steps, function()
|
||||||
|
if not name_u then return end
|
||||||
|
if not message_u then return end
|
||||||
|
if not actions_u then return end
|
||||||
|
|
||||||
-- Test if all properties have been updated.
|
-- No new notification should have been created.
|
||||||
table.insert(steps, function()
|
assert(#active == 1)
|
||||||
if not name_u then return end
|
|
||||||
if not message_u then return end
|
|
||||||
if not actions_u then return end
|
|
||||||
|
|
||||||
-- No new notification should have been created.
|
local n = active[1]
|
||||||
assert(#active == 1)
|
|
||||||
|
|
||||||
local n = active[1]
|
assert(n.title == "updated title" )
|
||||||
|
assert(n.message == "updated message body")
|
||||||
|
|
||||||
assert(n.title == "updated title" )
|
assert(#n.actions == 3)
|
||||||
assert(n.message == "updated message body")
|
assert(n.actions[1].name == "four" )
|
||||||
|
assert(n.actions[2].name == "five" )
|
||||||
|
assert(n.actions[3].name == "six" )
|
||||||
|
|
||||||
assert(#n.actions == 3)
|
return true
|
||||||
assert(n.actions[1].name == "four" )
|
end)
|
||||||
assert(n.actions[2].name == "five" )
|
|
||||||
assert(n.actions[3].name == "six" )
|
|
||||||
|
|
||||||
return true
|
|
||||||
end)
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Now check if the old deprecated (but still supported) APIs don't have errors.
|
-- Now check if the old deprecated (but still supported) APIs don't have errors.
|
||||||
table.insert(steps, function()
|
table.insert(steps, function()
|
||||||
|
|
Loading…
Reference in New Issue