ItsMapem_TpFunctions.ttcn 110 KB
Newer Older
Yann Garcia's avatar
Yann Garcia committed
 *    @version  $Url: https://oldforge.etsi.org/svn/ITS/tags/20170222_STF527_Final/ttcn/AtsMapemSpatem/ItsMapem_TpFunctions.ttcn $
 *              $Id: ItsMapem_TpFunctions.ttcn,v 1.2 2018/05/31 15:57:07 dte Exp $
garciay's avatar
garciay committed
 *    @copyright   ETSI Copyright Notification
 *                 No part may be reproduced except as authorized by written permission.
 *                 The copyright and the foregoing restriction extend to reproduction in all media.
 *                 All rights reserved.
 *
 */

module ItsMapem_TpFunctions {
    
    // LibCommon
    import from LibCommon_BasicTypesAndValues all;
    import from LibCommon_Sync all;
    import from LibCommon_VerdictControl all;
    import from LibCommon_Time all;
    
    // LibItsCommon
    import from LibItsCommon_Functions all;
    import from LibItsCommon_TypesAndValues all;
    
    // LibIts
    import from ITS_Container language "ASN.1:1997" all;
    import from MAPEM_PDU_Descriptions language "ASN.1:1997" all;
    import from SPATEM_PDU_Descriptions language "ASN.1:1997" all;
    import from DSRC language "ASN.1:1997" all;
Yann Garcia's avatar
Yann Garcia committed
    import from DSRC_REGION_noCircular language "ASN.1:1997" all;
    
    // LibItsMapemSpatem
    import from LibItsMapemSpatem_TestSystem all;
    import from LibItsMapemSpatem_Functions all;
    import from LibItsMapemSpatem_Templates all;
    import from LibItsMapemSpatem_TypesAndValues all;
    import from LibItsMapemSpatem_Pics all;
Yann Garcia's avatar
Yann Garcia committed
    import from LibItsMapemSpatem_Pixits all;
    
    group mapeMessageDissemination { 
        
        group mapeMessageFormat { 
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_01
            function f_IS_RLT_GEN_MSGF_BV_01 () runs on ItsMapemSpatem {
garciay's avatar
garciay committed
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
garciay's avatar
garciay committed
                f_prInitialState();
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                        mw_mapemInd(
                            mw_mapemPdu
                    )) { 
                        tc_ac.stop;
                        log("*** " & testcasename() & ": PASS: Successfully received MAPEM PDU header. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
                
            } // End of function f_IS_RLT_GEN_MSGF_BV_01
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_02
             */
            function f_IS_RLT_GEN_MSGF_BV_02 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, v_mapem.msgIn.map_.intersections[0].id.id, m_speedLimits(maxSpeedInConstructionZone, 30)));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                { mw_intersectionGeometry(v_mapem.msgIn.map_.intersections[0].id, v_mapem.msgIn.map_.intersections[0].revision + 1) }
                    )))) { 
                        tc_ac.stop;
                        log("*** " & testcasename() & ": PASS: Successfully received MAPEM PDU header. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
                
            } // End of function f_IS_RLT_GEN_MSGF_BV_02
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_03
             */
            function f_IS_RLT_GEN_MSGF_BV_03 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
Yann Garcia's avatar
Yann Garcia committed
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, v_mapem.msgIn.map_.intersections[0].id.id, v_mapem.msgIn.map_.intersections[0].speedLimits[0]));
Yann Garcia's avatar
Yann Garcia committed
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                { mw_intersectionGeometry(v_mapem.msgIn.map_.intersections[0].id, v_mapem.msgIn.map_.intersections[0].revision) }
                    )))) { 
                        tc_ac.stop;
                        log("*** " & testcasename() & ": PASS: Successfully received MAPEM PDU header. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
                
            } // End of function f_IS_RLT_GEN_MSGF_BV_03
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_04
             */
            function f_IS_RLT_GEN_MSGF_BV_04 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                -,
                                                                                {
                                                                                  mw_roadSegment(
                                                                                                 -, -, -, 
                                                                                                 { mw_roadLane(-, -, ?), mw_roadLane(-, -, -, ?) }
                                                                                                 )
                                                                                }
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        log("*** " & testcasename() & ": PASS: Successfully received MAPEM PDU header. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
                
            } // End of function f_IS_RLT_GEN_MSGF_BV_04
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_05
             */
            function f_IS_RLT_GEN_MSGF_BV_05 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, -, -, PX_3D_REF_POINT_LATITUDE));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                { mw_intersectionGeometry(v_mapem.msgIn.map_.intersections[0].id, -, mw_position3D(-, -, ?)) }
                    )))) { 
                        tc_ac.stop;
                        log("*** " & testcasename() & ": PASS: Successfully received MAPEM PDU header. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
                
            } // End of function f_IS_RLT_GEN_MSGF_BV_05
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_06
             */
            function f_IS_RLT_GEN_MSGF_BV_06 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, 7));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_uniqueless_lanes_id(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_06 {
                
                function f_check_uniqueless_lanes_id(
                                                     in IntersectionGeometryList p_intersections
                                                     ) return boolean {
                    var charstring v_lane_ids_found; // Used to build the list of the laneID already processed
                    var charstring v_lane_id; // laneID currently processed
                    var template charstring v_found_pattern; // Used in regex to verify that ''v_usageStatememtId' was not found before'
                    
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        v_lane_ids_found := ";";
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            v_lane_id := int2str(p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx].laneID);
                            v_found_pattern := pattern "*({v_lane_id})*";
                            if (regexp(v_lane_ids_found, v_found_pattern, 0) == v_lane_id) {
                                return false; // v_lane_id exist at least 2 times, uniqueness is not verified
                            }
                            // v_lane_id non found, add current laneID into the built list
                            v_lane_ids_found := v_lane_ids_found & v_lane_id & ";";
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_uniqueless_lanes_id
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_06
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_07
             */
            function f_IS_RLT_GEN_MSGF_BV_07 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_lanes_nodes_length(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_07 {
                
                function f_check_lanes_nodes_length(
                                                    in IntersectionGeometryList p_intersections
                                                    ) return boolean {
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            var NodeListXY v_nodes_list := p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx].nodeList;
                            if (ischosen(v_nodes_list.nodes)) {
                                for (var integer v_idx := 0; v_idx < lengthof(v_nodes_list.nodes); v_idx := v_idx + 1) {
                                    var NodeXY v_node := v_nodes_list.nodes[v_idx];
                                    // TODO Which fields should be tested?
                                    //if (v_node.delta.)
                                } // End of 'for' statement
                            } // else, ignore ComputedLane field
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_lanes_nodes_length
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_07
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_08
             */
            function f_IS_RLT_GEN_MSGF_BV_08 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_generic_lanes_content(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_08 {
                
                function f_check_generic_lanes_content(
                                                       in IntersectionGeometryList p_intersections
                                                       ) return boolean {
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            var GenericLane v_lane := p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx];
                            if (match(v_lane, mw_roadLane) == false) {
                                return false;
                            }
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_generic_lanes_content
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_08
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_09
             */
            function f_IS_RLT_GEN_MSGF_BV_09 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
Yann Garcia's avatar
Yann Garcia committed
                if (not PICS_MAPEM_GENERATION or not PICS_PEDESTRIAN_MANOEUVRES) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION and PICS_PEDESTRIAN_MANOEUVRES required for executing the TC ***");
Yann Garcia's avatar
Yann Garcia committed
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_generic_pedestrian_lanes_content(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_09 {
                
                function f_check_generic_pedestrian_lanes_content(
                                                                  in IntersectionGeometryList p_intersections
                                                                  ) return boolean {
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            var GenericLane v_lane := p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx];
                            if (match(v_lane, mw_roadLane) == false) {
                                return false;
                            }
                            // TODO Which fields should be tested?
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_generic_pedestrian_lanes_content
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_09
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_10
             */
            function f_IS_RLT_GEN_MSGF_BV_10 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
Yann Garcia's avatar
Yann Garcia committed
                if (not PICS_MAPEM_GENERATION or not PICS_SPECIALIZED_CARS_MANOEUVRES) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION and PICS_SPECIALIZED_CARS_MANOEUVRES required for executing the TC ***");
Yann Garcia's avatar
Yann Garcia committed
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_generic_special_lanes_content(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_10 {
                
                function f_check_generic_special_lanes_content(
                                                               in IntersectionGeometryList p_intersections
                                                               ) return boolean {
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            var GenericLane v_lane := p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx];
                            if (match(v_lane, mw_roadLane) == false) {
                                return false;
                            }
                            // TODO Which fields should be tested?
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_generic_special_lanes_content
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_10
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_11
             */
            function f_IS_RLT_GEN_MSGF_BV_11 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        tc_ac.stop;
                        if (f_check_generic_crosswalk_lanes_content(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        } else {
                            log("*** " & testcasename() & ": FAIL: Duplicated lanes identifier. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_11 {
                
                function f_check_generic_crosswalk_lanes_content(
                                                                 in IntersectionGeometryList p_intersections
                                                                 ) return boolean {
                    for (var integer v_intersections_idx := 0; v_intersections_idx < lengthof(p_intersections); v_intersections_idx := v_intersections_idx + 1) {
                        for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                            var GenericLane v_lane := p_intersections[v_intersections_idx].laneSet[v_lane_ids_idx];
                            if (match(v_lane, mw_roadLane) == false) {
                                return false;
                            }
                            // TODO Which fields should be tested?
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_generic_crosswalk_lanes_content
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_11
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_12
             */
            function f_IS_RLT_GEN_MSGF_BV_12 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
Yann Garcia's avatar
Yann Garcia committed
                if (not PICS_MAPEM_GENERATION or not PICS_MAPEM_HAS_LANE_WIDTH) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION and PICS_MAPEM_HAS_LANE_WIDTH required for executing the TC ***");
Yann Garcia's avatar
Yann Garcia committed
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        var integer v_intersections_idx;
                        
                        tc_ac.stop;
                        for (v_intersections_idx := 0; v_intersections_idx < lengthof(v_mapem.msgIn.map_.intersections); v_intersections_idx := v_intersections_idx + 1) {
                            var integer v_lane_ids_idx;
                            for (v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(v_mapem.msgIn.map_.intersections[v_intersections_idx].laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                                if (f_check_node_list_content(v_mapem.msgIn.map_.intersections[v_intersections_idx].laneSet[v_lane_ids_idx].nodeList)) {
                                    log("*** " & testcasename() & ": FAIL: Wrong NodeList content for intersection #", v_intersections_idx , ". ***");
                                    f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                                    break;
                                }
                            } // End of 'for' statement
                            if (v_lane_ids_idx < lengthof(v_mapem.msgIn.map_.intersections[v_intersections_idx].laneSet)) {
                                break;
                            }
                        } // End of 'for' statement
                        if (v_intersections_idx == lengthof(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_12 {
                
                function f_check_node_list_content(
                                                   in NodeListXY p_node_list
                                                   ) return boolean {
                    if (ischosen(p_node_list.nodes) == false) {
                        return false;
                    }
                    for (var integer v_nodes_idx := 0; v_nodes_idx < lengthof(p_node_list.nodes); v_nodes_idx := v_nodes_idx + 1) {
                        var NodeXY v_node_xy := p_node_list.nodes[v_nodes_idx];
                        if (match(v_node_xy, mw_nodeXY(-, mw_nodeAttributeSetXY_default)) == false) {
                            return false;
                        }
                        // TODO Which fields should be tested?
                    } // End of 'for' statement
                    
                    return true;
Yann Garcia's avatar
Yann Garcia committed
                } // End of function f_check_node_list_content
Yann Garcia's avatar
Yann Garcia committed
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_12
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_13
             */
            function f_IS_RLT_GEN_MSGF_BV_13 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;
                
                // Test control
                if (not PICS_MAPEM_GENERATION or not PICS_MAPEM_HAS_LANE_WIDTH) {
                    log("*** " & testcasename() & ": PICS_MAPEM_GENERATION and PICS_MAPEM_HAS_LANE_WIDTH required for executing the TC ***");
                    setverdict(inconc);
                    stop;
                }
                
                // Test component configuration
                f_cfUp();
                    
                // Preamble
                f_prInitialState();
                f_awaitMapeMessage(
                    mw_mapemInd(
                        mw_mapemPdu(
                            mw_defaultMapem
                    )),
                    v_mapem
                );
                f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
                    
                // Test Body
                f_utTriggerEvent(m_utTriggerEvent(mapemNewContent, PX_INTERSECTION_ID));
                
                tc_ac.start;
                alt {
                    [] mapemSpatemPort.receive(
                                               mw_mapemInd(
                                                           mw_mapemPdu(
                                                                       mw_mapem(
                                                                                ?
                    )))) -> value v_mapem { 
                        var integer v_intersections_idx;
                        
                        tc_ac.stop;
                        for (v_intersections_idx := 0; v_intersections_idx < lengthof(v_mapem.msgIn.map_.intersections); v_intersections_idx := v_intersections_idx + 1) {
                            if (f_check_node_list_width_attribut(v_mapem.msgIn.map_.intersections[v_intersections_idx])) {
                                log("*** " & testcasename() & ": FAIL: Wrong NodeList content for intersection #", v_intersections_idx , ". ***");
                                f_selfOrClientSyncAndVerdict(c_tbDone, e_error);
                                break;
                            }
                        } // End of 'for' statement
                        if (v_intersections_idx == lengthof(v_mapem.msgIn.map_.intersections)) {
                            log("*** " & testcasename() & ": PASS: The lanes identifier are unique. ***");
                            f_selfOrClientSyncAndVerdict(c_tbDone, e_success);
                        }
                    }
                    [] tc_ac.timeout {
                        log("*** " & testcasename() & ": INCONC: Timeout while awaiting the reception of a message. ***");
                        f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout);
                    }
                }
                
                // Postamble
                f_poDefault();
                f_cfDown();
Yann Garcia's avatar
Yann Garcia committed
            group checks_IS_RLT_GEN_MSGF_BV_13 {
                
                function f_check_node_list_width_attribut(
                                                          in IntersectionGeometry p_intersections_geometry
                                                          ) return boolean {
                    if (ispresent(p_intersections_geometry)) {
                        return false;
                    }
                    for (var integer v_lane_ids_idx := 0; v_lane_ids_idx < lengthof(p_intersections_geometry.laneSet); v_lane_ids_idx := v_lane_ids_idx + 1) {
                        var NodeListXY v_node_list := p_intersections_geometry.laneSet[v_lane_ids_idx].nodeList;
                        
                        if (ischosen(v_node_list.nodes) == false) {
                            return false;
                        }
                        for (var integer v_nodes_idx := 0; v_nodes_idx < lengthof(v_node_list.nodes); v_nodes_idx := v_nodes_idx + 1) {
                            var NodeXY v_node_xy := v_node_list.nodes[v_nodes_idx];
                            if (match(v_node_xy, mw_nodeXY(-, mw_nodeAttributeSetXY_default)) == false) {
                                return false;
                            }
                            // TODO Which fields should be tested?
                        } // End of 'for' statement
                    } // End of 'for' statement
                    
                    return true;
                } // End of function f_check_node_list_width_attribut
                
            } // End of group checks_IS_RLT_GEN_MSGF_BV_13
            
            /**
             * @desc    TP Function for TC_IS_RLT_GEN_MSGF_BV_14
             */
            function f_IS_RLT_GEN_MSGF_BV_14 () runs on ItsMapemSpatem {
                
Yann Garcia's avatar
Yann Garcia committed
                // Local variables
                var MapemInd v_mapem;