97 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| '''
 | |
| Module with dummy classes for unit testing of XMPP and related code.
 | |
| '''
 | |
| 
 | |
| import threading, time
 | |
| 
 | |
| from mock import Mock
 | |
| 
 | |
| from common.xmpp import idlequeue
 | |
| 
 | |
| IDLEQUEUE_INTERVAL = 0.2 # polling interval. 200ms is used in Gajim as default
 | |
| IDLEMOCK_TIMEOUT = 30 # how long we wait for an event
 | |
| 
 | |
| class IdleQueueThread(threading.Thread):
 | |
| 	'''
 | |
| 	Thread for regular processing of idlequeue.
 | |
| 	'''
 | |
| 	def __init__(self):
 | |
| 		self.iq = idlequeue.IdleQueue()
 | |
| 		self.stop = threading.Event() # Event to stop the thread main loop.
 | |
| 		self.stop.clear()
 | |
| 		threading.Thread.__init__(self)
 | |
| 	
 | |
| 	def run(self):
 | |
| 		while not self.stop.isSet():
 | |
| 			self.iq.process()
 | |
| 			time.sleep(IDLEQUEUE_INTERVAL)
 | |
| 
 | |
| 	def stop_thread(self):
 | |
| 		self.stop.set()
 | |
| 
 | |
| 	
 | |
| class IdleMock:
 | |
| 	'''
 | |
| 	Serves as template for testing objects that are normally controlled by GUI.
 | |
| 	Allows to wait for asynchronous callbacks with wait() method. 
 | |
| 	'''
 | |
| 	def __init__(self):
 | |
| 		self._event = threading.Event()
 | |
| 		self._event.clear()
 | |
| 
 | |
| 	def wait(self):
 | |
| 		'''
 | |
| 		Block until some callback sets the event and clearing the event
 | |
| 		subsequently. 
 | |
| 		Returns True if event was set, False on timeout
 | |
| 		'''
 | |
| 		self._event.wait(IDLEMOCK_TIMEOUT)
 | |
| 		if self._event.isSet():
 | |
| 			self._event.clear()
 | |
| 			return True
 | |
| 		else:
 | |
| 			return False
 | |
| 
 | |
| 	def set_event(self):
 | |
| 		self._event.set()
 | |
| 
 | |
| 
 | |
| class MockConnection(IdleMock, Mock):
 | |
| 	'''
 | |
| 	Class simulating Connection class from src/common/connection.py
 | |
| 
 | |
| 	It is derived from Mock in order to avoid defining all methods
 | |
| 	from real Connection that are called from NBClient or Dispatcher
 | |
| 	( _event_dispatcher for example)
 | |
| 	'''
 | |
| 
 | |
| 	def __init__(self, *args):
 | |
| 		self.connect_succeeded = True
 | |
| 		IdleMock.__init__(self)
 | |
| 		Mock.__init__(self, *args)
 | |
| 
 | |
| 	def on_connect(self, success, *args):
 | |
| 		'''
 | |
| 		Method called after connecting - after receiving <stream:features>
 | |
| 		from server (NOT after TLS stream restart) or connect failure
 | |
| 		'''
 | |
| 		self.connect_succeeded = success
 | |
| 		self.set_event()
 | |
| 		
 | |
| 
 | |
| 	def on_auth(self, con, auth):
 | |
| 		'''
 | |
| 		Method called after authentication, regardless of the result.
 | |
| 
 | |
| 		:Parameters:
 | |
| 			con : NonBlockingClient
 | |
| 				reference to authenticated object
 | |
| 			auth : string
 | |
| 				type of authetication in case of success ('old_auth', 'sasl') or
 | |
| 				None in case of auth failure
 | |
| 		'''
 | |
| 		self.auth_connection = con
 | |
| 		self.auth = auth
 | |
| 		self.set_event()
 | |
| 
 | |
| # vim: se ts=3:
 |