Merge branch 'xep-0439-improved' into 'master'
XEP-0439: add events & tests See merge request poezio/slixmpp!82
This commit is contained in:
commit
c892fba778
2 changed files with 96 additions and 5 deletions
59
itests/test_quickresponse.py
Normal file
59
itests/test_quickresponse.py
Normal file
|
@ -0,0 +1,59 @@
|
|||
import unittest
|
||||
from slixmpp.test.integration import SlixIntegration
|
||||
from slixmpp.plugins.xep_0439 import stanza
|
||||
|
||||
|
||||
class TestQuickResponse(SlixIntegration):
|
||||
async def asyncSetUp(self):
|
||||
self.add_client(
|
||||
self.envjid('CI_ACCOUNT1'),
|
||||
self.envstr('CI_ACCOUNT1_PASSWORD'),
|
||||
)
|
||||
self.add_client(
|
||||
self.envjid('CI_ACCOUNT2'),
|
||||
self.envstr('CI_ACCOUNT2_PASSWORD'),
|
||||
)
|
||||
self.register_plugins(['xep_0439'])
|
||||
await self.connect_clients()
|
||||
|
||||
async def test_quickresponse(self):
|
||||
"""Send and receive actions and responses"""
|
||||
actions = [
|
||||
('id1', 'Action 1'),
|
||||
('id2', 'Action 2'),
|
||||
]
|
||||
self.clients[0]['xep_0439'].ask_for_actions(
|
||||
self.clients[1].boundjid.full,
|
||||
"Action 1 or 2 ?",
|
||||
actions
|
||||
)
|
||||
msg = await self.clients[1].wait_until('action_received')
|
||||
actions_recv = [
|
||||
(st['id'], st['label']) for st in msg if isinstance(st, stanza.Action)
|
||||
]
|
||||
self.assertEqual(
|
||||
actions,
|
||||
actions_recv,
|
||||
)
|
||||
|
||||
reply = self.clients[1].make_message(
|
||||
mto=self.clients[0].boundjid.full
|
||||
)
|
||||
reply['action_selected']['id'] = 'id1'
|
||||
reply.send()
|
||||
|
||||
reply_recv = await self.clients[0].wait_until('action_selected')
|
||||
self.assertEqual(
|
||||
reply_recv['action_selected']['id'],
|
||||
'id1',
|
||||
)
|
||||
|
||||
self.clients[0]['xep_0439'].ask_for_response(
|
||||
self.clients[1].boundjid.full,
|
||||
"Reply with action 1 or 2 (id1/id2) ?",
|
||||
actions
|
||||
)
|
||||
msg = await self.clients[1].wait_until('responses_received')
|
||||
|
||||
|
||||
suite = unittest.TestLoader().loadTestsFromTestCase(TestQuickResponse)
|
|
@ -11,9 +11,12 @@ from typing import (
|
|||
Tuple,
|
||||
)
|
||||
|
||||
from slixmpp import JID
|
||||
from slixmpp import JID, Message
|
||||
from slixmpp.plugins import BasePlugin
|
||||
from slixmpp.plugins.xep_0439 import stanza
|
||||
from slixmpp.xmlstream.matcher import StanzaPath
|
||||
from slixmpp.xmlstream.handler import Callback
|
||||
|
||||
|
||||
|
||||
class XEP_0439(BasePlugin):
|
||||
|
@ -27,8 +30,37 @@ class XEP_0439(BasePlugin):
|
|||
|
||||
def plugin_init(self) -> None:
|
||||
stanza.register_plugins()
|
||||
self.xmpp.register_handler(Callback(
|
||||
'Action received',
|
||||
StanzaPath('message/action'),
|
||||
self._handle_action,
|
||||
))
|
||||
self.xmpp.register_handler(Callback(
|
||||
'Response received',
|
||||
StanzaPath('message/response'),
|
||||
self._handle_response,
|
||||
))
|
||||
self.xmpp.register_handler(Callback(
|
||||
'ActionSelected received',
|
||||
StanzaPath('message/action_selected'),
|
||||
self._handle_action_selected,
|
||||
))
|
||||
|
||||
def ask_for_responses(self, mto: JID, body: str,
|
||||
def plugin_send(self):
|
||||
self.xmpp.remove_handler('Action received')
|
||||
self.xmpp.remove_handler('Response received')
|
||||
self.xmpp.remove_handler('ActionSelected received')
|
||||
|
||||
def _handle_response(self, msg: Message):
|
||||
self.xmpp.event('responses_received', msg)
|
||||
|
||||
def _handle_action(self, msg: Message):
|
||||
self.xmpp.event('action_received', msg)
|
||||
|
||||
def _handle_action_selected(self, msg: Message):
|
||||
self.xmpp.event('action_selected', msg)
|
||||
|
||||
def ask_for_response(self, mto: JID, body: str,
|
||||
responses: Iterable[Tuple[str, str]],
|
||||
mtype: str = 'chat', lang: Optional[str] = None, *,
|
||||
mfrom: Optional[JID] = None):
|
||||
|
|
Loading…
Reference in a new issue