From 04cd7c233bf8e7f5894930e4824d1ce7ccf1c52d Mon Sep 17 00:00:00 2001 From: Matt Martz Date: Thu, 10 Apr 2014 10:03:39 -0400 Subject: [PATCH 1/2] Allow search_regex to be used in wait_for with port --- library/utilities/wait_for | 33 ++++++++++++++++++++++++++------- 1 file changed, 26 insertions(+), 7 deletions(-) diff --git a/library/utilities/wait_for b/library/utilities/wait_for index 3a381f0694..f7cb4c6a45 100644 --- a/library/utilities/wait_for +++ b/library/utilities/wait_for @@ -76,9 +76,9 @@ options: version_added: "1.4" required: false description: - - with the path option can be used match a string in the file that must match before continuing. Defaults to a multiline regex. - -notes: [] + - Can be used to match a string in either a file or a socket connection. Defaults to a multiline regex. +notes: + - The ability to use search_regex with a port connection was added in 1.7. requirements: [] author: Jeroen Hoekx, John Jarvis, Andrii Radyk ''' @@ -100,6 +100,9 @@ EXAMPLES = ''' # wait until the process is finished and pid was destroyed - wait_for: path=/proc/3466/status state=absent +# Wait 300 seconds for port 22 to become open and contain "OpenSSH", don't start checking for 10 seconds +- local_action: wait_for port=22 host="{{ inventory_hostname }}" search_regex=OpenSSH delay=10 + ''' def main(): @@ -196,16 +199,32 @@ def main(): s.settimeout(connect_timeout) try: s.connect( (host, port) ) - s.shutdown(socket.SHUT_RDWR) - s.close() - break + if search_regex: + data = '' + matched = False + while 1: + data += s.recv(1024) + if re.search(search_regex, data, re.MULTILINE): + matched = True + break + if matched: + s.shutdown(socket.SHUT_RDWR) + s.close() + break + else: + s.shutdown(socket.SHUT_RDWR) + s.close() + break except: time.sleep(1) pass else: elapsed = datetime.datetime.now() - start if port: - module.fail_json(msg="Timeout when waiting for %s:%s" % (host, port), elapsed=elapsed.seconds) + if search_regex: + module.fail_json(msg="Timeout when waiting for search string %s in %s:%s" % (search_regex, host, port), elapsed=elapsed.seconds) + else: + module.fail_json(msg="Timeout when waiting for %s:%s" % (host, port), elapsed=elapsed.seconds) elif path: if search_regex: module.fail_json(msg="Timeout when waiting for search string %s in %s" % (search_regex, path), elapsed=elapsed.seconds) From eb80bd1a56635233cfbe4e547de222f20bbe13c0 Mon Sep 17 00:00:00 2001 From: James Cammarata Date: Mon, 14 Jul 2014 14:14:13 -0500 Subject: [PATCH 2/2] Break out of loop for sockets in wait_for when there's no data to read --- library/utilities/wait_for | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/library/utilities/wait_for b/library/utilities/wait_for index e8788cb7a7..e87fd566a4 100644 --- a/library/utilities/wait_for +++ b/library/utilities/wait_for @@ -213,7 +213,9 @@ def main(): matched = False while 1: data += s.recv(1024) - if re.search(search_regex, data, re.MULTILINE): + if not data: + break + elif re.search(search_regex, data, re.MULTILINE): matched = True break if matched: