Add option to terminate sim on python event error (#1434)

This commit is contained in:
Jacqueline Deans 2023-01-20 15:46:10 -06:00 committed by GitHub
parent 1b2203b867
commit 5ff52a01c5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 82 additions and 14 deletions

View File

@ -449,6 +449,9 @@ For information on how Trick processes events during runtime, see [Event Process
# Add the event to the input processor's list of events (it will be processed at top of frame before scheduled jobs) # Add the event to the input processor's list of events (it will be processed at top of frame before scheduled jobs)
trick.add_event(<event name>) trick.add_event(<event name>)
# Tell trick whether to terminate the sim if an error occurs while parsing Python code. Defaults to False
trick.terminate_on_event_parse_error(<True|False>)
``` ```
#### Advanced Event (Malfunction) Usage #### Advanced Event (Malfunction) Usage

View File

@ -184,6 +184,15 @@ namespace Trick {
*/ */
static void set_event_info_msg_off() ; static void set_event_info_msg_off() ;
/**
@brief @userdesc Command to set whether the sim should check error codes from
Python parsing and terminate if an error is detected. Set to false by default
@par Python Usage:
@code trick.terminate_on_event_parse_error(True|False) @endcode
@return always 0
*/
static void terminate_on_event_parse_error(bool on_off);
/** /**
@brief called by the event manager when the event is loaded from a checkpoint @brief called by the event manager when the event is loaded from a checkpoint
*/ */
@ -402,7 +411,7 @@ namespace Trick {
any events instantiated yet */ any events instantiated yet */
static void set_python_processor(Trick::IPPython * in_ip) ; static void set_python_processor(Trick::IPPython * in_ip) ;
static void set_mtv(Trick::MTV * in_mtv) ; static void set_mtv(Trick::MTV * in_mtv) ;
private: private:
/* A static pointer to the python input processor set at the S_define level */ /* A static pointer to the python input processor set at the S_define level */
@ -411,6 +420,8 @@ namespace Trick {
/* A static pointer to the MTV set at the S_define level */ /* A static pointer to the MTV set at the S_define level */
static Trick::MTV * mtv ; static Trick::MTV * mtv ;
/* Defaults to false */
static bool terminate_sim_on_event_python_error;
} ; } ;
} }

View File

@ -44,6 +44,7 @@ if hasattr(top.cvar, 'trick_ip'):
set_event_info_msg_on = trick.IPPythonEvent.set_event_info_msg_on set_event_info_msg_on = trick.IPPythonEvent.set_event_info_msg_on
set_event_info_msg_off = trick.IPPythonEvent.set_event_info_msg_off set_event_info_msg_off = trick.IPPythonEvent.set_event_info_msg_off
terminate_on_event_parse_error = trick.IPPythonEvent.terminate_on_event_parse_error
# bind pyton input_processor event routines to shortcut names. # bind pyton input_processor event routines to shortcut names.
new_event = trick.ippython_new_event new_event = trick.ippython_new_event

View File

@ -0,0 +1,7 @@
trick.stop(1.0)
# print(dir(trick))
trick.terminate_on_event_parse_error(True)
# Error in add read
trick.add_read(0.1, "a = b")

View File

@ -0,0 +1,12 @@
trick.terminate_on_event_parse_error(True)
# Error in condition
event1 = trick.new_event("event1")
event1.condition(0, "this is a syntax error")
event1.action(0, "print (\"event1\");")
event1.action(1, "event1.activate()")
event1.set_cycle(1.0)
event1.activate()
trick.add_event(event1)
trick.stop(10)

View File

@ -0,0 +1,12 @@
trick.terminate_on_event_parse_error(True)
# Error in event action
event1 = trick.new_event("event1")
event1.condition(0, "True")
event1.action(0, "this is a syntax error")
event1.action(1, "event1.activate()")
event1.set_cycle(1.0)
event1.activate()
trick.add_event(event1)
trick.stop(10)

View File

@ -42,13 +42,6 @@ SIM_demo_sdefine:
runs: runs:
RUN_test/unit_test.py: RUN_test/unit_test.py:
returns: 0 returns: 0
SIM_events:
path: test/SIM_events
build_command: "trick-CP -t"
binary: "T_main_{cpu}_test.exe"
runs:
RUN_test/unit_test.py:
returns: 0
SIM_exec_set_time_tic_value: SIM_exec_set_time_tic_value:
path: test/SIM_exec_set_time_tic_value path: test/SIM_exec_set_time_tic_value
build_command: "trick-CP -t" build_command: "trick-CP -t"
@ -267,6 +260,21 @@ SIM_checkpoint_data_recording:
# compare: # compare:
# - test/SIM_checkpoint_data_recording/RUN_test6/ref_log_foo2.csv vs. test/SIM_checkpoint_data_recording/RUN_test6/log_foo2.csv # - test/SIM_checkpoint_data_recording/RUN_test6/ref_log_foo2.csv vs. test/SIM_checkpoint_data_recording/RUN_test6/log_foo2.csv
SIM_events:
path: test/SIM_events
build_command: "trick-CP -t"
binary: "T_main_{cpu}_test.exe"
runs:
RUN_test/unit_test.py:
returns: 0
RUN_test/unit_test_error1.py:
returns: 255
RUN_test/unit_test_error2.py:
returns: 255
RUN_test/unit_test_error3.py:
returns: 255
# The variable server client and SIM_amoeba sometimes fail to connect and need to be retried # The variable server client and SIM_amoeba sometimes fail to connect and need to be retried
SIM_test_varserv: SIM_test_varserv:
path: test/SIM_test_varserv path: test/SIM_test_varserv

View File

@ -179,11 +179,11 @@ int Trick::IPPython::parse_condition(std::string in_string, int & cond_return_va
pthread_mutex_lock(&ip_mutex); pthread_mutex_lock(&ip_mutex);
in_string = std::string("trick_ip.ip.return_val = ") + in_string + "\n" ; in_string = std::string("trick_ip.ip.return_val = ") + in_string + "\n" ;
// Running the simple string will set return_val. // Running the simple string will set return_val.
PyRun_SimpleString(in_string.c_str()) ; int py_ret = PyRun_SimpleString(in_string.c_str()) ;
cond_return_val = return_val ; cond_return_val = return_val ;
pthread_mutex_unlock(&ip_mutex); pthread_mutex_unlock(&ip_mutex);
return 0 ; return py_ret ;
} }

View File

@ -29,6 +29,7 @@ extern Trick::MemoryManager * trick_MM ;
Trick::IPPython * Trick::IPPythonEvent::ip ; Trick::IPPython * Trick::IPPythonEvent::ip ;
Trick::MTV * Trick::IPPythonEvent::mtv ; Trick::MTV * Trick::IPPythonEvent::mtv ;
bool Trick::IPPythonEvent::info_msg = false ; bool Trick::IPPythonEvent::info_msg = false ;
bool Trick::IPPythonEvent::terminate_sim_on_event_python_error = false;
Trick::condition_t::condition_t() { Trick::condition_t::condition_t() {
enabled = 0 ; enabled = 0 ;
@ -169,6 +170,10 @@ void Trick::IPPythonEvent::set_event_info_msg_off() {
info_msg = false; info_msg = false;
} }
void Trick::IPPythonEvent::terminate_on_event_parse_error(bool on_off) {
terminate_sim_on_event_python_error = on_off;
}
void Trick::IPPythonEvent::restart() { void Trick::IPPythonEvent::restart() {
int jj ; int jj ;
@ -515,7 +520,10 @@ int Trick::IPPythonEvent::process( long long curr_time ) {
} else { } else {
// it's a read event // it's a read event
active = false ; active = false ;
ip->parse(action_list[0]->str) ; int ret = ip->parse(action_list[0]->str) ;
if (ret != 0 && terminate_sim_on_event_python_error) {
exec_terminate_with_return( ret , __FILE__ , __LINE__ , "Python error in event processing" ) ;
}
// keep stats so mtv will show when it ran // keep stats so mtv will show when it ran
fired_count++ ; fired_count++ ;
fired_time = curr_time ; fired_time = curr_time ;
@ -572,7 +580,10 @@ bool Trick::IPPythonEvent::process_user_event( long long curr_time ) {
} else { } else {
// otherwise use python to evaluate string // otherwise use python to evaluate string
std::string full_in_string ; std::string full_in_string ;
ip->parse_condition(condition_list[ii]->str, return_val) ; int python_ret = ip->parse_condition(condition_list[ii]->str, return_val) ;
if (python_ret != 0 && terminate_sim_on_event_python_error) {
exec_terminate_with_return( python_ret , __FILE__ , __LINE__ , "Python error in event condition processing" ) ;
}
} }
if (return_val) { if (return_val) {
//TODO: write to log/send_hs that trigger fired //TODO: write to log/send_hs that trigger fired
@ -639,8 +650,11 @@ bool Trick::IPPythonEvent::process_user_event( long long curr_time ) {
break; break;
} }
} else { } else {
// otherwise use python to evaluate string // otherwise use python to evaluate string
ip->parse(action_list[ii]->str) ; int ret = ip->parse(action_list[ii]->str) ;
if (ret != 0 && terminate_sim_on_event_python_error) {
exec_terminate_with_return( ret , __FILE__ , __LINE__ , "Python error in event action processing" ) ;
}
} }
it_ran = true ; it_ran = true ;
action_list[ii]->ran = true ; action_list[ii]->ran = true ;