Commit 1245aa79 authored by Ian Fischer's avatar Ian Fischer

Correctly handle logging when devices are disconnected or logging processes otherwise crash.

parent 5177b7d1
...@@ -512,7 +512,12 @@ class AndroidDevice(object): ...@@ -512,7 +512,12 @@ class AndroidDevice(object):
log_process = subprocess.Popen(cmd, bufsize=1, stdout=subprocess.PIPE) log_process = subprocess.Popen(cmd, bufsize=1, stdout=subprocess.PIPE)
while True: while True:
try: try:
sys.stdout.write('ANDROID: ' + log_process.stdout.readline()) log_line = log_process.stdout.readline()
if log_line == '':
if log_process.poll() != None:
logging.error('The Android logging process has quit unexpectedly. Please call the "logs" command again.')
break
sys.stdout.write('ANDROID: ' + log_line)
sys.stdout.flush() sys.stdout.flush()
except KeyboardInterrupt: except KeyboardInterrupt:
break break
...@@ -635,6 +640,10 @@ class IOSDevice(object): ...@@ -635,6 +640,10 @@ class IOSDevice(object):
while True: while True:
try: try:
log_line = log_process.stdout.readline() log_line = log_process.stdout.readline()
if log_line == '':
if log_process.poll() != None:
logging.error('The iOS logging process has quit unexpectedly. Please call the "logs" command again.')
break
if re.match(r'.*SkyShell.*', log_line) is not None: if re.match(r'.*SkyShell.*', log_line) is not None:
sys.stdout.write('IOS DEV: ' + log_line) sys.stdout.write('IOS DEV: ' + log_line)
sys.stdout.flush() sys.stdout.flush()
...@@ -757,6 +766,10 @@ class IOSSimulator(object): ...@@ -757,6 +766,10 @@ class IOSSimulator(object):
while True: while True:
try: try:
log_line = log_process.stdout.readline() log_line = log_process.stdout.readline()
if log_line == '':
if log_process.poll() != None:
logging.error('The iOS Simulator logging process has quit unexpectedly. Please call the "logs" command again.')
break
if re.match(r'.*SkyShell.*', log_line) is not None: if re.match(r'.*SkyShell.*', log_line) is not None:
sys.stdout.write('IOS SIM: ' + log_line) sys.stdout.write('IOS SIM: ' + log_line)
sys.stdout.flush() sys.stdout.flush()
......
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