diff options
author | Lance Stout <lancestout@gmail.com> | 2011-03-22 20:48:09 -0400 |
---|---|---|
committer | Lance Stout <lancestout@gmail.com> | 2011-03-22 20:48:09 -0400 |
commit | 756c4c032f820285455c7c57e4925887f9c8e213 (patch) | |
tree | bc964a6c96cdbf9ccf1c8c82a6e9291b4d5f738a /tests | |
parent | e1360ae04946a4b6f9fe7ed19f9349ce24405dd1 (diff) | |
parent | 4b1fadde4bd87a8763131165701c08a3035005eb (diff) | |
download | slixmpp-756c4c032f820285455c7c57e4925887f9c8e213.tar.gz slixmpp-756c4c032f820285455c7c57e4925887f9c8e213.tar.bz2 slixmpp-756c4c032f820285455c7c57e4925887f9c8e213.tar.xz slixmpp-756c4c032f820285455c7c57e4925887f9c8e213.zip |
Merge branch 'develop' into roster
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_stream_xep_0128.py | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/tests/test_stream_xep_0128.py b/tests/test_stream_xep_0128.py new file mode 100644 index 00000000..6fee6556 --- /dev/null +++ b/tests/test_stream_xep_0128.py @@ -0,0 +1,106 @@ +import sys +import time +import threading + +from sleekxmpp.test import * +from sleekxmpp.xmlstream import ElementBase + + +class TestStreamExtendedDisco(SleekTest): + + """ + Test using the XEP-0128 plugin. + """ + + def tearDown(self): + sys.excepthook = sys.__excepthook__ + self.stream_close() + + def testUsingExtendedInfo(self): + self.stream_start(mode='client', + jid='tester@localhost', + plugins=['xep_0030', + 'xep_0004', + 'xep_0128']) + + form = self.xmpp['xep_0004'].makeForm(ftype='result') + form.addField(var='FORM_TYPE', ftype='hidden', value='testing') + + info_ns = 'http://jabber.org/protocol/disco#info' + self.xmpp['xep_0030'].add_identity(node='test', + category='client', + itype='bot') + self.xmpp['xep_0030'].add_feature(node='test', feature=info_ns) + self.xmpp['xep_0128'].set_extended_info(node='test', data=form) + + self.recv(""" + <iq type="get" id="test" to="tester@localhost"> + <query xmlns="http://jabber.org/protocol/disco#info" + node="test" /> + </iq> + """) + + self.send(""" + <iq type="result" id="test"> + <query xmlns="http://jabber.org/protocol/disco#info" + node="test"> + <identity category="client" type="bot" /> + <feature var="http://jabber.org/protocol/disco#info" /> + <x xmlns="jabber:x:data" type="result"> + <field var="FORM_TYPE" type="hidden"> + <value>testing</value> + </field> + </x> + </query> + </iq> + """) + + def testUsingMultipleExtendedInfo(self): + self.stream_start(mode='client', + jid='tester@localhost', + plugins=['xep_0030', + 'xep_0004', + 'xep_0128']) + + form1 = self.xmpp['xep_0004'].makeForm(ftype='result') + form1.addField(var='FORM_TYPE', ftype='hidden', value='testing') + + form2 = self.xmpp['xep_0004'].makeForm(ftype='result') + form2.addField(var='FORM_TYPE', ftype='hidden', value='testing_2') + + info_ns = 'http://jabber.org/protocol/disco#info' + self.xmpp['xep_0030'].add_identity(node='test', + category='client', + itype='bot') + self.xmpp['xep_0030'].add_feature(node='test', feature=info_ns) + self.xmpp['xep_0128'].set_extended_info(node='test', data=[form1, form2]) + + self.recv(""" + <iq type="get" id="test" to="tester@localhost"> + <query xmlns="http://jabber.org/protocol/disco#info" + node="test" /> + </iq> + """) + + self.send(""" + <iq type="result" id="test"> + <query xmlns="http://jabber.org/protocol/disco#info" + node="test"> + <identity category="client" type="bot" /> + <feature var="http://jabber.org/protocol/disco#info" /> + <x xmlns="jabber:x:data" type="result"> + <field var="FORM_TYPE" type="hidden"> + <value>testing</value> + </field> + </x> + <x xmlns="jabber:x:data" type="result"> + <field var="FORM_TYPE" type="hidden"> + <value>testing_2</value> + </field> + </x> + </query> + </iq> + """) + + +suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamExtendedDisco) |