*** Variables ***
${PMSH_BASE_URL} https://${PMSH_IP}:8443
-${MR_BASE_URL} http://${MR_IP_ADDRESS}:3904
-${CBS_BASE_URL} https://${CBS_SIM_IP_ADDRESS}:10443
+${MR_SIM_BASE_URL} http://${MR_SIM_IP_ADDRESS}:3904
${SUBSCRIPTION_ENDPOINT} /subscription
-${POLICY_PUBLISH_MR_TOPIC} /events/unauthenticated.PMSH_CL_INPUT
-${AAI_MR_TOPIC} /events/AAI_EVENT
+${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
-${CBS_EXPECTATION_ADMIN_STATE_UNLOCKED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/cbs-expectation-unlocked-config.json
+${MR_POLICY_RESPONSE_PNF_DELETED} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/policy-sub-deleted-pnf-existing.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
-${ADMIN_STATE_LOCKED_PATTERN} 'administrativeState': 'LOCKED'
-${CLI_EXEC_GET_CBS_CONFIG_FIRST} docker exec pmsh /bin/sh -c "grep -m 1 'PMSH config from CBS' /var/log/ONAP/dcaegen2/services/pmsh/application.log"
+${CREATE_MSG_GRP_DATA} %{WORKSPACE}/tests/dcaegen2-services-pmsh/testcases/assets/create_msg_grp.json
*** Test Cases ***
Verify Get subscriptions with Network Functions None
[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
[Tags] PMSH_04
[Documentation] Verify policy response on MR is handled
[Timeout] 60 seconds
- SimulatePolicyResponse ${MR_POLICY_RESPONSE_PNF_EXISTING}
+ 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
[Tags] PMSH_05
[Documentation] Verify PNF created AAI event on MR is handled
[Timeout] 60 seconds
- SimulateNewPNF ${MR_AAI_PNF_CREATED}
- Sleep 31 seconds Ensure AAI event on MR is picked up
+ 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
[Tags] PMSH_06
[Documentation] Verify PNF deleted AAI event on MR is handled
[Timeout] 60 seconds
- SimulateDeletedPNF ${MR_AAI_PNF_REMOVED}
- Sleep 31 seconds Ensure AAI event on MR is picked up
+ 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
+ [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} == 404
Should Be Equal As Strings ${resp.json()['error']} Subscription was not defined with the name : sub_none
-Verify Get subscriptions with Network Functions
+Verify Update Measurement Group admin status from Unlocked to Locking
[Tags] PMSH_14
- [Documentation] Verify Get all defined subscriptions with associated Network Functions
+ [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
+ [Tags] PMSH_17
+ [Documentation] Verify Update Measurement Group admin status to unlocked with no Network Functions 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_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}
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
+Verify Delete Measurement Group with Administrative State unlocked
+ [Tags] PMSH_22
+ [Documentation] Verify Delete Measurement Group with Administrative State unlocked
+ [Timeout] 60 seconds
+ ${json_string}= Set Variable {"administrativeState": "UNLOCKED"}
+ ${json}= evaluate json.loads('''${json_string}''') json
+ PutMsgGrpStatusCall /subscription/subs_01/measurementGroups/msg_grp_02/adminState ${json}
+ ${resp}= DeleteMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_02
+ Should Be True ${resp.status_code} == 409
+
+Verify Delete Measurement Group with incorrect Measurement Group name server error
+ [Tags] PMSH_23
+ [Documentation] Verify Delete Measurement Group with incorrect Measurement Group Name
+ [Timeout] 60 seconds
+ ${resp}= DeleteMeasGrpCall /subscription/subs_01/measurementGroups/nonexistent
+ Should Be True ${resp.status_code} == 500
+
+Verify Create Measurement Group successful
+ [Tags] PMSH_24
+ [Documentation] Verify Create Measurement Group successful
+ [Timeout] 60 seconds
+ ${json_value}= json_from_file ${CREATE_MSG_GRP_DATA}
+ ${resp}= PostMsgGrpCall /subscription/subs_01/measurementGroups/msg_grp_05 ${json_value}
+ Should Be True ${resp.status_code} == 201
+
+Verify Create Measurement Group unsuccessful
+ [Tags] PMSH_25
+ [Documentation] Verify Create Measurement Group successful
+ [Timeout] 60 seconds
+ ${json_value}= json_from_file ${CREATE_MSG_GRP_DATA}
+ ${resp}= PostMsgGrpCall /subscription/subs_01/measurementGroups/msg_grp_05 ${json_value}
+ Should Be True ${resp.status_code} == 409
+
+Verify Delete Measurement Group successful
+ [Tags] PMSH_26
+ [Documentation] Verify Delete Measurement Group successful
+ [Timeout] 60 seconds
+ ${resp}= DeleteMeasGrpCall /subscription/subs_01/measurementGroups/msg_grp_05
+ Should Be True ${resp.status_code} == 204
*** 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/.*"}
+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 CBS time to set expectation
- ${resp} = PUT On Session cbs_sim_session url=/expectation data=${data}
+ 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
-SimulatePolicyResponse
- [Arguments] ${expected_contents}
- ${json_value}= json_from_file ${expected_contents}
- ${resp}= PostMrCall ${POLICY_PUBLISH_MR_TOPIC} ${json_value}
- log ${resp.text}
- Should Be Equal As Strings ${resp.status_code} 200
- ${count}= Evaluate $resp.json().get('count')
- log 'JSON Response Code:'${resp}
-
-SimulateNewPNF
- [Arguments] ${expected_contents}
- ${json_value}= json_from_file ${expected_contents}
- ${resp}= PostMrCall ${AAI_MR_TOPIC} ${json_value}
- log ${resp.text}
- Should Be Equal As Strings ${resp.status_code} 200
- ${count}= Evaluate $resp.json().get('count')
- log 'JSON Response Code:'${resp}
-
-SimulateDeletedPNF
- [Arguments] ${expected_contents}
- ${json_value}= json_from_file ${expected_contents}
- ${resp}= PostMrCall ${AAI_MR_TOPIC} ${json_value}
- log ${resp.text}
- Should Be Equal As Strings ${resp.status_code} 200
- ${count}= Evaluate $resp.json().get('count')
- log 'JSON Response Code:'${resp}
-
-PostMrCall
- [Arguments] ${url} ${data}
- Create Session mr_sim_session ${MR_BASE_URL} verify=false
- ${headers}= Create Dictionary Accept=application/json Content-Type=application/json
- ${resp}= POST On Session mr_sim_session url=${url} json=${data} headers=${headers}
- [Return] ${resp}
+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}
${resp}= GET On Session pmsh_session url=${url}
[Return] ${resp}
+DeleteMeasGrpCall
+ [Arguments] ${url}
+ Create Session pmsh_session ${PMSH_BASE_URL} verify=false
+ ${resp}= DELETE On Session pmsh_session url=${url} expected_status=anything
+ [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}
+
+PostMsgGrpCall
+ [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}