Software /
code /
prosody
File
spec/scansion/basic_message.scs @ 10486:479e96e554c8
net.server_epoll: Add debug logging for delayed reading
In :onreadable, if there is still buffered incoming data after reading
from the socket (as indicated by the :dirty method, usually because
LuaSocket has an 8k buffer that's full but it read a smaller amount),
another attempt to read is scheduled via this :pausefor method. This is
also called from some other places where it would be pointless to read
because there shouldn't be any data.
In the delayed read case, this should report that the socket is "dirty".
If it reports that the socket is "clean" then the question is where
the buffer contents went?
If this doesn't get logged after the scheduled time (0.000001s by
default) then this would suggests a problem with timer or scheduling.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sat, 07 Dec 2019 19:05:10 +0100 |
parent | 9291:329a670ae975 |
child | 10515:35bf3b80480f |
line wrap: on
line source
# Basic message routing and delivery [Client] Romeo jid: user@localhost password: password [Client] Juliet jid: juliet@localhost password: password [Client] Juliet's phone jid: juliet@localhost password: password resource: mobile --------- # Act 1, scene 1 # The clients connect Romeo connects Juliet connects Juliet's phone connects # Romeo publishes his presence. Juliet has not, and so does not receive presence. Romeo sends: <presence/> Romeo receives: <presence from="${Romeo's full JID}" /> # Romeo sends a message to Juliet's full JID Romeo sends: <message to="${Juliet's full JID}" type="chat"> <body>Hello Juliet!</body> </message> Juliet receives: <message to="${Juliet's full JID}" from="${Romeo's full JID}" type="chat"> <body>Hello Juliet!</body> </message> # Romeo sends a message to Juliet's phone Romeo sends: <message to="${Juliet's phone's full JID}" type="chat"> <body>Hello Juliet, on your phone.</body> </message> Juliet's phone receives: <message to="${Juliet's phone's full JID}" from="${Romeo's full JID}" type="chat"> <body>Hello Juliet, on your phone.</body> </message> # Scene 2 # This requires the server to support offline messages (which is optional). # Romeo sends a message to Juliet's bare JID. This is not immediately delivered, as she # has not published presence on either of her resources. Romeo sends: <message to="juliet@localhost" type="chat"> <body>Hello Juliet, are you there?</body> </message> # Juliet sends presence on her phone, and should receive the message there Juliet's phone sends: <presence/> Juliet's phone receives: <presence/> Juliet's phone receives: <message from="${Romeo's full JID}" type="chat"> <body>Hello Juliet, are you there?</body> <delay xmlns='urn:xmpp:delay' from='localhost' stamp='{scansion:any}' /> </message> # Romeo sends another bare-JID message, it should be delivered # instantly to Juliet's phone Romeo sends: <message to="juliet@localhost" type="chat"> <body>Oh, hi!</body> </message> Juliet's phone receives: <message from="${Romeo's full JID}" type="chat"> <body>Oh, hi!</body> </message> # Juliet's laptop goes online, but with a negative priority Juliet sends: <presence> <priority>-1</priority> </presence> Juliet receives: <presence from="${Juliet's full JID}"> <priority>-1</priority> </presence> Juliet's phone receives: <presence from="${Juliet's full JID}"> <priority>-1</priority> </presence> # Again, Romeo sends a message to her bare JID, but it should # only get delivered to her phone: Romeo sends: <message to="juliet@localhost" type="chat"> <body>How are you?</body> </message> Juliet's phone receives: <message from="${Romeo's full JID}" type="chat"> <body>How are you?</body> </message> # Romeo sends direct to Juliet's full JID, and she should receive it Romeo sends: <message to="${Juliet's full JID}" type="chat"> <body>Are you hiding?</body> </message> Juliet receives: <message from="${Romeo's full JID}" type="chat"> <body>Are you hiding?</body> </message> # Juliet publishes non-negative presence Juliet sends: <presence/> Juliet receives: <presence from="${Juliet's full JID}"/> Juliet's phone receives: <presence from="${Juliet's full JID}"/> # And now Romeo's bare JID messages get delivered to both resources # (server behaviour may vary here) Romeo sends: <message to="juliet@localhost" type="chat"> <body>There!</body> </message> Juliet receives: <message from="${Romeo's full JID}" type="chat"> <body>There!</body> </message> Juliet's phone receives: <message from="${Romeo's full JID}" type="chat"> <body>There!</body> </message> # The End Romeo disconnects Juliet disconnects Juliet's phone disconnects