mirror of
https://github.com/nasa/trick.git
synced 2025-01-20 11:39:13 +00:00
Add option to terminate sim on python event error (#1434)
This commit is contained in:
parent
1b2203b867
commit
5ff52a01c5
@ -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
|
||||||
|
@ -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;
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
7
test/SIM_events/RUN_test/unit_test_error1.py
Normal file
7
test/SIM_events/RUN_test/unit_test_error1.py
Normal 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")
|
12
test/SIM_events/RUN_test/unit_test_error2.py
Normal file
12
test/SIM_events/RUN_test/unit_test_error2.py
Normal 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)
|
12
test/SIM_events/RUN_test/unit_test_error3.py
Normal file
12
test/SIM_events/RUN_test/unit_test_error3.py
Normal 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)
|
@ -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
|
||||||
|
@ -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 ;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 ;
|
||||||
|
Loading…
Reference in New Issue
Block a user