summaryrefslogtreecommitdiffstats
path: root/test/src/issues/test-issue62.cpp
blob: b75693c83ee15142a177642e987ec81cf41dafba (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include "uscxml/Interpreter.h"
#include "glog/logging.h"

using namespace uscxml;

int main(int argc, char** argv) {
    google::LogToStderr();
    google::InitGoogleLogging(argv[0]);
    
    const char* scxmlContent =
    "<scxml datamodel=\"lua\" initial=\"init\" name=\"scxml_root\" version=\"1.0\" xmlns=\"http://www.w3.org/2005/07/scxml\">               "
    "   <state id=\"init\">                                                                                                                 "
    "       <transition target=\"InvokeParent\"/>                                                                                           "
    "   </state>                                                                                                                            "
    "   <final id=\"FinalShape1\"/>                                                                                                         "
    "   <state id=\"InvokeParent\">                                                                                                         "
    "       <invoke autoforward=\"true\" id=\"test_invoke\" type=\"scxml\">                                                                 "
    "           <content>                                                                                                                   "
    "               <scxml datamodel=\"lua\" initial=\"On\" name=\"ScxmlShape1\" version=\"1.0\" xmlns=\"http://www.w3.org/2005/07/scxml\"> "
    "                   <state id=\"On\">                                                                                                   "
    "                       <onentry>                                                                                                       "
    "                           <script>print('TEST LOGGING FROM INVOKE SOURCE')</script>                                                   "
    "                       </onentry>                                                                                                      "
    "                       <transition target=\"Off\"/>                                                                                    "
    "                   </state>                                                                                                            "
    "                   <state id=\"Off\">                                                                                                  "
    "                       <transition event=\"inside_invoke\" target=\"End\"/>                                                            "
    "                   </state>                                                                                                            "
    "                   <final id=\"End\"/>                                                                                                 "
    "               </scxml>                                                                                                                "
    "           </content>                                                                                                                  "
    "       </invoke>                                                                                                                       "
    "       <transition event=\"done.invoke.test_invoke\" target=\"FinalShape1\"/>                                                          "
    "       <transition event=\"move_here\" target=\"StateXXX\"/>                                                                           "
    "   </state>                                                                                                                            "
    "   <state id=\"StateXXX\">                                                                                                             "
    "       <transition target=\"FinalShape1\"/>                                                                                            "
    "   </state>                                                                                                                            "
    "</scxml>                                                                                                                               ";
    
    std::string msg;
    
    uscxml::Interpreter scxml = uscxml::Interpreter(uscxml::Interpreter::fromXML(scxmlContent, ""));
    scxml.addMonitor(new StateTransitionMonitor());
    
    uscxml::InterpreterState state;
    
    // assume initial stable configuration
    do {
        state = scxml.step();
    } while(state > 0);
    
    scxml.receive(Event("move_here"));
    scxml.receive(Event("inside_invoke"));

    while(state != uscxml::USCXML_FINISHED) {

        do {
            state = scxml.step();
        } while(state > 0);
        
    }
    
    std::cout << "************************************" << std::endl;
    std::cout << "Successfully finished state machine!" << std::endl;
    
    return EXIT_SUCCESS;
    
}