[rtems-tools commit] tester: Telnet console reopens the connection if it fails or closes.

Chris Johns chrisj at rtems.org
Thu Oct 5 03:24:19 UTC 2017


Module:    rtems-tools
Branch:    master
Commit:    2ae9b6d52b4623a7bffec5290882496e7602c0be
Changeset: http://git.rtems.org/rtems-tools/commit/?id=2ae9b6d52b4623a7bffec5290882496e7602c0be

Author:    Chris Johns <chrisj at rtems.org>
Date:      Thu Oct  5 14:21:33 2017 +1100

tester: Telnet console reopens the connection if it fails or closes.

Some hardware can drop a USB serial enumeration when power is
remove or applied. This changes make the telnet console more
fault tolerant.

---

 tester/rt/telnet.py | 26 ++++++++++++++++++++------
 1 file changed, 20 insertions(+), 6 deletions(-)

diff --git a/tester/rt/telnet.py b/tester/rt/telnet.py
index a7f16cd..74c9e49 100644
--- a/tester/rt/telnet.py
+++ b/tester/rt/telnet.py
@@ -32,6 +32,7 @@
 # RTEMS Testing Consoles
 #
 
+import errno
 import os
 import sys
 import telnetlib
@@ -44,6 +45,7 @@ class tty:
 
     def __init__(self, dev):
         self.dev = dev
+        self.timeout = 5
         self.conn = None
         ds = dev.split(':')
         self.host = ds[0]
@@ -54,12 +56,8 @@ class tty:
                 self.port = int(ds[1])
             except:
                 raise error.general('invalid port: %s' % (dev))
-        try:
-            self.conn = telnetlib.Telnet(self.host, self.port, 5)
-        except IOError as ioe:
-            raise error.general('opening telnet dev: %s: %s' % (dev, ioe))
-        except:
-            raise error.general('opening telnet dev: %s: unknown' % (dev))
+        self.conn = telnetlib.Telnet()
+        self._reopen()
 
     def __del__(self):
         if self.conn:
@@ -72,6 +70,14 @@ class tty:
         s = 'host: %s port: %d' % ((self.host, self.port))
         return s
 
+    def _reopen(self):
+        try:
+            self.conn.open(self.host, self.port, self.timeout)
+        except IOError as ioe:
+            raise error.general('opening telnet dev: %s: %s' % (dev, ioe))
+        except:
+            raise error.general('opening telnet dev: %s: unknown' % (dev))
+
     def off(self):
         self.is_on = False
 
@@ -82,10 +88,18 @@ class tty:
         pass
 
     def read(self):
+        reopen = False
         try:
             data = self.conn.read_very_eager()
+        except IOError as ioe:
+            if ioe.errno == errno.ECONNREFUSED:
+                reopen = True
+            data = ''
         except EOFError:
+            reopen = True
             data = ''
+        if reopen:
+            self._reopen()
         return data
 
 if __name__ == "__main__":




More information about the vc mailing list