ItsRSUsSimulator_TestCases.ttcn 24.7 KB
Newer Older
garciay's avatar
garciay committed
module ItsRSUsSimulator_TestCases {
    
    // Libcommon
    import from LibCommon_VerdictControl all;
    import from LibCommon_Sync all;
    
garciay's avatar
garciay committed
    // LibIts
    import from ITS_Container language "ASN.1:1997" all;
    import from CAM_PDU_Descriptions language "ASN.1:1997" all;
    import from IEEE1609dot2BaseTypes language "ASN.1:1997" all;
    import from IEEE1609dot2 language "ASN.1:1997" all;
    import from EtsiTs103097Module language "ASN.1:1997" all;
garciay's avatar
garciay committed
    
garciay's avatar
garciay committed
    // LibItsCommon
    import from LibItsCommon_Functions all;
    
    // LibItsGeoNetworking
    import from LibItsGeoNetworking_TestSystem all;
    import from LibItsGeoNetworking_TypesAndValues all;
    import from LibItsGeoNetworking_Templates all;
    
    // LibItsCam
    import from LibItsCam_TypesAndValues all;
    import from LibItsCam_EncdecDeclarations all;
    
garciay's avatar
garciay committed
    // LibItsDenm
    import from LibItsDenm_Templates all;
    
garciay's avatar
garciay committed
    // LibItsSecurity
    import from LibItsSecurity_TypesAndValues all;
    import from LibItsSecurity_Functions all;
    
garciay's avatar
garciay committed
    // AtsRSUsSimulator
    import from ItsRSUsSimulator_TypesAndValues all;
    import from ItsRSUsSimulator_Templates all;
    import from ItsRSUsSimulator_TestSystem all;
    import from ItsRSUsSimulator_Functions all;
garciay's avatar
garciay committed
    import from ItsRSUsSimulator_Pics all;
garciay's avatar
garciay committed
    import from ItsRSUsSimulator_Pixits all;
    
    testcase TC_RSUSIMU_BV_01() runs on ItsRSUsSimulator system ItsRSUsSimulatorSystem {
garciay's avatar
garciay committed
        // Local variables
        var template (value) GnRawPayload v_payload;
garciay's avatar
garciay committed
        var GeoNetworkingInd v_gnInd;
        var CfEvent v_cfEvent;
garciay's avatar
garciay committed
        
        // Test control
        
        // Test component configuration
        ItsRSUsSimulator_Functions.f_cf01Up();
garciay's avatar
garciay committed
            
        // Test adapter configuration
        
        // Preamble
        activate(a_process_cf_ut_command());
garciay's avatar
garciay committed
        f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
        
        // Test Body
YannGarcia's avatar
YannGarcia committed
        if (PICS_ITS_S_ROLE == false) {
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].beacon)) {
YannGarcia's avatar
YannGarcia committed
          }
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].cam)) {
            tc_cam.start(vc_cam_timer_value);
YannGarcia's avatar
YannGarcia committed
          }
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].denms)) {
            tc_denm.start;
YannGarcia's avatar
YannGarcia committed
          }
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].mapem)) {
garciay's avatar
garciay committed
            tc_mapem.start;
YannGarcia's avatar
YannGarcia committed
          }
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].spatems)) {
garciay's avatar
garciay committed
            tc_spatem.start;
YannGarcia's avatar
YannGarcia committed
          }
          if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].ivim)) {
garciay's avatar
garciay committed
            tc_ivim.start;
YannGarcia's avatar
YannGarcia committed
          }
          /* if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].evcsn)) { */
          /*     tc_evcsn.start; */
          /* } */
        } // else, nothing to do, waiting for PKI triggers
garciay's avatar
garciay committed
        geoNetworkingPort.clear;
garciay's avatar
garciay committed
        alt {
YannGarcia's avatar
YannGarcia committed
          [PICS_SEND_BEACON_INDICATION == true] geoNetworkingPort.receive(
garciay's avatar
garciay committed
                mw_geoNwInd(
                    mw_geoNwPdu(
YannGarcia's avatar
YannGarcia committed
                                mw_geoNwShbPacket
                                ))) -> value v_gnInd { // Receive a BEACON
                log("*** " & testcasename() & ": DEBUG: Processing Beacon ***");
                f_processBeacon(v_gnInd.msgIn);
garciay's avatar
garciay committed
                repeat;
YannGarcia's avatar
YannGarcia committed
          }
          [PICS_SEND_DENM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
YannGarcia's avatar
YannGarcia committed
                        mw_geoNwBroadcastPacketWithNextHeader_denm( //mw_geoNwTsbPacketWithNextHeader_denm(
YannGarcia's avatar
YannGarcia committed
                            ?
            )))) -> value v_gnInd { // Receive a DENM message
YannGarcia's avatar
YannGarcia committed
                log("*** " & testcasename() & ": DEBUG: Processing DENM ***");
                f_processDenm(v_gnInd.msgIn);
YannGarcia's avatar
YannGarcia committed
          }
          [PICS_SEND_CAM_INDICATION == true] geoNetworkingPort.receive(
garciay's avatar
garciay committed
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwShbPacketWithNextHeader_cam(
                            ?,
                            ?,
                            e_btpB
YannGarcia's avatar
YannGarcia committed
            )))) -> value v_gnInd { // Receive a CAM message
garciay's avatar
garciay committed
                log("*** " & testcasename() & ": DEBUG: Processing CAM ***");
                f_processCam(v_gnInd.msgIn);
                repeat;
Yann Garcia's avatar
Yann Garcia committed
          }
          [PICS_SEND_IVIM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_ivim(
Yann Garcia's avatar
Yann Garcia committed
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a IVIM message
                log("*** " & testcasename() & ": DEBUG: Processing IVIM ***");
                f_processIvim(v_gnInd.msgIn);
                repeat;
          }
          [PICS_SEND_MAPEM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_mapem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a MAPEM message
                log("*** " & testcasename() & ": DEBUG: Processing MAPEM ***");
                f_processMapem(v_gnInd.msgIn);
                repeat;
          }
          [PICS_SEND_SPATEM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_spatem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a SPATEM message
                log("*** " & testcasename() & ": DEBUG: Processing SPATEM ***");
                f_processSpatem(v_gnInd.msgIn);
                repeat;
          }
Yann Garcia's avatar
Yann Garcia committed
          [PICS_SEND_SSEM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_ssem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a SSEM message
                log("*** " & testcasename() & ": DEBUG: Processing SSEM ***");
                f_processSsem(v_gnInd.msgIn);
                repeat;
            }
          [PICS_SEND_RTCMEM_INDICATION == true] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_rtcmem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a RTCMEM message
                log("*** " & testcasename() & ": DEBUG: Processing RTCMEM ***");
                f_processRtcmem(v_gnInd.msgIn);
                repeat;
          }
Yann Garcia's avatar
Yann Garcia committed
          [] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_srem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a SREM message
                log("*** " & testcasename() & ": DEBUG: Processing SREM ***");
                f_processSrem(v_gnInd.msgIn);
                repeat;
            }
Yann Garcia's avatar
Yann Garcia committed
          [] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwBroadcastPacketWithNextHeader_ssem(
                            ?,
                            ?,
                            e_btpB
            )))) -> value v_gnInd { // Receive a SSEM message
                log("*** " & testcasename() & ": DEBUG: Processing SREM ***");
                f_processSsem(v_gnInd.msgIn);
                repeat;
            }
garciay's avatar
garciay committed
            [] geoNetworkingPort.receive(mw_geoNwInd(?)) -> value v_gnInd { // Receive a message
                log("*** " & testcasename() & ": DEBUG: Recieving unsollicited message ***");
garciay's avatar
garciay committed
                // Nothing to do, just for logging purposes
                repeat;
            [] cfPort.receive(CfEvent:?) -> value v_cfEvent {
                log("*** " & testcasename() & ": DEBUG: Configuration port command:", v_cfEvent, " ***");
                if (f_process_cf_event(v_cfEvent) == true) {
                    repeat;
                }
            [vc_beacon == true] tc_beacon.timeout {
YannGarcia's avatar
YannGarcia committed
                //log("*** " & testcasename() & ": DEBUG: Processing BEACON ***");
garciay's avatar
garciay committed
                f_send(v_payload, PICS_BEACON_ITS_AID);
                tc_beacon.start;
                repeat;
            }
            [vc_cam == true] tc_cam.timeout {
                //log("*** " & testcasename() & ": DEBUG: Processing CAM ***");
garciay's avatar
garciay committed
                f_prepare_cam(v_payload);
                f_send(v_payload, PICS_CAM_ITS_AID);
                tc_cam.start(vc_cam_timer_value);
garciay's avatar
garciay committed
                repeat;
            }
            [vc_denm == true] tc_denm.timeout {
                //log("*** " & testcasename() & ": DEBUG: Processing DENM ***");
                for (var integer v_i := 0; v_i < lengthof(vc_rsuMessagesValueList[vc_rsu_id].denms); v_i := v_i + 1) {
                    f_prepare_denm(v_payload);
                    f_send(v_payload, PICS_DENM_ITS_AID);
                } // End of 'for' 
                tc_denm.start;
garciay's avatar
garciay committed
                repeat;
            }
            [vc_mapem == true] tc_mapem.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing MAPEM ***");
garciay's avatar
garciay committed
                f_prepare_mapem(v_payload);
                f_send(v_payload, PICS_MAPEM_ITS_AID);
garciay's avatar
garciay committed
                tc_mapem.start;
                repeat;
            }
            [vc_spatem == true] tc_spatem.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing SPATEM ***");
                for (var integer v_counter := 0; v_counter < lengthof(vc_rsuMessagesValueList[PX_RSU_ID - 1].spatems); v_counter := v_counter + 1) {
                    f_prepare_spatem(vc_rsuMessagesValueList[PX_RSU_ID - 1].spatems[v_counter], v_payload);
                    f_send(v_payload, PICS_SPATEM_ITS_AID);
garciay's avatar
garciay committed
                tc_spatem.start;
                repeat;
            }
            [vc_ivim == true] tc_ivim.timeout {
Yann Garcia's avatar
Yann Garcia committed
                log("*** " & testcasename() & ": DEBUG: Processing IVIM ***");
garciay's avatar
garciay committed
                f_prepare_ivim(v_payload);
                f_send(v_payload, PICS_IVIM_ITS_AID);
garciay's avatar
garciay committed
                tc_ivim.start;
                repeat;
            }
Yann Garcia's avatar
Yann Garcia committed
            [vc_srem == true] tc_srem.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing SREM ***");
                f_prepare_srem(v_payload);
                f_send(v_payload, PICS_SREM_ITS_AID);
                tc_srem.start;
Yann Garcia's avatar
Yann Garcia committed
                vc_ssem_timer_value.stop;
                vc_ssem_timer_value.start;
                repeat;
            }
            [vc_ssem == true] tc_ssem.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing SSEM ***");
                tc_ssem.start;
                repeat;
            }
            [vc_ssem == true] vc_ssem_timer_value.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing SSEM repetition ***");
                tc_ssem.stop;
Yann Garcia's avatar
Yann Garcia committed
                repeat;
            }
Yann Garcia's avatar
Yann Garcia committed
            [vc_rtcmem == true] tc_rtcmem.timeout {
                log("*** " & testcasename() & ": DEBUG: Processing RTCMEM ***");
                f_prepare_rtcmem(v_payload);
                f_send(v_payload, PICS_RTCMEM_ITS_AID);
                tc_rtcmem.start;
                repeat;
            }
            /* [vc_evcsn == true] tc_evcsn.timeout { */
            /*     //log("*** " & testcasename() & ": DEBUG: Processing EVCSN ***"); */
            /*     f_prepare_evcsn(v_payload); */
            /*     f_send(v_payload, PICS_EVCSN_ITS_AID); */
            /*     tc_evcsn.start; */
            /*     repeat; */
            /* } */
garciay's avatar
garciay committed
        } // End of 'alt' statement
        f_selfOrClientSyncAndVerdictTestBody(c_tbDone, e_success);
        
        // Postamble
        if (ispresent(vc_rsuMessagesValueList[vc_rsu_id].denms)) {
            for (var integer v_i := 0; v_i < lengthof(vc_rsuMessagesValueList[vc_rsu_id].denms); v_i := v_i + 1) {
                f_prepare_denm(v_payload, true);
                f_send(v_payload, PICS_DENM_ITS_AID);
            } // End of 'for' statement
        }
        ItsRSUsSimulator_Functions.f_cf01Down();
garciay's avatar
garciay committed
    } // End of TC_RSUSIMU_BV_01
    
    /**
     * @remark: All PICS_GENERATE_xxx = false
     *          PICS_CAM_FREQUENCY = 0.1
     */
    testcase TC_RSUSIMU_BV_02() runs on ItsRSUsSimulator system ItsRSUsSimulatorSystem {
        // Local variables
        const SequenceOfRectangularRegion c_detectionArea := { valueof(PICS_UC6_CAM_DETECTION_AREA_Z2) }; // PICS_UC6_CAM_DETECTION_AREA_Z1
garciay's avatar
garciay committed
        var VehiclesSimulator v_vehicles := {};
garciay's avatar
garciay committed
        var integer v_stationID;
        var boolean v_isInDetectionZone;
        var boolean v_notProcessed;
        var integer v_idx;
garciay's avatar
garciay committed
        var ThreeDLocation v_location;
garciay's avatar
garciay committed
        var GeoNetworkingInd v_gnInd;
        //var CfEvent v_cfEvent;
garciay's avatar
garciay committed
        
        // Test control
garciay's avatar
garciay committed
        if (f_isLocationInsideRectangularRegion(c_detectionArea, PICS_UC6_COLLISION_POINT_Z2) == false) { //PICS_UC6_COLLISION_POINT_Z1
            log("Collision location is outside of the area");
garciay's avatar
garciay committed
            stop;
        }
garciay's avatar
garciay committed
        
        // Test component configuration
        ItsRSUsSimulator_Functions.f_cf01Up();
garciay's avatar
garciay committed
            
        // Test adapter configuration
        
        // Preamble
garciay's avatar
garciay committed
        for (v_idx := 0; v_idx < SIMULTANEOUS_VEHICLE_NUM; v_idx := v_idx + 1) { 
garciay's avatar
garciay committed
            v_vehicles[v_idx].detected := false;
            v_vehicles[v_idx].detectionCounter := 0;
            v_vehicles[v_idx].stationId := 0;
        } // End of 'for' statement
garciay's avatar
garciay committed
        f_selfOrClientSyncAndVerdictPreamble(c_prDone, e_success);
        
        // Test Body
        tc_ac.start;
        geoNetworkingPort.clear;
garciay's avatar
garciay committed
        alt {
            [] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                        mw_geoNwShbPacketWithNextHeader_cam(
                            -,
                            -,
                            e_btpB
            )))) -> value v_gnInd { // Receive a CAM message
                var CAM v_camValue; // Assume BTP/CAM payload is well formed
                var bitstring v_payload;
                var integer v_result;
                
garciay's avatar
garciay committed
                tc_ac.stop;
garciay's avatar
garciay committed
                //log("v_gnInd = ", v_gnInd);
                v_payload := oct2bit(substr(v_gnInd.msgIn.gnPacket.packet.payload, 4, lengthof(v_gnInd.msgIn.gnPacket.packet.payload) - 4));
                v_result := decvalue(v_payload, v_camValue);
                if (isbound(v_camValue)) {
                    if (PICS_USE_LPV == true) {
                        v_location := {
                            v_gnInd.msgIn.gnPacket.packet.extendedHeader.shbHeader.srcPosVector.latitude,
                            v_gnInd.msgIn.gnPacket.packet.extendedHeader.shbHeader.srcPosVector.longitude,
                            0
                        };
garciay's avatar
garciay committed
                    } else {
                        v_location := {
                            v_camValue.cam.camParameters.basicContainer.referencePosition.latitude,
                            v_camValue.cam.camParameters.basicContainer.referencePosition.longitude,
                            v_camValue.cam.camParameters.basicContainer.referencePosition.altitude.altitudeValue
                        };
garciay's avatar
garciay committed
                    }
                    v_stationID := v_camValue.header.stationID;
                    
                    // Check if it already processed
                    v_notProcessed := true;
                    for (v_idx := 0; v_idx < SIMULTANEOUS_VEHICLE_NUM and v_vehicles[v_idx].stationId != 0; v_idx := v_idx + 1) { 
                        if (v_vehicles[v_idx].stationId == v_stationID) {
                            v_notProcessed := not(v_vehicles[v_idx].detected);
                            break;
                        }
                    } // End of 'for' statement
                    if (v_idx < SIMULTANEOUS_VEHICLE_NUM) {
                        v_vehicles[v_idx].stationId := v_stationID;
                    } else if (v_idx == SIMULTANEOUS_VEHICLE_NUM) {
                        log("*** " & testcasename() & ": ERROR: Increase the size of the file ***");
                        stop;
                    }
                    //v_isInDetectionZone := f_isLocationInsideRectangularRegion(c_detectionArea, v_location);
                    v_isInDetectionZone := f_isInApproach(PX_UC6_APPROACH_POINT_Z2, v_location, 100.0);
                    log("v_idx:               ", v_idx);
                    log("v_vehicles[v_idx]:   ", v_vehicles[v_idx]);
                    log("v_notProcessed:      ", v_notProcessed);
                    log("v_isInDetectionZone: ", v_isInDetectionZone);
                    if (v_notProcessed == true) { // Vehicle not processed yet                    
                        if (v_isInDetectionZone == true) { // Check if it entered into the rectangular area
                            /*if (v_vehicles[v_idx].detectionCounter == 0) { // First detection, wait one CAM to confrm detection
                                // Prepare component
                                v_vehicles[v_idx].detectionCounter := v_vehicles[v_idx].detectionCounter + 1;*/
                                v_vehicles[v_idx].component_ := ItsRSUsSimulator.create("Node" & int2char(v_idx + 65)) alive;
                                // Wait next message in detection area
                            /*} else {*/
                                log("*** " & testcasename() & ": DEBUG: StationID: " & int2str(v_stationID) & " is entering in area ***");
                                v_vehicles[v_idx].detectionCounter := 1;/*0;*/
                                v_vehicles[v_idx].detected := true;
                                v_vehicles[v_idx].component_.start(f_startVehicleSimulator(v_vehicles[v_idx].component_, v_idx, v_camValue));
                            /*}*/
                        } else {
                            // Nothing to do
    //                        log("*** " & testcasename() & ": DEBUG: StationID: " & int2str(v_stationID) & " is outside of area ***");
                            v_vehicles[v_idx].detectionCounter := 0;
                            v_vehicles[v_idx].detected := false;
                            //v_vehicles[v_idx].stationId := 0;
                        }
                    } else if (v_isInDetectionZone == false) {
                        if (v_vehicles[v_idx].detected == true) { // Remove station if from v_stationIDs
                            log("*** " & testcasename() & ": DEBUG: Remove stationID: " & int2str(v_stationID) & " ***");
                            v_vehicles[v_idx].detectionCounter := 0;
                            v_vehicles[v_idx].detected := false;
                            //v_vehicles[v_idx].stationId := 0;
                            v_vehicles[v_idx].component_.kill;
                        } else {
                            v_vehicles[v_idx].detectionCounter := 0;
                            v_vehicles[v_idx].detected := false;
                            //v_vehicles[v_idx].stationId := 0;
                        }
garciay's avatar
garciay committed
                    } else {
                        // Nothing to do
                        log("*** " & testcasename() & ": DEBUG: StationID: " & int2str(v_stationID) & " already processed ***");
garciay's avatar
garciay committed
                    }
                    tc_ac.start;
                    repeat;
garciay's avatar
garciay committed
            [] geoNetworkingPort.receive(
                mw_geoNwInd(
                    mw_geoNwPdu(
                       ?
            ))) -> value v_gnInd { // Receive a CAM message
                tc_ac.stop;
//                log("v_gnInd = ", v_gnInd);
                tc_ac.start;
                repeat;
            }
garciay's avatar
garciay committed
            [] tc_ac.timeout {
                log("*** " & testcasename() & ": DEBUG: No CAM message received ***");
garciay's avatar
garciay committed
                //all component.stop;
                tc_ac.start;
                repeat;
garciay's avatar
garciay committed
            }
        } // End of 'alt' statement
        f_selfOrClientSyncAndVerdictTestBody(c_tbDone, e_success);
        
        // Postamble
garciay's avatar
garciay committed
        for (v_idx := 0; v_idx < lengthof(v_vehicles); v_idx := v_idx + 1) {
garciay's avatar
garciay committed
            if (isbound(v_vehicles[v_idx].component_)) {
                v_vehicles[v_idx].component_.kill;
            }
garciay's avatar
garciay committed
        } // End of 'for' statement
        ItsRSUsSimulator_Functions.f_cf01Down();
garciay's avatar
garciay committed
        
    } // End of TC_RSUSIMU_BV_02
    
    group tc_RSUSIMU_BV_02 {
        
        function f_startVehicleSimulator(
                                         in ItsRSUsSimulator p_component,
garciay's avatar
garciay committed
                                         in integer p_vehicleIndex,
                                         in CAM p_camVehicle
garciay's avatar
garciay committed
        ) runs on ItsRSUsSimulator {
            
            // Local variables
            const SequenceOfRectangularRegion c_detectionArea := { valueof(PICS_UC6_CAM_DETECTION_AREA_Z2) }; // PICS_UC6_CAM_DETECTION_AREA_Z1
            var GeoNetworkingInd v_gnInd;
            var template (value) CAM v_camSimu;
garciay's avatar
garciay committed
            var ThreeDLocation v_location;
garciay's avatar
garciay committed
            var boolean v_inArea;
garciay's avatar
garciay committed
            
garciay's avatar
garciay committed
            f_initialiseVehicleSimulatorComponent(p_component, p_vehicleIndex, v_camSimu);
garciay's avatar
garciay committed
            
garciay's avatar
garciay committed
            tc_ac.start;
garciay's avatar
garciay committed
            geoNetworkingPort.clear;
garciay's avatar
garciay committed
            alt {
                [] geoNetworkingPort.receive(
                    mw_geoNwInd(
                        mw_geoNwPdu(
                            mw_geoNwShbPacketWithNextHeader_cam(
                                -,
                                -,
                                e_btpB,
                                mw_cam_stationID(
                                    -,
                                    p_camVehicle.header.stationID
                ))))) -> value v_gnInd { // Receive a CAM message from the processed vehicle
                    var CAM v_camValue; // Assume BTP/CAM payload is well formed
                    var bitstring v_payload;
                    var integer v_result;
                    
garciay's avatar
garciay committed
                    tc_ac.stop;
garciay's avatar
garciay committed
//                    log("*** " & testcasename() & ": DEBUG: Processing CAM #" & int2str(p_camVehicle.header.stationID) & " ***");
                    v_payload := oct2bit(substr(v_gnInd.msgIn.gnPacket.packet.payload, 4, lengthof(v_gnInd.msgIn.gnPacket.packet.payload) - 4));
                    v_result := decvalue(v_payload, v_camValue);
                    if (isbound(v_camValue)) {
                        if (PICS_USE_LPV == true) {
                            v_location := {
                                v_gnInd.msgIn.gnPacket.packet.extendedHeader.shbHeader.srcPosVector.latitude,
                                v_gnInd.msgIn.gnPacket.packet.extendedHeader.shbHeader.srcPosVector.longitude,
                                0
                            };
                        } else {
                            v_location := {
                                v_camValue.cam.camParameters.basicContainer.referencePosition.latitude,
                                v_camValue.cam.camParameters.basicContainer.referencePosition.longitude,
                                v_camValue.cam.camParameters.basicContainer.referencePosition.altitude.altitudeValue
                            };
                        }
                        f_mirror_and_send_vehicle_cam(v_camSimu, v_camValue, v_location/*To be removed*/);
                        // Check if the behicule leave the area
                        //v_inArea := f_isLocationInsideRectangularRegion(c_detectionArea, v_location);
                        v_inArea := f_isInApproach(PX_UC6_APPROACH_POINT_Z2, v_location, 100.0);
    
                        log("*** " & testcasename() & ": DEBUG: In area: ", v_inArea, " ***");
                        if (v_inArea == true) {
                            tc_ac.start;
                            repeat;
                        } else {
                            log("*** " & testcasename() & ": PASS: Terminate component for #" & int2str(p_camVehicle.header.stationID) & " ***");
                            f_setVerdict(e_success);
                        }
garciay's avatar
garciay committed
                    }
garciay's avatar
garciay committed
                [] tc_ac.timeout {
                    log("*** " & testcasename() & ": DEBUG: No CAM message received ***");
garciay's avatar
garciay committed
                }
            } // End of 'altstep' statement
            
            f_uninitialiseVehicleSimulatorComponent(p_component);
garciay's avatar
garciay committed
            log("*** " & testcasename() & ": DEBUG: Exit ***");
garciay's avatar
garciay committed
            
        } // End of f_startVehicleSimulator
        
    } // End of group tc_RSUSIMU_BV_02 
} // End of module ItsRSUsSimulator_TestCases