*** Settings *** Documentation Testing PMSH functionality Library OperatingSystem Library RequestsLibrary Library String Library Process Resource ../../common.robot Test Teardown Delete All Sessions *** Variables *** ${PMSH_BASE_URL} https://${PMSH_IP}:8443 ${MR_SIM_BASE_URL} http://${MR_SIM_IP_ADDRESS}:3904 ${CBS_BASE_URL} https://${CBS_SIM_IP_ADDRESS}:10443 ${SUBSCRIPTION_ENDPOINT} /subscription ${MR_SIM_RESET} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/mr-sim-reset.json ${MR_AAI_PNF_CREATED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/aai-pnf-create.json ${MR_AAI_PNF_REMOVED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/aai-pnf-delete.json ${MR_POLICY_RESPONSE_PNF_EXISTING} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/policy-sub-created-pnf-existing.json ${MR_POLICY_RESPONSE_PNF_DELETED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/policy-sub-deleted-pnf-existing.json ${CBS_EXPECTATION_ADMIN_STATE_UNLOCKED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/cbs-expectation-unlocked-config.json ${CREATE_SUBSCRIPTION_DATA} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/create_subscription_request.json ${CREATE_SECOND_SUBSCRIPTION_DATA} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/create_second_subscription_request.json ${CREATE_SUBSCRIPTION_BAD_DATA} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/create_subscription_bad_request.json ${CREATE_SUBSCRIPTION_SCHEMA_ERROR_DATA} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/create_subscription_schema_error_request.json *** Test Cases *** Verify Get subscriptions with Network Functions None [Tags] PMSH_01 [Documentation] Verify Get all subscriptions when there are no defined subscriptions [Timeout] 10 seconds ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT} "" Should Be True ${resp.status_code} == 200 Should Contain ${resp.text} [] Verify Create Subscriptions API [Tags] PMSH_07 [Documentation] Verify Create Subscription API [Timeout] 60 seconds ${json_value}= json_from_file ${CREATE_SUBSCRIPTION_DATA} ${resp}= PostSubscriptionCall ${SUBSCRIPTION_ENDPOINT} ${json_value} Should Be True ${resp.status_code} == 201 ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT} "/subs_01" Should Be Equal As Strings ${resp.json()[0]['subscription']['subscriptionName']} subs_01 Verify database tables exist and are empty [Tags] PMSH_02 [Documentation] Verify database has been created and is empty [Timeout] 10 seconds ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT} "" Should Be True ${resp.status_code} == 200 Should Contain ${resp.text} [] Verify PNF detected in AAI when administrative state unlocked [Tags] PMSH_03 [Documentation] Verify PNF detected when administrative state unlocked [Timeout] 60 seconds SetAdministrativeStateToUnlocked Sleep 31 Allow PMSH time to pick up changes in CBS config ${resp}= GetMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_01 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['administrativeState']} UNLOCKED Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfMgStatus']} PENDING_CREATE Verify Policy response on MR is handled [Tags] PMSH_04 [Documentation] Verify policy response on MR is handled [Timeout] 60 seconds AddCreatePolicyResponeToMrSim Sleep 31 seconds Ensure Policy response on MR is picked up ResetMrSim ${resp}= GetMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_01 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['administrativeState']} UNLOCKED Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfMgStatus']} CREATED Verify AAI event on MR detailing new PNF being detected is handled [Tags] PMSH_05 [Documentation] Verify PNF created AAI event on MR is handled [Timeout] 60 seconds AddNewPnfToMrSim Sleep 25 seconds Give sim time to set expectation ResetMrSim ${resp}= GetMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_01 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['administrativeState']} UNLOCKED Should Be Equal As Strings ${resp.json()['networkFunctions'][1]['nfName']} pnf_newly_discovered Should Be Equal As Strings ${resp.json()['networkFunctions'][1]['nfMgStatus']} PENDING_CREATE Verify AAI event on MR detailing PNF being deleted is handled [Tags] PMSH_06 [Documentation] Verify PNF deleted AAI event on MR is handled [Timeout] 60 seconds RemoveNewPnfFromMrSim Sleep 21 seconds Ensure AAI event on MR is picked up ResetMrSim ${resp}= GetMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_01 Should Not Contain ${resp.text} pnf_newly_discovered Verify Create Subscription API for duplicate subscription Id [Tags] PMSH_08 [Documentation] Verify Create Subscription API for duplicate subscription Id [Timeout] 60 seconds ${json_value}= json_from_file ${CREATE_SUBSCRIPTION_DATA} ${resp}= PostSubscriptionCall ${SUBSCRIPTION_ENDPOINT} ${json_value} Should Be True ${resp.status_code} == 409 Should Contain ${resp.json()} subscription Name: subs_01 already exists. Verify Create Subscription API for schema error [Tags] PMSH_09 [Documentation] Verify Create Subscription API [Timeout] 60 seconds ${json_value}= json_from_file ${CREATE_SUBSCRIPTION_SCHEMA_ERROR_DATA} ${resp}= PostSubscriptionCall ${SUBSCRIPTION_ENDPOINT} ${json_value} Should Be True ${resp.status_code} == 400 Should Contain ${resp.json()['detail']} 'administrativeState' is a required property - 'subscription.measurementGroups.0.measurementGroup' Verify Create Subscription API for filter values missing [Tags] PMSH_10 [Documentation] Verify Create Subscription API [Timeout] 60 seconds ${json_value}= json_from_file ${CREATE_SUBSCRIPTION_BAD_DATA} ${resp}= PostSubscriptionCall ${SUBSCRIPTION_ENDPOINT} ${json_value} Should Be True ${resp.status_code} == 400 Should Contain ${resp.json()} At least one filter within nfFilter must not be empty Verify Get Measurement Group with Network Functions [Tags] PMSH_11 [Documentation] Verify Get Measurement Group with Network Functions by using MGName and SubName [Timeout] 60 seconds ${resp}= GetMeasGrpWithNFSCall /subscription/subs_01/measurementGroups/msg_grp_01 ${nf_length}= Get length ${resp.json()['networkFunctions']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['measurementGroupName']} msg_grp_01 Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should be equal as numbers ${nf_length} 1 Verify Get single subscription with Network Functions [Tags] PMSH_12 [Documentation] Verify Get single subscription with Network Functions by using subscription name [Timeout] 60 seconds ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT}/subs_01 "" ${nf_length}= Get length ${resp.json()['subscription']['nfs']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()['subscription']['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['subscription']['nfs'][0]} pnf-existing Should Be Equal As Strings ${resp.json()['subscription']['measurementGroups'][0]['measurementGroup']['measurementGroupName']} msg_grp_02 Should be equal as numbers ${nf_length} 1 Verify Get single subscription with Network Functions None [Tags] PMSH_13 [Documentation] Verify Get single subscription with Network Functions when there is no defined subscription [Timeout] 60 seconds ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT}/sub_none "" Should Be True ${resp.status_code} == 404 Should Be Equal As Strings ${resp.json()['error']} Subscription was not defined with the name : sub_none Verify Update Measurement Group admin status from Unlocked to Locking [Tags] PMSH_14 [Documentation] Verify Update Measurement Group admin status from Unlocked to Locking [Timeout] 60 seconds ${json_string}= Set Variable {"administrativeState": "LOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_01/adminState ${json} Should Be True ${resp.status_code} == 200 Should Contain ${resp.json()} Successfully updated admin state ${resp}= GetMeasGrpWithNFSCall /subscription/subs_01/measurementGroups/msg_grp_01 ${nf_length}= Get length ${resp.json()['networkFunctions']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['measurementGroupName']} msg_grp_01 Should Be Equal As Strings ${resp.json()['administrativeState']} LOCKING Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfMgStatus']} PENDING_DELETE Should be equal as numbers ${nf_length} 1 Verify Update Measurement Group admin status with locking in progress [Tags] PMSH_15 [Documentation] Verify Update Measurement Group admin status with locking in progress [Timeout] 60 seconds ${json_string}= Set Variable {"administrativeState": "LOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_01/adminState ${json} Should Be True ${resp.status_code} == 409 Should Contain ${resp.json()} Cannot update admin status as Locked request is in progress for sub name: subs_01 and meas group name: msg_grp_01 Verify Measurement Group admin status update from Locking to Locked [Tags] PMSH_16 [Documentation] Verify Measurement Group admin status update from Locking to Locked [Timeout] 60 seconds AddDeletePolicyResponeToMrSim Sleep 31 seconds Ensure Policy response on MR is picked up ResetMrSim ${resp}= GetMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_01 Should Be Equal As Strings ${resp.json()['measurementGroupName']} msg_grp_01 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['administrativeState']} LOCKED ${nf_length}= Get length ${resp.json()['networkFunctions']} Should be equal as numbers ${nf_length} 0 Verify Update Measurement Group admin status to unlocked with no Network Functions in Subscription [Tags] PMSH_17 [Documentation] Verify Update Measurement Group admin status to unlocked with no Network Functions in Subscription [Timeout] 60 seconds ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT}/subs_01 "" ${nf_length}= Get length ${resp.json()['subscription']['nfs']} Should be equal as numbers ${nf_length} 0 ${json_string}= Set Variable {"administrativeState": "UNLOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_01/adminState ${json} Should Be True ${resp.status_code} == 200 Should Contain ${resp.json()} Successfully updated admin state ${resp}= GetMeasGrpWithNFSCall /subscription/subs_01/measurementGroups/msg_grp_01 ${nf_length}= Get length ${resp.json()['networkFunctions']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['measurementGroupName']} msg_grp_01 Should Be Equal As Strings ${resp.json()['administrativeState']} UNLOCKED Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfMgStatus']} PENDING_CREATE Should be equal as numbers ${nf_length} 1 Verify Update Measurement Group admin status from Locked to Unlocked with Network function present in subscription [Tags] PMSH_18 [Documentation] Verify Update Measurement Group admin status from Locked to Unlocked with Network function present in subscription [Timeout] 60 seconds ${json_string}= Set Variable {"administrativeState": "UNLOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_02/adminState ${json} Should Be True ${resp.status_code} == 200 Should Contain ${resp.json()} Successfully updated admin state ${resp}= GetMeasGrpWithNFSCall /subscription/subs_01/measurementGroups/msg_grp_02 ${nf_length}= Get length ${resp.json()['networkFunctions']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()['measurementGroupName']} msg_grp_02 Should Be Equal As Strings ${resp.json()['administrativeState']} UNLOCKED Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfName']} pnf-existing Should Be Equal As Strings ${resp.json()['networkFunctions'][0]['nfMgStatus']} PENDING_CREATE Should be equal as numbers ${nf_length} 1 Verify Update Measurement Group admin status with no change [Tags] PMSH_19 [Documentation] Verify Update Measurement Group admin status with no change [Timeout] 60 seconds ${json_string}= Set Variable {"administrativeState": "UNLOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_01/adminState ${json} Should Be True ${resp.status_code} == 400 Should Contain ${resp.json()} Measurement group is already in UNLOCKED state for sub name: subs_01 and meas group name: msg_grp_01 Verify Update Measurement Group admin status for invalid measurement group [Tags] PMSH_20 [Documentation] Verify Update Measurement Group admin status for invalid measurement group [Timeout] 60 seconds ${json_string}= Set Variable {"administrativeState": "LOCKED"} ${json}= evaluate json.loads('''${json_string}''') json ${resp}= PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_11/adminState ${json} Should Be True ${resp.status_code} == 400 Should Contain ${resp.json()} Requested measurement group not available for admin status update Verify Get subscriptions with Network Functions [Tags] PMSH_21 [Documentation] Verify Get subscriptions with Network Functions [Timeout] 60 seconds ${json_value}= json_from_file ${CREATE_SECOND_SUBSCRIPTION_DATA} ${resp_post}= PostSubscriptionCall ${SUBSCRIPTION_ENDPOINT} ${json_value} ${resp}= GetSubsCall ${SUBSCRIPTION_ENDPOINT} "" ${nf_length_first}= Get length ${resp.json()[0]['subscription']['nfs']} ${nf_length_second}= Get length ${resp.json()[1]['subscription']['nfs']} Should Be True ${resp.status_code} == 200 Should Be Equal As Strings ${resp.json()[0]['subscription']['subscriptionName']} subs_01 Should Be Equal As Strings ${resp.json()[0]['subscription']['nfs'][0]} pnf-existing Should Be Equal As Strings ${resp.json()[0]['subscription']['measurementGroups'][0]['measurementGroup']['measurementGroupName']} msg_grp_02 Should be equal as numbers ${nf_length_first} 1 Should Be Equal As Strings ${resp.json()[1]['subscription']['subscriptionName']} subs_02 Should Be Equal As Strings ${resp.json()[1]['subscription']['nfs'][0]} pnf-existing Should Be Equal As Strings ${resp.json()[1]['subscription']['measurementGroups'][0]['measurementGroup']['measurementGroupName']} msg_grp_04 Should be equal as numbers ${nf_length_second} 1 *** Keywords *** SetAdministrativeStateToUnlocked ${data}= Get Data From File ${CBS_EXPECTATION_ADMIN_STATE_UNLOCKED} Create Session cbs_sim_session ${CBS_BASE_URL} verify=false ${resp}= PUT On Session cbs_sim_session url=/clear data={"path": "/service_component_all/.*"} Should Be True ${resp.status_code} == 200 Sleep 2 Allow CBS time to set expectation ${resp} = PUT On Session cbs_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 AddCreatePolicyResponeToMrSim ${data}= Get Data From File ${MR_POLICY_RESPONSE_PNF_EXISTING} Create Session mr_sim_session ${MR_SIM_BASE_URL} verify=false ${resp}= PUT On Session mr_sim_session url=/clear data={"id" : "pmsh_cl_input_event"} Should Be True ${resp.status_code} == 200 Sleep 2 Allow MR_SIM time to set expectation ${resp} = PUT On Session mr_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 AddDeletePolicyResponeToMrSim ${data}= Get Data From File ${MR_POLICY_RESPONSE_PNF_DELETED} Create Session mr_sim_session ${MR_SIM_BASE_URL} verify=false ${resp}= PUT On Session mr_sim_session url=/clear data={"id" : "pmsh_cl_input_event"} Should Be True ${resp.status_code} == 200 Sleep 2 Allow MR_SIM time to set expectation ${resp} = PUT On Session mr_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 AddNewPnfToMrSim ${data}= Get Data From File ${MR_AAI_PNF_CREATED} Create Session mr_sim_session ${MR_SIM_BASE_URL} verify=false ${resp}= PUT On Session mr_sim_session url=/clear data={"id" : "mr_aai_event"} Should Be True ${resp.status_code} == 200 Sleep 2 Allow MR_SIM time to set expectation ${resp} = PUT On Session mr_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 RemoveNewPnfFromMrSim ${data}= Get Data From File ${MR_AAI_PNF_REMOVED} Create Session mr_sim_session ${MR_SIM_BASE_URL} verify=false ${resp}= PUT On Session mr_sim_session url=/clear data={"id" : "mr_aai_event"} Should Be True ${resp.status_code} == 200 Sleep 2 Allow MR_SIM time to set expectation ${resp} = PUT On Session mr_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 ResetMrSim ${data}= Get Data From File ${MR_SIM_RESET} Create Session mr_sim_session ${MR_SIM_BASE_URL} verify=false ${resp}= PUT On Session mr_sim_session url=/reset Should Be True ${resp.status_code} == 200 ${resp}= PUT On Session mr_sim_session url=/expectation data=${data} Should Be True ${resp.status_code} == 201 GetSubsCall [Arguments] ${url} ${url_path_param} Create Session pmsh_session ${PMSH_BASE_URL} verify=false ${resp}= GET On Session pmsh_session url=${url} data={"path": {url_path_param}} expected_status=any [Return] ${resp} GetMeasGrpCall [Arguments] ${url} Create Session pmsh_session ${PMSH_BASE_URL} verify=false ${resp}= GET On Session pmsh_session url=${url} [Return] ${resp} GetMeasGrpWithNFSCall [Arguments] ${url} Create Session pmsh_session ${PMSH_BASE_URL} verify=false ${resp}= GET On Session pmsh_session url=${url} [Return] ${resp} PostSubscriptionCall [Arguments] ${url} ${data} Create Session pmsh_sub_session ${PMSH_BASE_URL} verify=false ${headers}= Create Dictionary Accept=application/json Content-Type=application/json ${resp}= POST On Session pmsh_sub_session url=${url} json=${data} headers=${headers} expected_status=anything [Return] ${resp} PutMsgGrpStatusCall [Arguments] ${url} ${data} Create Session pmsh_sub_session ${PMSH_BASE_URL} verify=false ${headers}= Create Dictionary Accept=application/json Content-Type=application/json ${resp}= PUT On Session pmsh_sub_session url=${url} json=${data} headers=${headers} expected_status=anything [Return] ${resp}