diff options
author | Matthew Wild <mwild1@gmail.com> | 2008-11-20 22:42:37 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2008-11-20 22:42:37 +0000 |
commit | 902d98e4865d92ebeea81c0ddcb5a38fa63d1162 (patch) | |
tree | 82053f3c9b53fde238429318e586d7d815c7639c /plugins/mod_selftests.lua | |
parent | 08f20e796a3f8e94eabccd8215abe1b402b6203a (diff) | |
download | prosody-902d98e4865d92ebeea81c0ddcb5a38fa63d1162.tar.gz prosody-902d98e4865d92ebeea81c0ddcb5a38fa63d1162.zip |
Adding selftests module, but not enabling in config
Diffstat (limited to 'plugins/mod_selftests.lua')
-rw-r--r-- | plugins/mod_selftests.lua | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/plugins/mod_selftests.lua b/plugins/mod_selftests.lua new file mode 100644 index 00000000..fe09e529 --- /dev/null +++ b/plugins/mod_selftests.lua @@ -0,0 +1,57 @@ + +local st = require "util.stanza"; +local register_component = require "core.componentmanager".register_component; +local core_route_stanza = core_route_stanza; +local socket = require "socket"; + +local open_pings = {}; + +local t_insert = table.insert; + +local log = require "util.logger".init("mod_selftests"); + +local tests_jid, host; "self_tests@getjabber.ath.cx"; +local host = "getjabber.ath.cx"; + +if not (tests_jid and host) then + for currhost in pairs(host) do + if currhost ~= "localhost" then + tests_jid, host = "self_tests@"..currhost, currhost; + end + end +end + +if tests_jid and host then + local bot = register_component(tests_jid, function(origin, stanza, ourhost) + local time = open_pings[stanza.attr.id]; + + if time then + log("info", "Ping reply from %s in %fs", tostring(stanza.attr.from), socket.gettime() - time); + else + log("info", "Unexpected reply: %s", stanza:pretty_print()); + end + end); + + + local our_origin = hosts[host]; + add_event_hook("server-started", + function () + local id = st.new_id(); + local ping_attr = { xmlns = 'urn:xmpp:ping' }; + local function send_ping(to) + log("info", "Sending ping to %s", to); + core_route_stanza(our_origin, st.iq{ to = to, from = tests_jid, id = id, type = "get" }:tag("ping", ping_attr)); + open_pings[id] = socket.gettime(); + end + + send_ping "matthewwild.co.uk" + send_ping "snikket.com" + send_ping "gmail.com" + send_ping "isode.com" + send_ping "jabber.org" + send_ping "chrome.pl" + send_ping "swissjabber.ch" + send_ping "soapbox.net" + send_ping "jabber.ccc.de" + end); +end |