def __init__(self, out_file, options, file_is_stream): # Initialize the parent super(Curses, self).__init__(out_file, options, file_is_stream) self.using_terminal = True self.have_curses = True self.initialize_event = None self.jobs = [None] * 64 self.job_tests = [None] * 64 self.results = list() try: self.main_window = lldbcurses.intialize_curses() self.main_window.add_key_action( '\t', self.main_window.select_next_first_responder, "Switch between views that can respond to keyboard input") self.main_window.refresh() self.job_panel = None self.results_panel = None self.status_panel = None self.info_panel = None self.hide_status_list = list() self.start_time = time.time() except: self.have_curses = False lldbcurses.terminate_curses() self.using_terminal = False print("Unexpected error:", sys.exc_info()[0]) raise self.line_dict = dict()
def handle_event(self, test_event): with self.lock: super(Curses, self).handle_event(test_event) # for formatter in self.formatters: # formatter.process_event(test_event) if self.have_curses: worker_index = -1 if 'worker_index' in test_event: worker_index = test_event['worker_index'] if 'event' in test_event: check_for_one_key = True #print(str(test_event), file=self.events_file) event = test_event['event'] if self.status_panel: self.status_panel.update_status( 'time', str( datetime.timedelta( seconds=math.floor( time.time() - self.start_time)))) if event == 'test_start': name = test_event['test_class'] + \ '.' + test_event['test_name'] self.job_tests[worker_index] = test_event if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) + name else: line = name self.job_panel.set_line(worker_index, line) self.main_window.refresh() elif event == 'test_result': status = test_event['status'] self.status_panel.increment_status(status) if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) else: line = '' self.job_panel.set_line(worker_index, line) name = test_event['test_class'] + \ '.' + test_event['test_name'] elapsed_time = test_event[ 'event_time'] - self.job_tests[worker_index]['event_time'] if status not in self.hide_status_list: self.results_panel.append_line( '%s (%6.2f sec) %s' % (self.status_to_short_str( status, test_event), elapsed_time, name)) self.main_window.refresh() # Append the result pairs test_event['elapsed_time'] = elapsed_time self.results.append( [self.job_tests[worker_index], test_event]) self.job_tests[worker_index] = '' elif event == 'job_begin': self.jobs[worker_index] = test_event if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) else: line = '' self.job_panel.set_line(worker_index, line) elif event == 'job_end': self.jobs[worker_index] = '' self.job_panel.set_line(worker_index, '') elif event == 'initialize': self.initialize_event = test_event num_jobs = test_event['worker_count'] job_frame = self.main_window.get_contained_rect( height=num_jobs + 2) results_frame = self.main_window.get_contained_rect( top_inset=num_jobs + 2, bottom_inset=1) status_frame = self.main_window.get_contained_rect( height=1, top_inset=self.main_window.get_size().h - 1) self.job_panel = lldbcurses.BoxedPanel( frame=job_frame, title="Jobs") self.results_panel = lldbcurses.BoxedPanel( frame=results_frame, title="Results") self.results_panel.add_key_action( curses.KEY_UP, self.results_panel.select_prev, "Select the previous list entry") self.results_panel.add_key_action( curses.KEY_DOWN, self.results_panel.select_next, "Select the next list entry") self.results_panel.add_key_action( curses.KEY_HOME, self.results_panel.scroll_begin, "Scroll to the start of the list") self.results_panel.add_key_action( curses.KEY_END, self.results_panel.scroll_end, "Scroll to the end of the list") self.results_panel.add_key_action( curses.KEY_ENTER, self.show_info_panel, "Display info for the selected result item") self.results_panel.add_key_action( '.', lambda: self.toggle_status( EventBuilder.STATUS_SUCCESS), "Toggle showing/hiding tests whose status is 'success'") self.results_panel.add_key_action( 'e', lambda: self.toggle_status( EventBuilder.STATUS_ERROR), "Toggle showing/hiding tests whose status is 'error'") self.results_panel.add_key_action( 'f', lambda: self.toggle_status( EventBuilder.STATUS_FAILURE), "Toggle showing/hiding tests whose status is 'failure'") self.results_panel.add_key_action('s', lambda: self.toggle_status( EventBuilder.STATUS_SKIP), "Toggle showing/hiding tests whose status is 'skip'") self.results_panel.add_key_action( 'x', lambda: self.toggle_status( EventBuilder.STATUS_EXPECTED_FAILURE), "Toggle showing/hiding tests whose status is 'expected_failure'") self.results_panel.add_key_action( '?', lambda: self.toggle_status( EventBuilder.STATUS_UNEXPECTED_SUCCESS), "Toggle showing/hiding tests whose status is 'unexpected_success'") self.status_panel = lldbcurses.StatusPanel( frame=status_frame) self.main_window.add_child(self.job_panel) self.main_window.add_child(self.results_panel) self.main_window.add_child(self.status_panel) self.main_window.set_first_responder( self.results_panel) self.status_panel.add_status_item( name="time", title="Elapsed", format="%s", width=20, value="0:00:00", update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_SUCCESS, title="Success", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_FAILURE, title="Failure", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_ERROR, title="Error", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_SKIP, title="Skipped", format="%u", width=20, value=0, update=True) self.status_panel.add_status_item( name=EventBuilder.STATUS_EXPECTED_FAILURE, title="Expected Failure", format="%u", width=30, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_UNEXPECTED_SUCCESS, title="Unexpected Success", format="%u", width=30, value=0, update=False) self.main_window.refresh() elif event == 'terminate': # self.main_window.key_event_loop() lldbcurses.terminate_curses() check_for_one_key = False self.using_terminal = False # Check for 1 keypress with no delay # Check for 1 keypress with no delay if check_for_one_key: self.main_window.key_event_loop(0, 1)
def handle_event(self, test_event): with self.lock: super(Curses, self).handle_event(test_event) # for formatter in self.formatters: # formatter.process_event(test_event) if self.have_curses: worker_index = -1 if 'worker_index' in test_event: worker_index = test_event['worker_index'] if 'event' in test_event: check_for_one_key = True #print(str(test_event), file=self.events_file) event = test_event['event'] if self.status_panel: self.status_panel.update_status( 'time', str( datetime.timedelta( seconds=math.floor(time.time() - self.start_time)))) if event == 'test_start': name = test_event['test_class'] + \ '.' + test_event['test_name'] self.job_tests[worker_index] = test_event if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) + name else: line = name self.job_panel.set_line(worker_index, line) self.main_window.refresh() elif event == 'test_result': status = test_event['status'] self.status_panel.increment_status(status) if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) else: line = '' self.job_panel.set_line(worker_index, line) name = test_event['test_class'] + \ '.' + test_event['test_name'] elapsed_time = test_event[ 'event_time'] - self.job_tests[worker_index][ 'event_time'] if status not in self.hide_status_list: self.results_panel.append_line( '%s (%6.2f sec) %s' % (self.status_to_short_str( status, test_event), elapsed_time, name)) self.main_window.refresh() # Append the result pairs test_event['elapsed_time'] = elapsed_time self.results.append( [self.job_tests[worker_index], test_event]) self.job_tests[worker_index] = '' elif event == 'job_begin': self.jobs[worker_index] = test_event if 'pid' in test_event: line = 'pid: %5d ' % (test_event['pid']) else: line = '' self.job_panel.set_line(worker_index, line) elif event == 'job_end': self.jobs[worker_index] = '' self.job_panel.set_line(worker_index, '') elif event == 'initialize': self.initialize_event = test_event num_jobs = test_event['worker_count'] job_frame = self.main_window.get_contained_rect( height=num_jobs + 2) results_frame = self.main_window.get_contained_rect( top_inset=num_jobs + 2, bottom_inset=1) status_frame = self.main_window.get_contained_rect( height=1, top_inset=self.main_window.get_size().h - 1) self.job_panel = lldbcurses.BoxedPanel(frame=job_frame, title="Jobs") self.results_panel = lldbcurses.BoxedPanel( frame=results_frame, title="Results") self.results_panel.add_key_action( curses.KEY_UP, self.results_panel.select_prev, "Select the previous list entry") self.results_panel.add_key_action( curses.KEY_DOWN, self.results_panel.select_next, "Select the next list entry") self.results_panel.add_key_action( curses.KEY_HOME, self.results_panel.scroll_begin, "Scroll to the start of the list") self.results_panel.add_key_action( curses.KEY_END, self.results_panel.scroll_end, "Scroll to the end of the list") self.results_panel.add_key_action( curses.KEY_ENTER, self.show_info_panel, "Display info for the selected result item") self.results_panel.add_key_action( '.', lambda: self.toggle_status(EventBuilder. STATUS_SUCCESS), "Toggle showing/hiding tests whose status is 'success'" ) self.results_panel.add_key_action( 'e', lambda: self.toggle_status(EventBuilder. STATUS_ERROR), "Toggle showing/hiding tests whose status is 'error'" ) self.results_panel.add_key_action( 'f', lambda: self.toggle_status(EventBuilder. STATUS_FAILURE), "Toggle showing/hiding tests whose status is 'failure'" ) self.results_panel.add_key_action( 's', lambda: self.toggle_status(EventBuilder. STATUS_SKIP), "Toggle showing/hiding tests whose status is 'skip'" ) self.results_panel.add_key_action( 'x', lambda: self.toggle_status( EventBuilder.STATUS_EXPECTED_FAILURE), "Toggle showing/hiding tests whose status is 'expected_failure'" ) self.results_panel.add_key_action( '?', lambda: self.toggle_status( EventBuilder.STATUS_UNEXPECTED_SUCCESS), "Toggle showing/hiding tests whose status is 'unexpected_success'" ) self.status_panel = lldbcurses.StatusPanel( frame=status_frame) self.main_window.add_child(self.job_panel) self.main_window.add_child(self.results_panel) self.main_window.add_child(self.status_panel) self.main_window.set_first_responder( self.results_panel) self.status_panel.add_status_item(name="time", title="Elapsed", format="%s", width=20, value="0:00:00", update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_SUCCESS, title="Success", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_FAILURE, title="Failure", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_ERROR, title="Error", format="%u", width=20, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_SKIP, title="Skipped", format="%u", width=20, value=0, update=True) self.status_panel.add_status_item( name=EventBuilder.STATUS_EXPECTED_FAILURE, title="Expected Failure", format="%u", width=30, value=0, update=False) self.status_panel.add_status_item( name=EventBuilder.STATUS_UNEXPECTED_SUCCESS, title="Unexpected Success", format="%u", width=30, value=0, update=False) self.main_window.refresh() elif event == 'terminate': # self.main_window.key_event_loop() lldbcurses.terminate_curses() check_for_one_key = False self.using_terminal = False # Check for 1 keypress with no delay # Check for 1 keypress with no delay if check_for_one_key: self.main_window.key_event_loop(0, 1)