summaryrefslogtreecommitdiff
path: root/tests/test_stanza_xep_0313.py
diff options
context:
space:
mode:
authormathieui <mathieui@mathieui.net>2021-03-09 21:20:14 +0100
committermathieui <mathieui@mathieui.net>2021-03-09 21:20:14 +0100
commit7c86c43fc74dd4786ff741386484b58d1c396e8b (patch)
tree3f6be757fedc9cd515b635643a50e9afd8b20b77 /tests/test_stanza_xep_0313.py
parent8a1f9bec561466008553e3d2e67ad9391f519a0c (diff)
parent0115feaa31ef998b59da98c99c523ad34ed92651 (diff)
downloadslixmpp-7c86c43fc74dd4786ff741386484b58d1c396e8b.tar.gz
slixmpp-7c86c43fc74dd4786ff741386484b58d1c396e8b.tar.bz2
slixmpp-7c86c43fc74dd4786ff741386484b58d1c396e8b.tar.xz
slixmpp-7c86c43fc74dd4786ff741386484b58d1c396e8b.zip
Merge branch 'mam-update' into 'master'
MAM Update See merge request poezio/slixmpp!149
Diffstat (limited to 'tests/test_stanza_xep_0313.py')
-rw-r--r--tests/test_stanza_xep_0313.py105
1 files changed, 105 insertions, 0 deletions
diff --git a/tests/test_stanza_xep_0313.py b/tests/test_stanza_xep_0313.py
new file mode 100644
index 00000000..ac5fcb14
--- /dev/null
+++ b/tests/test_stanza_xep_0313.py
@@ -0,0 +1,105 @@
+import unittest
+from slixmpp import JID, Iq, Message
+from slixmpp.test import SlixTest
+from slixmpp.plugins.xep_0313 import stanza
+from slixmpp.plugins.xep_0004.stanza import Form
+from slixmpp.plugins.xep_0297 import stanza as fstanza
+from slixmpp.plugins.xep_0059 import stanza as rstanza
+from slixmpp.xmlstream import register_stanza_plugin
+
+
+class TestMAM(SlixTest):
+
+ def setUp(self):
+ register_stanza_plugin(stanza.MAM, Form)
+ register_stanza_plugin(Iq, stanza.MAM)
+ register_stanza_plugin(Message, stanza.Result)
+ register_stanza_plugin(Iq, stanza.Fin)
+ register_stanza_plugin(
+ stanza.Result,
+ fstanza.Forwarded
+ )
+ register_stanza_plugin(stanza.MAM, rstanza.Set)
+ register_stanza_plugin(stanza.Fin, rstanza.Set)
+
+ register_stanza_plugin(Iq, stanza.Metadata)
+ register_stanza_plugin(stanza.Metadata, stanza.Start)
+ register_stanza_plugin(stanza.Metadata, stanza.End)
+
+ def testMAMQuery(self):
+ """Test that we can build a simple MAM query."""
+ iq = Iq()
+ iq['type'] = 'set'
+ iq['mam']['queryid'] = 'f27'
+
+ self.check(iq, """
+ <iq type='set'>
+ <query xmlns='urn:xmpp:mam:2' queryid='f27'/>
+ </iq>
+ """)
+
+ def testMAMQueryOptions(self):
+ """Test that we can build a mam query with all options."""
+ iq = Iq()
+ iq['type'] = 'set'
+ iq['mam']['with'] = JID('juliet@capulet.lit')
+ iq['mam']['start'] = '2010-06-07T00:00:00Z'
+ iq['mam']['end'] = '2010-07-07T13:23:54Z'
+ iq['mam']['after_id'] = 'id1'
+ iq['mam']['before_id'] = 'id2'
+ iq['mam']['ids'] = ['a', 'b', 'c']
+
+ self.check(iq, """
+ <iq type='set'>
+ <query xmlns='urn:xmpp:mam:2'>
+ <x xmlns='jabber:x:data' type='submit'>
+ <field var='FORM_TYPE' type='hidden'>
+ <value>urn:xmpp:mam:2</value>
+ </field>
+ <field var='with'>
+ <value>juliet@capulet.lit</value>
+ </field>
+ <field var='start'>
+ <value>2010-06-07T00:00:00Z</value>
+ </field>
+ <field var='end'>
+ <value>2010-07-07T13:23:54Z</value>
+ </field>
+ <field var='after-id'>
+ <value>id1</value>
+ </field>
+ <field var='before-id'>
+ <value>id2</value>
+ </field>
+ <field var='ids'>
+ <value>a</value>
+ <value>b</value>
+ <value>c</value>
+ </field>
+ </x>
+ </query>
+ </iq>
+ """, use_values=False)
+
+ def testMAMMetadata(self):
+ """Test that we can build a MAM metadata payload"""
+
+ iq = Iq()
+ iq['type'] = 'result'
+ iq['mam_metadata']['start']['id'] = 'YWxwaGEg'
+ iq['mam_metadata']['start']['timestamp'] = '2008-08-22T21:09:04Z'
+ iq['mam_metadata']['end']['id'] = 'b21lZ2Eg'
+ iq['mam_metadata']['end']['timestamp'] = '2020-04-20T14:34:21Z'
+
+ self.check(iq, """
+ <iq type='result'>
+ <metadata xmlns='urn:xmpp:mam:2'>
+ <start id='YWxwaGEg' timestamp='2008-08-22T21:09:04Z' />
+ <end id='b21lZ2Eg' timestamp='2020-04-20T14:34:21Z' />
+ </metadata>
+ </iq>
+ """)
+
+
+
+suite = unittest.TestLoader().loadTestsFromTestCase(TestMAM)