Commit 75c330b2 authored by Vincent Pelletier's avatar Vincent Pelletier

Fix infinite loop in test_connectToPrimaryMasterNode.

- test more steps
- fix erroneous assertion
- use a local variable to detect that all handler were executed, rather than a class variable


git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@787 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent 1c569416
...@@ -785,15 +785,40 @@ class ClientApplicationTests(NeoTestBase): ...@@ -785,15 +785,40 @@ class ClientApplicationTests(NeoTestBase):
from neo.master.tests.connector import DoNothingConnector from neo.master.tests.connector import DoNothingConnector
# will raise IndexError at the third iteration # will raise IndexError at the third iteration
app = self.getApp('127.0.0.1:10010 127.0.0.1:10011') app = self.getApp('127.0.0.1:10010 127.0.0.1:10011')
# third iteration : node not ready # TODO: test more connection failure cases
def _waitMessage4(app, conn=None, msg_id=None, handler=None): # Seventh packet : askNodeInformation succeeded
app.local_var.node_ready = False all_passed = []
app.setNodeReady() def _waitMessage8(self, conn=None, msg_id=None, handler=None):
print '_waitMessage8'
all_passed.append(1)
# Sixth packet : askPartitionTable succeeded
def _waitMessage7(self, conn=None, msg_id=None, handler=None):
print '_waitMessage7'
app.pt = Mock({'operational': True}) app.pt = Mock({'operational': True})
Application._waitMessage = _waitMessage8
# fifth packet : request node identification succeeded
def _waitMessage6(self, conn=None, msg_id=None, handler=None):
print '_waitMessage6'
conn.setUUID('D' * 16)
app.uuid = 'C' * 16 app.uuid = 'C' * 16
self.all_passed = True Application._waitMessage = _waitMessage7
# fourth iteration : connection to primary master succeeded
def _waitMessage5(self, conn=None, msg_id=None, handler=None):
print '_waitMessage5'
app.trying_master_node = app.primary_master_node = Mock({
'getServer': ('192.168.1.1', 10000),
'__str__': 'Fake master node',
})
Application._waitMessage = _waitMessage6
# third iteration : node not ready
def _waitMessage4(app, conn=None, msg_id=None, handler=None):
print '_waitMessage4'
app.setNodeNotReady()
app.trying_master_node = None
Application._waitMessage = _waitMessage5
# second iteration : master node changed # second iteration : master node changed
def _waitMessage3(app, conn=None, msg_id=None, handler=None): def _waitMessage3(app, conn=None, msg_id=None, handler=None):
print '_waitMessage3'
app.primary_master_node = Mock({ app.primary_master_node = Mock({
'getServer': ('192.168.1.1', 10000), 'getServer': ('192.168.1.1', 10000),
'__str__': 'Fake master node', '__str__': 'Fake master node',
...@@ -801,10 +826,12 @@ class ClientApplicationTests(NeoTestBase): ...@@ -801,10 +826,12 @@ class ClientApplicationTests(NeoTestBase):
Application._waitMessage = _waitMessage4 Application._waitMessage = _waitMessage4
# first iteration : connection failed # first iteration : connection failed
def _waitMessage2(app, conn=None, msg_id=None, handler=None): def _waitMessage2(app, conn=None, msg_id=None, handler=None):
print '_waitMessage2'
app.trying_master_node = None app.trying_master_node = None
Application._waitMessage = _waitMessage3 Application._waitMessage = _waitMessage3
# do nothing for the first call # do nothing for the first call
def _waitMessage1(app, conn=None, msg_id=None, handler=None): def _waitMessage1(app, conn=None, msg_id=None, handler=None):
print '_waitMessage1'
Application._waitMessage = _waitMessage2 Application._waitMessage = _waitMessage2
_waitMessage_old = Application._waitMessage _waitMessage_old = Application._waitMessage
Application._waitMessage = _waitMessage1 Application._waitMessage = _waitMessage1
...@@ -812,14 +839,13 @@ class ClientApplicationTests(NeoTestBase): ...@@ -812,14 +839,13 @@ class ClientApplicationTests(NeoTestBase):
app.connector_handler = DoNothingConnector app.connector_handler = DoNothingConnector
app.em = Mock({}) app.em = Mock({})
app.pt = Mock({ 'operational': False}) app.pt = Mock({ 'operational': False})
self.all_passed = False
try: try:
app.master_conn = app._connectToPrimaryMasterNode() app.master_conn = app._connectToPrimaryMasterNode()
self.assertEqual(len(all_passed), 1)
self.assertTrue(app.master_conn is not None)
self.assertTrue(app.pt.operational())
finally: finally:
Application._waitMessage = _waitMessage_old Application._waitMessage = _waitMessage_old
self.assertTrue(self.all_passed)
self.assertTrue(app.master_conn, neo.connection.MTClientConnection)
self.assertTrue(app.pt.operational())
def test_askStorage(self): def test_askStorage(self):
""" _askStorage is private but test it anyway """ """ _askStorage is private but test it anyway """
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment