/** * @author ETSI / STF569 * @version $URL:$ * $ID:$ * @desc This module provides the MEC test cases. * @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. * @see ETSI GS MEC 003, Draft ETSI GS MEC 013 V2.0.3 (2018-10) */ module AtsMec_AppLCM_TestCases { // Libcommon import from LibCommon_Sync all; // LibHttp import from LibItsHttp_TypesAndValues all; import from LibItsHttp_Functions all; import from LibItsHttp_Templates all; import from LibItsHttp_JsonTemplates all; import from LibItsHttp_TestSystem all; import from AppLCM_Templates all; import from AppLCM_Pics all; import from AppLCM_Pixits all; // LibMec import from LibMec_Functions all; import from LibMec_Pics all; import from LibMec_Pixits all; group App_lifecycle_management { /** * @desc: Check that MEC API provider creates a new App Package when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.1.3.1 * ETSI GS MEC 010-2 2.0.10, Table 6.2.2.3.2-1 //CreateAppInstanceRequest * ETSI GS MEC 010-2 2.0.10, Table 6.2.2.4.2-1 //AppInstanceInfo */ testcase TP_MEC_MEX_LCM_001_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI, v_headers, m_http_message_body_json( m_body_json_lifecycle_management( m_lifecycle_management_create( PX_APP_D_ID ) ) ) ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_201_created( mw_http_message_body_json( mw_body_json_mex_lcm_instance_info( mw_lcm_instance_info( -, PX_APP_D_ID, PX_INSTANTIATION_STATE ) ))))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with the App LCM Instance info details ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_001_OK /** * @desc: Check that MEC API provider sends an error when it receives * a malformed request for the creation of a new App Instance * ETSI GS MEC 010-2 2.0.10, clause 7.5.1.3.1 * ETSI GS MEC 010-2 2.0.10, Table 6.2.2.3.2-1 //CreateAppInstanceRequest */ testcase TP_MEC_MEX_LCM_001_BR() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI, v_headers, m_http_message_body_json( m_body_json_lifecycle_management_with_error( m_lifecycle_management_create_with_error( PX_APP_D_ID ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_400_bad_request( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a Bad response ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_001_BR /** * @desc: Check that MEC API provider retrieves the list of App instances when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.1.3.2 * ETSI GS MEC 010-2 2.0.10, Table 6.2.3.3.2-1 //AppInstanceInfo */ testcase TP_MEC_MEX_LCM_002_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_URI, v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_mex_lcm_instance_info_list({ *, mw_lcm_instance_info( PX_APP_INSTANCE_ID, -, - ), * } ) ) ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with an App LCM instance info and 200 status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_002_OK /** * @desc: Check that MEC API provider retrieves an App Package when requested * @see: ETSI GS MEC 010-2 2.0.10, clause 7.5.2.3.2 * ETSI GS MEC 010-2 2.0.10, Table 6.2.2.4.2-1 */ testcase TP_MEC_MEX_LCM_003_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")), v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_mex_lcm_instance_info( mw_lcm_instance_info( PX_APP_INSTANCE_ID, -, - ) ))))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a App instance info ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_003_OK /** * @desc: Check that MEC API provider fails on retrieving an App Instance when requested using wrong appInstanceId * @see: ETSI GS MEC 010-2 2.0.10, clause 7.5.2.3.2 */ testcase TP_MEC_MEX_LCM_003_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_INSTANCE_ID, "UTF-8")) &"/app_descriptor", v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_003_NF /** * @desc: Check that MEC API provider service deletes an App Instance when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.2.3.4 */ testcase TP_MEC_MEX_LCM_004_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_delete( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")), v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_204_no_content )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 204 no content status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_004_OK /** * @desc: Check that MEC API provider fails on deletion of an App Instance when requested using wrong appInstanceId * @see: ETSI GS MEC 010-2 2.0.10, clause 7.5.2.3.2 */ testcase TP_MEC_MEX_LCM_004_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_delete( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_INSTANCE_ID, "UTF-8")), v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_004_NF /** * @desc: Check that MEC API provider service instantiates an App Instance when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.6.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.7.2-1 //InstantiateAppRequest */ testcase TP_MEC_MEX_LCM_005_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/instantiate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_instantiate( m_lifecycle_management_instantiate( PX_APP_D_ID ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_202_accepted( ))) -> value v_response { tc_ac.stop; if (f_check_headers(v_response.response.header) == true) { log("*** " & testcasename() & ": PASS: IUT successfully responds with a 202 accepted***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } else { log("*** " & testcasename() & ": FAIL: Header 'Location' was not present in the response headers ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_error); } } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_005_OK /** * @desc: Check that MEC API providerservice fails to instantiate an App Instance when * it receives a request related to a not existing App Instance * ETSI GS MEC 010-2 2.0.10, clause 7.5.6.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.7.2-1 //InstantiateAppRequest */ testcase TP_MEC_MEX_LCM_005_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_INSTANCE_ID, "UTF-8")) & "/instantiate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_instantiate( m_lifecycle_management_instantiate( PX_APP_D_ID ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_005_NF /** * @desc: Check that MEC API provider service fails to instantiate an App Instance when it receives a malformed request * ETSI GS MEC 010-2 2.0.10, clause 7.5.6.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.7.2-1 //InstantiateAppRequest */ testcase TP_MEC_MEX_LCM_005_BR() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/instantiate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_instantiate_with_error( m_lifecycle_management_instantiate_with_error( PX_APP_D_ID ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_400_bad_request( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 400 bad request status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_005_BR /** * @desc: Check that MEC API provider service terminates an App Instance when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.7.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.9.2-1 //TerminateAppRequest */ testcase TP_MEC_MEX_LCM_006_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/terminate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_terminate( m_lifecycle_management_terminate( PX_APP_TERMINATION_TYPE ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_202_accepted( ))) -> value v_response { tc_ac.stop; if (f_check_headers(v_response.response.header) == true) { log("*** " & testcasename() & ": PASS: IUT successfully responds with a 202 accepted***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } else { log("*** " & testcasename() & ": FAIL: Header 'Location' was not present in the response headers ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_error); } } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_006_OK /** * @desc: Check that MEC API providerservice fails to terminate an App Instance when * it receives a request related to a not existing App Instance * ETSI GS MEC 010-2 2.0.10, clause 7.5.7.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.9.2-1 //TerminateAppRequest */ testcase TP_MEC_MEX_LCM_006_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_INSTANCE_ID, "UTF-8")) & "/terminate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_terminate( m_lifecycle_management_terminate( PX_APP_TERMINATION_TYPE ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_006_NF /** * @desc: Check that MEC API providerservice fails to terminate an App Instance when it receives a malformed request * ETSI GS MEC 010-2 2.0.10, clause 7.5.7.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.9.2-1 //TerminateAppRequest */ testcase TP_MEC_MEX_LCM_006_BR() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/terminate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_terminate_with_error( m_lifecycle_management_terminate_with_error( PX_APP_TERMINATION_TYPE_WITH_ERROR ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_400_bad_request( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 400 Bad Request status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_006_BR /** * @desc: Check that MEC API provider service terminates an App Instance when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.8.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.8.2-1 //OperateAppRequest */ testcase TP_MEC_MEX_LCM_007_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/operate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_operate( m_lifecycle_management_operate( PX_CHANGE_STATE_TO ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_202_accepted( ))) -> value v_response { tc_ac.stop; if (f_check_headers(v_response.response.header) == true) { log("*** " & testcasename() & ": PASS: IUT successfully responds with a 202 accepted***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } else { log("*** " & testcasename() & ": FAIL: Header 'Location' was not present in the response headers ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_error); } } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_007_OK /** * @desc: Check that MEC API provider service fails to change the status of an App Instance * when it receives a request related to a not existing App Instance * ETSI GS MEC 010-2 2.0.10, clause 7.5.8.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.8.2-1 //OperateAppRequest */ testcase TP_MEC_MEX_LCM_007_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_INSTANCE_ID, "UTF-8")) & "/operate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_operate( m_lifecycle_management_operate( PX_CHANGE_STATE_TO ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_007_NF /** * @desc: Check that MEC API provider service fails to operate on an App Instance when it receives a malformed request * ETSI GS MEC 010-2 2.0.10, clause 7.5.8.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.8.2-1 //OperateAppRequest */ testcase TP_MEC_MEX_LCM_007_BR() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_URI & oct2char(unichar2oct(PX_APP_INSTANCE_ID, "UTF-8")) & "/operate", v_headers, m_http_message_body_json( m_body_json_lifecycle_management_operate_with_error( m_lifecycle_management_operate_with_error( PX_CHANGE_STATE_TO_WITH_ERROR ) ) ) ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_400_bad_request( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with a 400 Bad Request status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_007_BR /** * @desc: Check that MEC API provider service retrieves info about LCM Operation Occurrency on App Instances when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.9.3.2 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.14.2-1" //AppLcmOpOcc */ testcase TP_MEC_MEX_LCM_008_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_OP_OCC_URI, v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_lifecycle_op_occ_list({ *, mw_lifecycle_management_op_occ( PX_APP_LCM_OP_OCC_ID ), * } ) ) ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with App LCM Operation Occurrencies info and 200 status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_008_OK /** * @desc: Check that MEC API provider service retrieves info about LCM Operation Occurrency on an App Instance when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.9.3.2 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.14.2-1" //AppLcmOpOcc */ testcase TP_MEC_MEX_LCM_009_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_OP_OCC_URI & oct2char(unichar2oct(PX_APP_LCM_OP_OCC_ID, "UTF-8")), v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_lifecycle_op_occ( mw_lifecycle_management_op_occ( PX_APP_LCM_OP_OCC_ID ) ) ) ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with the requested App LCM Operation Occurrency and 200 status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_009_OK /** * @desc:Check that MEC API provider service sends an error when it receives a query for a not existing LCM Operation Occurrency * ETSI GS MEC 010-2 2.0.10, clause 7.5.9.3.2 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.14.2-1" //AppLcmOpOcc */ testcase TP_MEC_MEX_LCM_009_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_OP_OCC_URI & oct2char(unichar2oct(PX_NON_EXISTENT_APP_LCM_OP_OCC_ID, "UTF-8")), v_headers ))); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with 404 not found status code ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_009_NF } // End of App_lifecycle_management group app_lcm_subscriptions { /** * @desc: Check that MEC API provider service creates a LCM Subscription when requested, * where the subscription request can have SUBSCRIPTION_TYPE: * - AppInstanceStateChangeSubscription * - AppLcmOpOccStateChangeSubscription * ETSI GS MEC 010-2 2.0.10, clause 7.5.3.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.13.2-1 //AppInstSubscriptionRequest * ETSI GS MEC 010-2 2.0.10, table 6.2.2.10.2-1 //AppInstSubscriptionInfo */ testcase TP_MEC_MEX_LCM_010_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS, v_headers, m_http_message_body_json( m_body_json_lcm_subscribe( m_app_lcm_subscribe_request( PX_SUBSCRIPTION_TYPE, PX_CALLBACK_URI ) ) ) ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_201_created( mw_http_message_body_json( mw_body_json_lcm_subscription( mw_app_lcm_subscription_info( -, PX_SUBSCRIPTION_TYPE, PX_CALLBACK_URI) ))))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with the new created subscription ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_010_OK /** * @desc: Check that MEC API providerservice sends an error when it receives a * malformed request to create a LCM Subscription * ETSI GS MEC 010-2 2.0.10, clause 7.5.3.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.13.2-1 //AppInstSubscriptionRequest */ testcase TP_MEC_MEX_LCM_010_BR() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS, v_headers, m_http_message_body_json( m_body_json_lcm_subscribe_with_error( m_app_lcm_subscribe_request_with_error( PX_SUBSCRIPTION_TYPE, PX_CALLBACK_URI ) ) ) ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_400_bad_request( ))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds a 400 Bad request ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_010_BR /** * @desc: Check that MEC API provider service sends the list of LCM Subscriptions when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.3.3.2 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.13.2-1 // AppInstSubscriptionRequest * ETSI GS MEC 010-2 2.0.10, table 6.2.2.15.2-1 // AppLcmOpOccSubscriptionRequest * ETSI GS MEC 010-2 2.0.10, table 6.2.2.10.2-1 // AppInstSubscriptionInfo * ETSI GS MEC 010-2 2.0.10, table 6.2.2.16.2-1 // AppLcmOpOccSubscriptionInfo */ testcase TP_MEC_MEX_LCM_011_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_post( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS, v_headers ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_lcm_subscription_list({ *, mw_app_lcm_subscription_info( -, PX_SUBSCRIPTION_TYPE, PX_CALLBACK_URI ), * } ))))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with the list of available subscriptions ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_011_OK /** * @desc: Check that MEC API provider service sends the information about an existing LCM subscription when requested * ETSI GS MEC 010-2 2.0.10, clause 7.5.4.3.2 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.10.2-1 // AppInstSubscriptionInfo * ETSI GS MEC 010-2 2.0.10, table 6.2.2.16.2-1 // AppLcmOpOccSubscriptionInfo */ testcase TP_MEC_MEX_LCM_012_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS & oct2char(unichar2oct(PX_SUBSCRIPTION_ID, "UTF-8")), v_headers ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_ok( mw_http_message_body_json( mw_body_json_lcm_subscription( mw_app_lcm_subscription_info( PX_SUBSCRIPTION_ID, PX_SUBSCRIPTION_TYPE, PX_CALLBACK_URI ) ))))) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with the subscription requested ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_012_OK /** * @desc: Check that MEC API provider service sends an error when it receives a query for a not existing LCM Subscription * ETSI GS MEC 010-2 2.0.10, clause 7.5.4.3.2 */ testcase TP_MEC_MEX_LCM_012_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_get( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS & oct2char(unichar2oct(PX_NON_ESISTENT_SUBSCRIPTION_ID, "UTF-8")), v_headers ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with 404 not found ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_012_NF /** * @desc: Check that MEC API provider service delete an existing LCM Subscription when requested * ETSI GS MEC 010-2 2.0.10, clause 7.3.4.3.4 */ testcase TP_MEC_MEX_LCM_013_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_delete( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS & oct2char(unichar2oct(PX_SUBSCRIPTION_ID, "UTF-8")), v_headers ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_204_no_content )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds 204 No Content ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_013_OK /** * @desc: Check that MEC API provider service delete an existing LCM Subscription when requested * ETSI GS MEC 010-2 2.0.10, clause 7.3.4.3.4 */ testcase TP_MEC_MEX_LCM_013_NF() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; var HttpMessage v_response; // Test control if (not(PIC_APP_LCM_MANAGEMENT)){ log("*** " & testcasename() & ": PIC_APP_LCM_MANAGEMENT required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_up(); // Preamble f_init_default_headers_list(-, -, v_headers); httpPort.send( m_http_request( m_http_request_delete( "/" & PICS_ROOT_API & PX_MEX_LCM_SUBS & oct2char(unichar2oct(PX_NON_ESISTENT_SUBSCRIPTION_ID, "UTF-8")), v_headers ) )); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_ac.start; alt { [] httpPort.receive( mw_http_response( mw_http_response_404_not_found( ) )) -> value v_response { tc_ac.stop; log("*** " & testcasename() & ": PASS: IUT successfully responds with 404 not found ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_ac.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement } // End of testcase TP_MEC_MEX_LCM_013_NF } // end of group app_lcm_subscriptions group app_lcm__notification { /** * @desc Check that MEC API provider sends a notification to the subscriber * when an application lcm change event occurs * @see ETSI GS MEC 010-2 2.0.10, clause 7.5.5.3.1 * ETSI GS MEC 010-2 2.0.10, table 6.2.2.18.2-1 // AppLcmOpOccNotification * ETSI GS MEC 010-2 2.0.10, table 6.2.2.12.2-1 // AppInstNotification */ testcase TP_MEC_MEX_LCM_014_OK() runs on HttpComponent system HttpTestAdapter { // Local variables var HeaderLines v_headers; // Test control if (not(PIC_APP_PACKAGE_NOTIFICATIONS)) { log("*** " & testcasename() & ": PIC_APP_PACKAGE_NOTIFICATIONS required for executing the TC ***"); setverdict(inconc); stop; } // Test component configuration f_cf_01_http_notif_up(); // Test adapter configuration // Preamble f_init_default_headers_list(-, -, v_headers); action("Trigger a expire notification event"); f_selfOrClientSyncAndVerdict(c_prDone, e_success); // Test Body tc_wait.start; alt { [] httpPort_notif.receive( mw_http_request( mw_http_request_post( oct2char(unichar2oct(PX_CALLBACK_URI)), -, mw_http_message_body_json( mw_body_json_lcm_notification( mw_app_lcm_notification( PX_NOTIFICATION_ID, PX_NOTIFICATION_TYPE ) ) ) ) ) ) { tc_wait.stop; log("*** " & testcasename() & ": INFO: IUT successfully sends notification ***"); // Send 204 No Content httpPort_notif.send(m_http_response(m_http_response_204_no_content(v_headers))); log("*** " & testcasename() & ": PASS: IUT successfully sends notification ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_success); } [] tc_wait.timeout { log("*** " & testcasename() & ": INCONC: Expected message not received ***"); f_selfOrClientSyncAndVerdict(c_tbDone, e_timeout); } } // End of 'alt' statement // Postamble f_cf_01_http_notif_down(); } } // end of group app_lcm__notification } // End of module AtsMec_PkgMgmt_mm1_TestCases