From c537a124cf4453900cc0270af5df47d440415c18 Mon Sep 17 00:00:00 2001 From: Jarrod Johnson Date: Tue, 28 Jan 2014 17:11:55 -0500 Subject: [PATCH] Rework get_next_output Use try/except to catch nonetype case. For whatever reason, databuffer could still be None, this should take care of that. --- confluent/consoleserver.py | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/confluent/consoleserver.py b/confluent/consoleserver.py index b0d53a6e..e483d15b 100644 --- a/confluent/consoleserver.py +++ b/confluent/consoleserver.py @@ -142,12 +142,13 @@ class ConsoleSession(object): self.reaper.cancel() currtime = util.monotonic_time() deadline = currtime + 45 - if self.databuffer is None: + try: + while len(self.databuffer) == 0 and currtime < deadline: + timeo = deadline - currtime + self.conshdl._console.wait_for_data(timeout=timeo) + currtime = util.monotonic_time() + except TypeError: return "" - while len(self.databuffer) == 0 and currtime < deadline: - timeo = deadline - currtime - self.conshdl._console.wait_for_data(timeout=timeo) - currtime = util.monotonic_time() retval = self.databuffer self.databuffer = "" self.reaper = eventlet.spawn_after(15, self.destroy)