Merge branch 'more-tests' into 'master'
Add more integration tests See merge request poezio/slixmpp!78
This commit is contained in:
commit
c0acb7e34f
9 changed files with 210 additions and 4 deletions
33
itests/test_disco.py
Normal file
33
itests/test_disco.py
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
import unittest
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
|
||||||
|
|
||||||
|
class TestDisco(SlixIntegration):
|
||||||
|
async def asyncSetUp(self):
|
||||||
|
await super().asyncSetUp()
|
||||||
|
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_0030'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_features(self):
|
||||||
|
"""Check we can add, get and delete a feature"""
|
||||||
|
self.clients[0]['xep_0030'].add_feature('urn:xmpp:fake:0')
|
||||||
|
info = await self.clients[1]['xep_0030'].get_info(
|
||||||
|
self.clients[0].boundjid.full
|
||||||
|
)
|
||||||
|
self.assertIn('urn:xmpp:fake:0', info['disco_info']['features'])
|
||||||
|
self.clients[0]['xep_0030'].del_feature(feature='urn:xmpp:fake:0')
|
||||||
|
info = await self.clients[1]['xep_0030'].get_info(
|
||||||
|
self.clients[0].boundjid.full
|
||||||
|
)
|
||||||
|
self.assertNotIn('urn:xmpp:fake:0', info['disco_info']['features'])
|
||||||
|
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestDisco)
|
55
itests/test_mam.py
Normal file
55
itests/test_mam.py
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
import unittest
|
||||||
|
from random import randint
|
||||||
|
from slixmpp import JID
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
|
||||||
|
|
||||||
|
class TestMAM(SlixIntegration):
|
||||||
|
async def asyncSetUp(self):
|
||||||
|
await super().asyncSetUp()
|
||||||
|
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_0313'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_mam_retrieve(self):
|
||||||
|
"""Make sure we can get messages from our archive"""
|
||||||
|
# send messages first
|
||||||
|
tok = randint(1, 999999)
|
||||||
|
self.clients[0].make_message(mto=self.clients[1].boundjid, mbody='coucou').send()
|
||||||
|
await self.clients[1].wait_until('message')
|
||||||
|
self.clients[1].make_message(
|
||||||
|
mto=self.clients[0].boundjid,
|
||||||
|
mbody='coucou coucou %s' % tok,
|
||||||
|
).send()
|
||||||
|
await self.clients[0].wait_until('message')
|
||||||
|
|
||||||
|
# Get archive
|
||||||
|
retrieve = self.clients[0]['xep_0313'].retrieve(
|
||||||
|
with_jid=JID(self.envjid('CI_ACCOUNT2')),
|
||||||
|
iterator=True,
|
||||||
|
reverse=True,
|
||||||
|
rsm={'max': 2}
|
||||||
|
)
|
||||||
|
msgs = []
|
||||||
|
count = 0
|
||||||
|
async for rsm in retrieve:
|
||||||
|
for msg in rsm['mam']['results']:
|
||||||
|
msgs.append(
|
||||||
|
msg['mam_result']['forwarded']['stanza']
|
||||||
|
)
|
||||||
|
count += 1
|
||||||
|
if count >= 2:
|
||||||
|
break
|
||||||
|
|
||||||
|
self.assertEqual(msgs[0]['body'], 'coucou')
|
||||||
|
self.assertEqual(msgs[1]['body'], 'coucou coucou %s' % tok)
|
||||||
|
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestMAM)
|
|
@ -7,7 +7,7 @@ from slixmpp.test.integration import SlixIntegration
|
||||||
UNIQUE = uuid4().hex
|
UNIQUE = uuid4().hex
|
||||||
|
|
||||||
|
|
||||||
class TestConnect(SlixIntegration):
|
class TestMUC(SlixIntegration):
|
||||||
|
|
||||||
async def asyncSetUp(self):
|
async def asyncSetUp(self):
|
||||||
self.mucserver = self.envjid('CI_MUC_SERVER')
|
self.mucserver = self.envjid('CI_MUC_SERVER')
|
||||||
|
@ -75,4 +75,4 @@ class TestConnect(SlixIntegration):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
suite = unittest.TestLoader().loadTestsFromTestCase(TestConnect)
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestMUC)
|
||||||
|
|
21
itests/test_ping.py
Normal file
21
itests/test_ping.py
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
import unittest
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
|
||||||
|
|
||||||
|
class TestPing(SlixIntegration):
|
||||||
|
async def asyncSetUp(self):
|
||||||
|
await super().asyncSetUp()
|
||||||
|
self.add_client(
|
||||||
|
self.envjid('CI_ACCOUNT1'),
|
||||||
|
self.envstr('CI_ACCOUNT1_PASSWORD'),
|
||||||
|
)
|
||||||
|
self.register_plugins(['xep_0199'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_ping(self):
|
||||||
|
"""Check we can ping our own server"""
|
||||||
|
rtt = await self.clients[0]['xep_0199'].ping()
|
||||||
|
self.assertGreater(10, rtt)
|
||||||
|
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestPing)
|
35
itests/test_privatestorage.py
Normal file
35
itests/test_privatestorage.py
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
import unittest
|
||||||
|
from slixmpp import ET
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
from slixmpp.plugins.xep_0048.stanza import Bookmarks
|
||||||
|
|
||||||
|
|
||||||
|
class TestPrivateStorage(SlixIntegration):
|
||||||
|
async def asyncSetUp(self):
|
||||||
|
self.add_client(
|
||||||
|
self.envjid('CI_ACCOUNT1'),
|
||||||
|
self.envstr('CI_ACCOUNT1_PASSWORD'),
|
||||||
|
)
|
||||||
|
self.register_plugins(['xep_0048', 'xep_0049'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_privatestorage(self):
|
||||||
|
"""Check we can set, get, and delete private in xml storage"""
|
||||||
|
# Set a bookmark using private storage
|
||||||
|
el = Bookmarks()
|
||||||
|
el.add_conference('test@example.com', 'toto')
|
||||||
|
await self.clients[0]['xep_0049'].store(
|
||||||
|
el,
|
||||||
|
)
|
||||||
|
result = await self.clients[0]['xep_0049'].retrieve('bookmarks')
|
||||||
|
self.assertEqual(str(result['private']['bookmarks']), str(el))
|
||||||
|
|
||||||
|
# Purge bookmarks
|
||||||
|
await self.clients[0]['xep_0049'].store(
|
||||||
|
Bookmarks(),
|
||||||
|
)
|
||||||
|
result = await self.clients[0]['xep_0049'].retrieve('bookmarks')
|
||||||
|
self.assertEqual(result['private']['bookmarks'], Bookmarks())
|
||||||
|
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestPrivateStorage)
|
32
itests/test_reactions.py
Normal file
32
itests/test_reactions.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import unittest
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
|
||||||
|
|
||||||
|
class TestReactions(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_0444'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_send_reaction(self):
|
||||||
|
"""Make sure we can send and receive reactions"""
|
||||||
|
self.clients[0]['xep_0444'].send_reactions(
|
||||||
|
self.clients[1].boundjid.full,
|
||||||
|
to_id='toto',
|
||||||
|
reactions=['🦙', '🦦'],
|
||||||
|
)
|
||||||
|
msg = await self.clients[1].wait_until('reactions')
|
||||||
|
self.assertEqual(
|
||||||
|
msg['reactions'].get_values(),
|
||||||
|
{'🦙', '🦦'},
|
||||||
|
)
|
||||||
|
self.assertEqual(msg['reactions']['id'], 'toto')
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestReactions)
|
29
itests/test_retract.py
Normal file
29
itests/test_retract.py
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import unittest
|
||||||
|
from slixmpp.test.integration import SlixIntegration
|
||||||
|
|
||||||
|
|
||||||
|
class TestRetract(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_0424'])
|
||||||
|
await self.connect_clients()
|
||||||
|
|
||||||
|
async def test_retract_msg(self):
|
||||||
|
"""Try to retract a message"""
|
||||||
|
self.clients[0]['xep_0424'].send_retraction(
|
||||||
|
self.clients[1].boundjid.full,
|
||||||
|
id='toto',
|
||||||
|
fallback_text='Twas a mistake',
|
||||||
|
)
|
||||||
|
msg = await self.clients[1].wait_until('message')
|
||||||
|
self.assertEqual(msg['apply_to']['id'], 'toto')
|
||||||
|
self.assertTrue(msg['apply_to']['retract'])
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestRetract)
|
|
@ -38,7 +38,7 @@ class XEP_0444(BasePlugin):
|
||||||
|
|
||||||
def plugin_end(self):
|
def plugin_end(self):
|
||||||
self.xmpp.remove_handler('Reaction received')
|
self.xmpp.remove_handler('Reaction received')
|
||||||
self.xmpp['xep_0030'].del_feature(stanza.NS)
|
self.xmpp['xep_0030'].del_feature(feature=stanza.NS)
|
||||||
|
|
||||||
def _handle_reactions(self, message: Message):
|
def _handle_reactions(self, message: Message):
|
||||||
self.xmpp.event('reactions', message)
|
self.xmpp.event('reactions', message)
|
||||||
|
|
|
@ -53,7 +53,8 @@ class SlixIntegration(IsolatedAsyncioTestCase):
|
||||||
"""Connect all clients"""
|
"""Connect all clients"""
|
||||||
for client in self.clients:
|
for client in self.clients:
|
||||||
client.connect()
|
client.connect()
|
||||||
await client.wait_until('session_start')
|
wait = [client.wait_until('session_start') for client in self.clients]
|
||||||
|
await asyncio.gather(*wait)
|
||||||
|
|
||||||
async def _destroy(self):
|
async def _destroy(self):
|
||||||
"""Kill all clients"""
|
"""Kill all clients"""
|
||||||
|
|
Loading…
Reference in a new issue