From d3ebaf5d8d574224d08aa65946bec2e914866053 Mon Sep 17 00:00:00 2001 From: Yann Leboulanger <asterix@lagaule.org> Date: Mon, 6 Apr 2009 13:18:56 +0000 Subject: [PATCH] fix test_xmpp_client_nb test unit --- test/test_xmpp_client_nb.py | 31 +++++++++++++++++++++++-------- 1 file changed, 23 insertions(+), 8 deletions(-) diff --git a/test/test_xmpp_client_nb.py b/test/test_xmpp_client_nb.py index b970204175..24a54a3ca9 100644 --- a/test/test_xmpp_client_nb.py +++ b/test/test_xmpp_client_nb.py @@ -13,6 +13,9 @@ from xmpp_mocks import MockConnection, IdleQueueThread from mock import Mock from common.xmpp import client_nb +#import logging +#log = logging.getLogger('gajim') +#log.setLevel(logging.DEBUG) # (XMPP server hostname, c2s port). Script will connect to the machine. xmpp_server_port = ('gajim.org', 5222) @@ -37,7 +40,7 @@ class TestNonBlockingClient(unittest.TestCase): self.client = None - def open_stream(self, server_port): + def open_stream(self, server_port, wrong_pass=False): ''' Method opening the XMPP connection. It returns when <stream:features> is received from server. @@ -46,10 +49,19 @@ class TestNonBlockingClient(unittest.TestCase): connect. ''' + class TempConnection(): + def get_password(self, cb): + if wrong_pass: + cb('wrong pass') + else: + cb(credentials[1]) + def on_connect_failure(self): + pass + self.client = client_nb.NonBlockingClient( domain=server_port[0], idlequeue=self.idlequeue_thread.iq, - caller=Mock()) + caller=Mock(realClass=TempConnection)) self.client.connect( hostname=server_port[0], @@ -86,7 +98,6 @@ class TestNonBlockingClient(unittest.TestCase): Does disconnecting of connected client. Returns when TCP connection is closed. ''' - #self.client.start_disconnect(None, on_disconnect=self.connection.set_event) self.client.RegisterDisconnectHandler(self.connection.set_event) self.client.disconnect() @@ -106,7 +117,7 @@ class TestNonBlockingClient(unittest.TestCase): self.client_auth(credentials[0], credentials[1], credentials[2], sasl=1) self.assert_(self.connection.con) - self.assert_(self.connection.auth=='sasl', msg="Unable to auth via SASL") + self.assert_(self.connection.auth=='sasl', msg='Unable to auth via SASL') self.do_disconnect() @@ -119,8 +130,12 @@ class TestNonBlockingClient(unittest.TestCase): self.assert_(self.client.get_connect_type()) self.client_auth(credentials[0], credentials[1], credentials[2], sasl=0) self.assert_(self.connection.con) - self.assert_(self.connection.auth=='old_auth', - msg="Unable to auth via old_auth") + features = self.client.Dispatcher.Stream.features + if not features.getTag('auth'): + print "Server doesn't support old authentication type, ignoring test" + else: + self.assert_(self.connection.auth=='old_auth', + msg='Unable to auth via old_auth') self.do_disconnect() def test_connect_to_nonexisting_host(self): @@ -143,9 +158,9 @@ class TestNonBlockingClient(unittest.TestCase): ''' Connecting with invalid password. ''' - self.open_stream(xmpp_server_port) + self.open_stream(xmpp_server_port, wrong_pass=True) self.assert_(self.client.get_connect_type()) - self.client_auth(credentials[0], "wrong pass", credentials[2], sasl=1) + self.client_auth(credentials[0], 'wrong pass', credentials[2], sasl=1) self.assert_(self.connection.auth is None) self.do_disconnect() -- GitLab