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,
|
Tuple,
|
||||||
)
|
)
|
||||||
|
|
||||||
from slixmpp import JID
|
from slixmpp import JID, Message
|
||||||
from slixmpp.plugins import BasePlugin
|
from slixmpp.plugins import BasePlugin
|
||||||
from slixmpp.plugins.xep_0439 import stanza
|
from slixmpp.plugins.xep_0439 import stanza
|
||||||
|
from slixmpp.xmlstream.matcher import StanzaPath
|
||||||
|
from slixmpp.xmlstream.handler import Callback
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class XEP_0439(BasePlugin):
|
class XEP_0439(BasePlugin):
|
||||||
|
@ -27,8 +30,37 @@ class XEP_0439(BasePlugin):
|
||||||
|
|
||||||
def plugin_init(self) -> None:
|
def plugin_init(self) -> None:
|
||||||
stanza.register_plugins()
|
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]],
|
responses: Iterable[Tuple[str, str]],
|
||||||
mtype: str = 'chat', lang: Optional[str] = None, *,
|
mtype: str = 'chat', lang: Optional[str] = None, *,
|
||||||
mfrom: Optional[JID] = None):
|
mfrom: Optional[JID] = None):
|
||||||
|
|
Loading…
Reference in a new issue