Make wait_for_entry raise exceptions

Instead of only logging errors when timeout is reached or query for the
entry fails for other reasons, `wait_for_entry` should raise exceptions
so that we can handle them in caller or let them propagate and fail
early.

https://pagure.io/freeipa/issue/6739

Reviewed-By: Martin Basti <mbasti@redhat.com>
Reviewed-By: Alexander Bokovoy <abokovoy@redhat.com>
This commit is contained in:
Martin Babinsky 2017-03-15 13:31:27 +01:00 committed by Martin Basti
parent bd18b5f91e
commit 069948466e

View File

@ -177,7 +177,7 @@ def wait_for_entry(connection, dn, timeout=7200, attr='', quiet=True):
pass # no entry yet pass # no entry yet
except Exception as e: # badness except Exception as e: # badness
root_logger.error("Error reading entry %s: %s", dn, e) root_logger.error("Error reading entry %s: %s", dn, e)
break raise
if not entry: if not entry:
if not quiet: if not quiet:
sys.stdout.write(".") sys.stdout.write(".")
@ -185,13 +185,10 @@ def wait_for_entry(connection, dn, timeout=7200, attr='', quiet=True):
time.sleep(1) time.sleep(1)
if not entry and int(time.time()) > timeout: if not entry and int(time.time()) > timeout:
root_logger.error( raise errors.NotFound(
"wait_for_entry timeout for %s for %s", connection, dn) reason="wait_for_entry timeout for %s for %s" % (connection, dn))
elif entry and not quiet: elif entry and not quiet:
root_logger.error("The waited for entry is: %s", entry) root_logger.error("The waited for entry is: %s", entry)
elif not entry:
root_logger.error(
"Error: could not read entry %s from %s", dn, connection)
class ReplicationManager(object): class ReplicationManager(object):