Skip to content
Snippets Groups Projects
Commit 9f9a408f authored by Pramod Kulkarni's avatar Pramod Kulkarni
Browse files

Merge branch 'Test_architecture_improvement' of https://git.onem2m.org/TST/ATS...

Merge branch 'Test_architecture_improvement' of https://git.onem2m.org/TST/ATS into Test_architecture_improvement
parents c787507d a1323038
No related branches found
No related tags found
No related merge requests found
...@@ -417,6 +417,9 @@ module OneM2M_Functions { ...@@ -417,6 +417,9 @@ module OneM2M_Functions {
function f_cse_preamble_subscriptionVerification(out AeSimu p_ae2,in integer p_aeIndex, inout integer p_ae2Index, inout template RequestPrimitive p_createRequestPrimitive,in ResourceType p_resourceType, in ResponseStatusCode p_responseStatusCode := int2001) runs on AeSimu { function f_cse_preamble_subscriptionVerification(out AeSimu p_ae2,in integer p_aeIndex, inout integer p_ae2Index, inout template RequestPrimitive p_createRequestPrimitive,in ResourceType p_resourceType, in ResponseStatusCode p_responseStatusCode := int2001) runs on AeSimu {
if(p_resourceType == int23){ if(p_resourceType == int23){
p_ae2 := AeSimu.create("AE2") alive; p_ae2 := AeSimu.create("AE2") alive;
map(p_ae2:mcaPort, system:mcaPort);
map(p_ae2:mcaPortIn, system:mcaPortIn);
//TODO shall be unmapped?
p_ae2.start(f_cse_createResource(int2, m_createAe(PX_APP_ID, -, PX_AE2_ID_STEM, "MyAe2", {f_getAnnouncementTargetPoA("HTTP", PX_AE2_ADDRESS, "")}), -1)); // AE2 is registred p_ae2.start(f_cse_createResource(int2, m_createAe(PX_APP_ID, -, PX_AE2_ID_STEM, "MyAe2", {f_getAnnouncementTargetPoA("HTTP", PX_AE2_ADDRESS, "")}), -1)); // AE2 is registred
p_ae2.done; p_ae2.done;
p_ae2Index := f_getResource(p_ae2); p_ae2Index := f_getResource(p_ae2);
...@@ -546,6 +549,43 @@ module OneM2M_Functions { ...@@ -546,6 +549,43 @@ module OneM2M_Functions {
} }
/**
@desc
*/
function f_getRequestPrimitive(in AeSimu p_ae) runs on Tester return RequestPrimitive {
var RequestPrimitive v_request;
f_connectInfoPort(p_ae);
p_ae.start(f_sendRequestPrimitive());
alt {
[]infoPort.receive(mw_requestPrimitiveforInfoPort) -> value v_request {
}
}
f_disconnectInfoPort(p_ae);
return v_request;
}
function f_getRemoteCseRequestPrimitive(in CseSimu p_cse) runs on Tester return RequestPrimitive {
var RequestPrimitive v_request;
f_connectInfoPort(p_cse);
p_cse.start(f_sendRemoteCseRequestPrimitive());
alt {
[]infoPort.receive(mw_requestPrimitiveforInfoPort) -> value v_request {
}
}
f_disconnectInfoPort(p_cse);
return v_request;
}
/** /**
@desc @desc
...@@ -619,6 +659,18 @@ module OneM2M_Functions { ...@@ -619,6 +659,18 @@ module OneM2M_Functions {
} }
function f_sendRequestPrimitive() runs on AeSimu {
infoPort.send(vc_request.primitive.requestPrimitive);
}
function f_sendRemoteCseRequestPrimitive() runs on CseSimu {
infoPort.send(vc_request.primitive.requestPrimitive);
}
function f_sendPrimitiveContentRetrievedResource() runs on AeSimu { function f_sendPrimitiveContentRetrievedResource() runs on AeSimu {
infoPort.send(vc_primitiveContentRetrievedResource); infoPort.send(vc_primitiveContentRetrievedResource);
...@@ -1476,11 +1528,9 @@ module OneM2M_Functions { ...@@ -1476,11 +1528,9 @@ module OneM2M_Functions {
*/ */
function f_cse_receiveCreateRequest(in template RequestPrimitive p_requestPrimitive := ?) runs on CseSimu { function f_cse_receiveCreateRequest(in template RequestPrimitive p_requestPrimitive := ?) runs on CseSimu {
var MsgIn v_request;
tc_ac.start; tc_ac.start;
alt { alt {
[] mccPort.receive(mw_request(p_requestPrimitive)) -> value v_request { [] mccPort.receive(mw_request(p_requestPrimitive)) -> value vc_request {
tc_ac.stop; tc_ac.stop;
setverdict(pass, __SCOPE__&":INFO: CREATE Request received successfuly"); setverdict(pass, __SCOPE__&":INFO: CREATE Request received successfuly");
} }
......
...@@ -102,6 +102,7 @@ module OneM2M_Pixits { ...@@ -102,6 +102,7 @@ module OneM2M_Pixits {
//NOTE: Apply to Device-based location request, and this requires Test System (TS) to activate ASN-AE mode to test IUT //NOTE: Apply to Device-based location request, and this requires Test System (TS) to activate ASN-AE mode to test IUT
modulepar boolean PX_IUT_IS_ASN_CSE := false; //default //set it to true when running Device-based location testcases modulepar boolean PX_IUT_IS_ASN_CSE := false; //default //set it to true when running Device-based location testcases
modulepar boolean PX_IUT_IS_MN_CSE := false; //default //set it to true when running Share-based location testcases modulepar boolean PX_IUT_IS_MN_CSE := false; //default //set it to true when running Share-based location testcases
modulepar boolean PX_IUT_IS_IN_CSE := false; //default //set it to true when running Share-based location testcases
//constant parameters for LOC //constant parameters for LOC
modulepar XSD.Token PX_LOCATION_TARGET_ID := "{LOCATION-TARGET-ID}"; //SUPPOSE TO BE RECEIVED FROM LOCATION SERVER modulepar XSD.Token PX_LOCATION_TARGET_ID := "{LOCATION-TARGET-ID}"; //SUPPOSE TO BE RECEIVED FROM LOCATION SERVER
......
...@@ -47,9 +47,9 @@ module OneM2M_Ports { ...@@ -47,9 +47,9 @@ module OneM2M_Ports {
*/ */
type port InfoPort message { type port InfoPort message {
in in
ResponsePrimitive, PrimitiveContent, MyResource; RequestPrimitive, ResponsePrimitive, PrimitiveContent, MyResource;
out out
ResponsePrimitive, PrimitiveContent, MyResource; RequestPrimitive, ResponsePrimitive, PrimitiveContent, MyResource;
} }
}//end module }//end module
...@@ -3309,6 +3309,8 @@ module OneM2M_Templates { ...@@ -3309,6 +3309,8 @@ module OneM2M_Templates {
template ResponsePrimitive mw_responsePrimitiveforInfoPort := ?; template ResponsePrimitive mw_responsePrimitiveforInfoPort := ?;
template RequestPrimitive mw_requestPrimitiveforInfoPort := ?;
template ResponsePrimitive mw_responsePrimitive(in template (present) ResponseStatusCode p_statusCode, in template PrimitiveContent p_content := *) := { template ResponsePrimitive mw_responsePrimitive(in template (present) ResponseStatusCode p_statusCode, in template PrimitiveContent p_content := *) := {
responseStatusCode := p_statusCode, responseStatusCode := p_statusCode,
requestIdentifier := ?, requestIdentifier := ?,
......
...@@ -4681,7 +4681,8 @@ module OneM2M_Testcases { ...@@ -4681,7 +4681,8 @@ module OneM2M_Testcases {
var RequestPrimitive v_requestPrimitive; var RequestPrimitive v_requestPrimitive;
var XSD.NonNegativeInteger maxByteSize := 512; //Correct value? Shall be indicated in TP? var XSD.NonNegativeInteger maxByteSize := 512; //Correct value? Shall be indicated in TP?
v_createRequest.primitiveContent.container.announceTo := {f_getAnnouncementTargetPoA()}; //v_createRequest.primitiveContent.container.announceTo := {f_getAnnouncementTargetPoA()};
v_createRequest.primitiveContent.container.announceTo := {PX_CSE1_ID};
v_createRequest.primitiveContent.container.maxByteSize := maxByteSize; v_createRequest.primitiveContent.container.maxByteSize := maxByteSize;
v_createRequest.primitiveContent.container.announcedAttribute := {"maxByteSize"}; //Correct value? Shall be indicated in TP? v_createRequest.primitiveContent.container.announcedAttribute := {"maxByteSize"}; //Correct value? Shall be indicated in TP?
...@@ -4690,6 +4691,7 @@ module OneM2M_Testcases { ...@@ -4690,6 +4691,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if maxByteSize attribute has been announced //Check if maxByteSize attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.containerAnnc.maxByteSize)){ if (ispresent(v_requestPrimitive.primitiveContent.containerAnnc.maxByteSize)){
if(v_requestPrimitive.primitiveContent.containerAnnc.maxByteSize != maxByteSize){ if(v_requestPrimitive.primitiveContent.containerAnnc.maxByteSize != maxByteSize){
setverdict(fail, __SCOPE__ & ": Error: Value of maxByteSize has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of maxByteSize has not been announced successfully");
...@@ -4709,7 +4711,8 @@ module OneM2M_Testcases { ...@@ -4709,7 +4711,8 @@ module OneM2M_Testcases {
var RequestPrimitive v_requestPrimitive; var RequestPrimitive v_requestPrimitive;
var XSD.NonNegativeInteger v_contentSize := 512; //Correct value? Shall be indicated in TP? var XSD.NonNegativeInteger v_contentSize := 512; //Correct value? Shall be indicated in TP?
v_createRequest.primitiveContent.contentInstance.announceTo := {f_getAnnouncementTargetPoA()}; //v_createRequest.primitiveContent.contentInstance.announceTo := {f_getAnnouncementTargetPoA()};
v_createRequest.primitiveContent.contentInstance.announceTo := {PX_CSE1_ID};
v_createRequest.primitiveContent.contentInstance.contentSize := v_contentSize; v_createRequest.primitiveContent.contentInstance.contentSize := v_contentSize;
v_createRequest.primitiveContent.contentInstance.announcedAttribute := {"contentSize"}; //Correct value? Shall be indicated in TP? v_createRequest.primitiveContent.contentInstance.announcedAttribute := {"contentSize"}; //Correct value? Shall be indicated in TP?
...@@ -4718,6 +4721,7 @@ module OneM2M_Testcases { ...@@ -4718,6 +4721,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if contentSize attribute has been announced //Check if contentSize attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.contentInstanceAnnc.contentSize)){ if (ispresent(v_requestPrimitive.primitiveContent.contentInstanceAnnc.contentSize)){
if(v_requestPrimitive.primitiveContent.contentInstanceAnnc.contentSize != v_contentSize){ if(v_requestPrimitive.primitiveContent.contentInstanceAnnc.contentSize != v_contentSize){
setverdict(fail, __SCOPE__ & ": Error: Value of contentSize has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of contentSize has not been announced successfully");
...@@ -4746,6 +4750,7 @@ module OneM2M_Testcases { ...@@ -4746,6 +4750,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if maxNrOfMembers attribute has been announced //Check if maxNrOfMembers attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.groupAnnc.maxNrOfMembers)){ if (ispresent(v_requestPrimitive.primitiveContent.groupAnnc.maxNrOfMembers)){
if(v_requestPrimitive.primitiveContent.groupAnnc.maxNrOfMembers != maxNrOfMembers){ if(v_requestPrimitive.primitiveContent.groupAnnc.maxNrOfMembers != maxNrOfMembers){
setverdict(fail, __SCOPE__ & ": Error: Value of maxNrOfMembers has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of maxNrOfMembers has not been announced successfully");
...@@ -4774,6 +4779,7 @@ module OneM2M_Testcases { ...@@ -4774,6 +4779,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if locationSource attribute has been announced //Check if locationSource attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.locationPolicyAnnc.locationSource)){ if (ispresent(v_requestPrimitive.primitiveContent.locationPolicyAnnc.locationSource)){
if(v_requestPrimitive.primitiveContent.locationPolicyAnnc.locationSource != locationSource){ if(v_requestPrimitive.primitiveContent.locationPolicyAnnc.locationSource != locationSource){
setverdict(fail, __SCOPE__ & ": Error: Value of locationSource has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of locationSource has not been announced successfully");
...@@ -4802,6 +4808,7 @@ module OneM2M_Testcases { ...@@ -4802,6 +4808,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if description attribute has been announced //Check if description attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.announcedMgmtResource.description)){ if (ispresent(v_requestPrimitive.primitiveContent.announcedMgmtResource.description)){
if(v_requestPrimitive.primitiveContent.announcedMgmtResource.description != description){ if(v_requestPrimitive.primitiveContent.announcedMgmtResource.description != description){
setverdict(fail, __SCOPE__ & ": Error: Value of description has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of description has not been announced successfully");
...@@ -4844,6 +4851,7 @@ module OneM2M_Testcases { ...@@ -4844,6 +4851,7 @@ module OneM2M_Testcases {
if(getverdict == pass){ if(getverdict == pass){
//Check if scheduleElement attribute has been announced //Check if scheduleElement attribute has been announced
v_requestPrimitive := f_getRequestPrimitive(v_ae1);
if (ispresent(v_requestPrimitive.primitiveContent.scheduleAnnc.scheduleElement)){ if (ispresent(v_requestPrimitive.primitiveContent.scheduleAnnc.scheduleElement)){
if(v_requestPrimitive.primitiveContent.scheduleAnnc.scheduleElement != scheduleElement){ if(v_requestPrimitive.primitiveContent.scheduleAnnc.scheduleElement != scheduleElement){
setverdict(fail, __SCOPE__ & ": Error: Value of scheduleElement has not been announced successfully"); setverdict(fail, __SCOPE__ & ": Error: Value of scheduleElement has not been announced successfully");
...@@ -4856,13 +4864,16 @@ module OneM2M_Testcases { ...@@ -4856,13 +4864,16 @@ module OneM2M_Testcases {
} }
} }
function f_CSE_DMR_CRE_017(ResourceType p_resourceType, template RequestPrimitive p_requestPrimitive, template (present) RequestPrimitive p_requestAnnc) runs on AeSimu return RequestPrimitive{ function f_CSE_DMR_CRE_017(ResourceType p_resourceType, template RequestPrimitive p_requestPrimitive, template (present) RequestPrimitive p_requestAnnc) runs on AeSimu{
// Local variables // Local variables
var MsgIn v_anncRequest; var MsgIn v_anncRequest;
var RequestPrimitive v_request; var RequestPrimitive v_request;
var integer v_parentIndex := -1; var integer v_parentIndex := -1;
var integer v_containerIndex := -1; var integer v_containerIndex := -1;
var integer v_remoteCseIndex;
var integer v_aeAnncIndex;
var integer v_resourceIndex;
// Test control // Test control
...@@ -4872,7 +4883,17 @@ module OneM2M_Testcases { ...@@ -4872,7 +4883,17 @@ module OneM2M_Testcases {
// Test adapter configuration // Test adapter configuration
// Preamble // Preamble
v_parentIndex := f_cse_preamble_registerAe();//c_CRUDNDi);
if (PX_IUT_IS_MN_CSE == true) {
vc_cseSimu.start(f_cse_registrationRemoteCse(m_createRemoteCSEBase));
}else if (PX_IUT_IS_IN_CSE == true) {
vc_cseSimu.start(f_cse_registerRemoteCse(m_createRemoteCSEBase));
}
vc_cseSimu.done;
vc_cseSimu.start(f_cse_resourceAnnouncementHandler());
v_resourceIndex := f_cse_createResource(int2, m_createAe(PX_APP_ID, omit, omit));
vc_cseSimu.done;
if(p_resourceType == int4) { if(p_resourceType == int4) {
v_containerIndex := f_cse_createResource(int3, m_createContainerBase, v_parentIndex); v_containerIndex := f_cse_createResource(int3, m_createContainerBase, v_parentIndex);
...@@ -4881,17 +4902,20 @@ module OneM2M_Testcases { ...@@ -4881,17 +4902,20 @@ module OneM2M_Testcases {
// Test Body // Test Body
v_request := f_getCreateRequestPrimitive(p_resourceType, p_requestPrimitive, v_parentIndex); v_request := f_getCreateRequestPrimitive(p_resourceType, p_requestPrimitive, v_parentIndex);
vc_cseSimu.start(f_cse_receiveCreateRequest(p_requestAnnc)); vc_cseSimu.start(f_cse_receiveCreateRequest(p_requestAnnc));
vc_cseSimu.done; mcaPort.send(m_request(v_request));
vc_cseSimu.done;
vc_request.primitive.requestPrimitive := f_getRemoteCseRequestPrimitive(vc_cseSimu);
// Postamble // Postamble
f_cse_postamble_deleteResources(); f_cse_postamble_deleteResources();
// Tear down // Tear down
f_cf02Down(); f_cf02Down();
return v_anncRequest.primitive.requestPrimitive; //return v_anncRequest.primitive.requestPrimitive;
}//end f_CSE_DMR_CRE_017 }//end f_CSE_DMR_CRE_017
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment