aboutsummaryrefslogtreecommitdiffstats
path: root/vid-webpack-master
diff options
context:
space:
mode:
authorEricMoore <eric.e.moore@est.tech>2020-03-01 19:14:22 +0200
committerEylon Malin <eylon.malin@intl.att.com>2020-05-03 13:17:59 +0000
commiteda0409e699d09b44676e82217391f2724edb6a8 (patch)
tree33b7023a8c16535da1c71937fc3cfe49a9b027be /vid-webpack-master
parent89050ec38eb9b61cd3ce4283f0bc910c5e414624 (diff)
Change Management: Support PNF software upgrade
Issue-ID: VID-505 Change-Id: I128b22092b78cf05a904648c276807a7ebb21aca Signed-off-by: Ittay Stern <ittay.stern@att.com> Signed-off-by: EricMoore <eric.e.moore@est.tech>
Diffstat (limited to 'vid-webpack-master')
-rw-r--r--vid-webpack-master/cypress/integration/iFrames/changeManagement.e2e.ts319
-rw-r--r--vid-webpack-master/cypress/support/jsonBuilders/mocks/jsons/get_vnf_data_by_globalid_and_service_type.json69
2 files changed, 351 insertions, 37 deletions
diff --git a/vid-webpack-master/cypress/integration/iFrames/changeManagement.e2e.ts b/vid-webpack-master/cypress/integration/iFrames/changeManagement.e2e.ts
index 3c2c9d80c..cb400528a 100644
--- a/vid-webpack-master/cypress/integration/iFrames/changeManagement.e2e.ts
+++ b/vid-webpack-master/cypress/integration/iFrames/changeManagement.e2e.ts
@@ -3,8 +3,30 @@
import {JsonBuilder} from "../../support/jsonBuilders/jsonBuilder";
import {AAISubDetailsModel} from "../../support/jsonBuilders/models/aaiSubDetails.model";
-describe('Change management AKA VNF changes', function () {
+function stubSubscriberDetails() {
let jsonBuilderAAISubDetailsModel: JsonBuilder<AAISubDetailsModel> = new JsonBuilder<AAISubDetailsModel>();
+ cy.readFile('cypress/support/jsonBuilders/mocks/jsons/defect710619/aaiSubDetailsE2E.json').then((res) => {
+ jsonBuilderAAISubDetailsModel.basicJson(
+ res,
+ Cypress.config('baseUrl') + "/aai_sub_details/e433710f-9217-458d-a79d-1c7aff376d89**",
+ 200,
+ 0,
+ "aai-sub-details")
+ });
+}
+
+function openNewVnfChangeModal() {
+ cy.visit('/serviceModels.htm#/change-management');
+ cy.getElementByDataTestsId('create-new-change-management').click();
+ cy.getElementByDataTestsId('newChangeManagementForm');
+}
+
+function fillSubscriberAndServiceType() {
+ cy.selectDropdownOptionByText('subscriberName', 'SILVIA ROBBINS');
+ cy.selectDropdownOptionByText('serviceType', 'TYLER SILVIA');
+}
+
+describe('Change management AKA VNF changes', function () {
let jsonBuilderVnfData: JsonBuilder<any> = new JsonBuilder<any>();
let aaiGetVNFDataUrl = Cypress.config('baseUrl') + "/get_vnf_data_by_globalid_and_service_type/e433710f-9217-458d-a79d-1c7aff376d89/TYLER SILVIA";
@@ -13,30 +35,15 @@ describe('Change management AKA VNF changes', function () {
beforeEach(() => {
cy.login();
cy.initAAIMock();
+ stubSubscriberDetails();
- cy.readFile('cypress/support/jsonBuilders/mocks/jsons/defect710619/aaiSubDetailsE2E.json').then((res) => {
- jsonBuilderAAISubDetailsModel.basicJson(
- res,
- Cypress.config('baseUrl') + "/aai_sub_details/e433710f-9217-458d-a79d-1c7aff376d89**",
- 200,
- 0,
- "aai-sub-details")
- });
-
- cy.readFile('cypress/support/jsonBuilders/mocks/jsons/flags.cypress.json').then(() => {
- cy.server()
- .route({
- method: 'GET',
- delay: 0,
- status: 200,
- url: Cypress.config('baseUrl') + "/flags**",
- response: {
- "FLAG_FLASH_REDUCED_RESPONSE_CHANGEMG": true,
- "FLAG_FLASH_CLOUD_REGION_AND_NF_ROLE_OPTIONAL_SEARCH": true,
- "FLAG_1810_CR_ADD_CLOUD_OWNER_TO_MSO_REQUEST": true
- }
- }).as('initFlags');
- });
+ cy.route(`${Cypress.config('baseUrl')}/flags`,
+ {
+ "FLAG_FLASH_REDUCED_RESPONSE_CHANGEMG": true,
+ "FLAG_FLASH_CLOUD_REGION_AND_NF_ROLE_OPTIONAL_SEARCH": true,
+ "FLAG_1810_CR_ADD_CLOUD_OWNER_TO_MSO_REQUEST": true,
+ })
+ .as('initFlags');
cy.readFile('cypress/support/jsonBuilders/mocks/jsons/get_vnf_data.json').then((res) => {
jsonBuilderVnfData.basicJson(
@@ -55,17 +62,6 @@ describe('Change management AKA VNF changes', function () {
cy.screenshot();
});
- function openNewVnfChangeModal() {
- cy.visit('/serviceModels.htm#/change-management');
- cy.getElementByDataTestsId('create-new-change-management').click();
- cy.getElementByDataTestsId('newChangeManagementForm');
- }
-
- function fillSubscriberAndServiceType() {
- cy.selectDropdownOptionByText('subscriberName', 'SILVIA ROBBINS');
- cy.selectDropdownOptionByText('serviceType', 'TYLER SILVIA');
- }
-
function fillCloudRegion() {
cy.selectDropdownOptionByText('cloudRegion', 'AAIAIC25 (AIC)');
}
@@ -111,7 +107,7 @@ describe('Change management AKA VNF changes', function () {
cy.get('#searchVNF').click();
cy.wait('@aai_get_vnf_data')
- .its('url').should('equal', aaiGetVNFDataUrl + "?cloudRegion=AAIAIC25")
+ .its('url').should('equal', aaiGetVNFDataUrl + "?cloudRegion=AAIAIC25")
});
it(`search vnfs by nf role`, function () {
@@ -121,6 +117,255 @@ describe('Change management AKA VNF changes', function () {
cy.get('#searchVNF').click();
cy.wait('@aai_get_vnf_data')
- .its('url').should('equal', aaiGetVNFDataUrl + "?nfRole=vMobileDNS")
+ .its('url').should('equal', aaiGetVNFDataUrl + "?nfRole=vMobileDNS")
});
});
+
+describe('Change management AKA VNF changes with SO workflows', function () {
+ beforeEach(() => {
+ cy.login();
+ cy.initAAIMock();
+ stubSubscriberDetails();
+
+ cy.route(`${Cypress.config('baseUrl')}/flags**`,
+ {
+ "FLAG_FLASH_REDUCED_RESPONSE_CHANGEMG": true,
+ "FLAG_FLASH_CLOUD_REGION_AND_NF_ROLE_OPTIONAL_SEARCH": false,
+ "FLAG_1810_CR_ADD_CLOUD_OWNER_TO_MSO_REQUEST": true,
+ "FLAG_HANDLE_SO_WORKFLOWS": true,
+ "FLAG_DISABLE_HOMING": true,
+ "FLAG_ADD_MSO_TESTAPI_FIELD": true,
+ })
+ .as('initFlags');
+
+ cy.route(`${Cypress.config('baseUrl')}/get_vnf_data_by_globalid_and_service_type/e433710f-9217-458d-a79d-1c7aff376d89/TYLER SILVIA`,
+ 'fixture:../support/jsonBuilders/mocks/jsons/get_vnf_data_by_globalid_and_service_type.json')
+ .as('aai_get_vnf_data');
+
+ cy.route(`${Cypress.config('baseUrl')}/rest/models/services?distributionStatus=DISTRIBUTED`,
+ 'fixture:../support/jsonBuilders/mocks/jsons/bug616888/list-services.json')
+ .as('list_services');
+
+ cy.route(`${Cypress.config('baseUrl')}/rest/models/services/74fa72dd-012b-49c3-800d-06b12bcaf1a0`,
+ 'fixture:../support/jsonBuilders/mocks/jsons/bug616888/Dror_service1806_Macro1.json')
+ .as('get_service_model');
+
+ cy.route('POST', `${Cypress.config('baseUrl')}/aai_get_version_by_invariant_id`,
+ {
+ "model": [
+ {
+ "model-invariant-id": "e88d6582-b7e5-4dc6-ac9c-6f7130727a92",
+ "model-type": "resource",
+ "resource-version": "1507747452923",
+ "model-vers": {
+ "model-ver": [
+ {
+ "model-version-id": "1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d",
+ "model-name": "092017_VSP_GINGERby11",
+ "model-version": "1.0",
+ "model-description": "092017_VSP_GINGERby11",
+ }
+ ]
+ }
+ },
+ ]
+ }
+ )
+ .as('aai_get_version_by_invariant_id');
+
+ openNewVnfChangeModal();
+ });
+
+ afterEach(() => {
+ cy.screenshot();
+ });
+
+
+ it(`vnf software upgrade: given vnf with matching workflow -- payload is as expected`, function () {
+
+ cy.route(`${Cypress.config('baseUrl')}/workflows-management/workflows?vnfModelId=1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d`,
+ [{
+ "id": "ab6478e4-ea33-3346-ac12-ab121484a333",
+ "workflowName": "inPlaceSoftwareUpdate",
+ "name": "VNF In Place Software Update",
+ "source": "native",
+ "workflowInputParameters": [
+ {
+ "label": "New Software Version",
+ "inputType": "text",
+ "required": true,
+ "soFieldName": "new_software_version",
+ "soPayloadLocation": "userParams",
+ "validation": []
+ }
+ ]
+ }])
+ .as('workflows_inPlaceSoftwareUpdate');
+
+ fillSubscriberAndServiceType();
+ selectNfRole();
+ selectVnf();
+
+ cy.get('#workflow').select('VNF In Place Software Update');
+
+ cy.get('#internal-workflow-parameter-text-2-operations-timeout')
+ .type("1");
+ cy.get('#internal-workflow-parameter-text-3-existing-software-version')
+ .type("1.0");
+ cy.get('#internal-workflow-parameter-text-4-new-software-version')
+ .type("3.0");
+
+ cy.route('POST', `${Cypress.config('baseUrl')}/change-management/workflow/zolson3amdns02test2`)
+ .as('apply_workflow');
+
+ cy.get('#submit').click();
+
+ cy.wait('@apply_workflow').then(xhr => {
+ cy.deepCompare(xhr.request.body, {
+ "requestType": "VNF In Place Software Update",
+ "requestDetails": [
+ {
+ "vnfName": "zolson3amdns02test2",
+ "vnfInstanceId": "8e5e3ba1-3fe6-4d86-966e-f9f03dab4855",
+ "modelInfo": {
+ "modelType": "vnf",
+ "modelInvariantId": "e88d6582-b7e5-4dc6-ac9c-6f7130727a92",
+ "modelVersionId": "1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d",
+ "modelName": "zolson3amdns02test2",
+ "modelCustomizationId": "cc40295f-a834-4f42-b634-32fff9d6489b"
+ },
+ "cloudConfiguration": {
+ "lcpCloudRegionId": "mdt1",
+ "tenantId": "88a6ca3ee0394ade9403f075db23167e"
+ },
+ "requestInfo": {
+ "source": "VID",
+ "suppressRollback": false,
+ "requestorId": "us16807000"
+ },
+ "relatedInstanceList": [
+ {
+ "relatedInstance": {
+ "instanceId": "97315a05-e6f3-4c47-ae7e-d850c327aa08",
+ "modelInfo": {
+ "modelType": "service",
+ "modelInvariantId": "bceeaff9-5716-42bf-8fa1-8c6f720cf61d",
+ "modelVersionId": "74fa72dd-012b-49c3-800d-06b12bcaf1a0",
+ "modelName": "Dror_service1806_Macro1",
+ "modelVersion": "2.0"
+ }
+ }
+ }
+ ],
+ "requestParameters": {
+ "payload": "{\"existing_software_version\":\"1.0\",\"new_software_version\":\"3.0\",\"operations_timeout\":\"1\"}"
+ }
+ }
+ ]
+ });
+ });
+
+ });
+
+ it(`pnf software upgrade: given pnf with matching workflow -- payload is as expected`, function () {
+
+ cy.route(`${Cypress.config('baseUrl')}/workflows-management/workflows?vnfModelId=1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d`,
+ [{
+ "id": "ab6478e4-ea33-3346-ac12-ab121484a333",
+ "workflowName": "PNFSoftwareUpgrade",
+ "name": "PNF Software Upgrade",
+ "source": "native",
+ "workflowInputParameters": [
+ {
+ "label": "Target Software Version",
+ "inputType": "text",
+ "required": true,
+ "soFieldName": "targetSoftwareVersion",
+ "soPayloadLocation": "userParams",
+ "validation": []
+ }
+ ]
+ }])
+ .as('workflows_PNFSoftwareUpgrade');
+
+ fillSubscriberAndServiceType();
+ selectNfRole();
+ selectPnf();
+
+ cy.get('#workflow').select('PNF Software Upgrade');
+
+ cy.get('#internal-workflow-parameter-text-6-target-software-version')
+ .type("demo-sw-ver2.0.0");
+
+ cy.route('POST', `${Cypress.config('baseUrl')}/change-management/workflow/zolson3amdns02test2`)
+ .as('apply_workflow');
+
+ cy.get('#submit').click();
+
+ cy.wait('@apply_workflow').then(xhr => {
+ cy.deepCompare(xhr.request.body, {
+ "requestType": "PNF Software Upgrade",
+ "requestDetails": [
+ {
+ "pnfInstanceId": "8e5e3ba1-3fe6-4d86-966e-f9f03dab4855",
+ "modelInfo": {
+ "modelType": "pnf",
+ "modelInvariantId": "e88d6582-b7e5-4dc6-ac9c-6f7130727a92",
+ "modelVersionId": "1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d",
+ "modelName": "zolson3amdns02test2",
+ "modelCustomizationId": "cc40295f-a834-4f42-b634-32fff9d6489b"
+ },
+ "cloudConfiguration": {
+ "lcpCloudRegionId": "mdt1",
+ "tenantId": "88a6ca3ee0394ade9403f075db23167e"
+ },
+ "requestInfo": {
+ "source": "VID",
+ "suppressRollback": false,
+ "requestorId": "us16807000"
+ },
+ "requestParameters": {
+ "userParams":[
+ {
+ "name":"pnfId",
+ "value":"8e5e3ba1-3fe6-4d86-966e-f9f03dab4855"
+ },
+ {
+ "name":"pnfName",
+ "value":"zolson3amdns02test2"
+ },
+ {
+ "name":"targetSoftwareVersion",
+ "value":"demo-sw-ver2.0.0"
+ }
+ ]
+ }
+ }
+ ]
+ });
+ });
+
+ });
+
+ function selectNfRole() {
+ cy.get('#vnfType').select('vMobileDNS');
+ }
+
+ function selectVnf() {
+ cy.get('#fromVNFVersion').select('1.0');
+
+ cy.log("open the Available VNF list").get('#vnfName').click();
+ cy.get('li').contains('zolson3amdns02test2').click();
+ cy.log("collapse the Available VNF list").get('#vnfName').click();
+ }
+
+ function selectPnf() {
+ cy.get('#fromVNFVersion').select('1.0');
+
+ cy.log("open the Available VNF list").get('#vnfName').click();
+ cy.get('li').contains('zolson3amdns02test2').click();
+ cy.log("collapse the Available VNF list").get('#vnfName').click();
+ }
+
+
+});
diff --git a/vid-webpack-master/cypress/support/jsonBuilders/mocks/jsons/get_vnf_data_by_globalid_and_service_type.json b/vid-webpack-master/cypress/support/jsonBuilders/mocks/jsons/get_vnf_data_by_globalid_and_service_type.json
new file mode 100644
index 000000000..c2ff8b974
--- /dev/null
+++ b/vid-webpack-master/cypress/support/jsonBuilders/mocks/jsons/get_vnf_data_by_globalid_and_service_type.json
@@ -0,0 +1,69 @@
+{
+ "results": [
+ {
+ "id": "3008335920",
+ "node-type": "service-instance",
+ "url": "https://aai.onap.org:8443/aai/v10/business/customers/customer/a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb/service-subscriptions/service-subscription/vRichardson/service-instances/service-instance/97315a05-e6f3-4c47-ae7e-d850c327aa08",
+ "properties": {
+ "service-instance-id": "97315a05-e6f3-4c47-ae7e-d850c327aa08",
+ "service-instance-name": "Dror_service1806_Macro1",
+ "model-invariant-id": "bceeaff9-5716-42bf-8fa1-8c6f720cf61d",
+ "model-version-id": "74fa72dd-012b-49c3-800d-06b12bcaf1a0",
+ "resource-version": "1506527653053",
+ "orchestration-status": "Active"
+ },
+ "related-to": [
+ {
+ "id": "10207440",
+ "node-type": "service-subscription",
+ "url": "https://aai.onap.org:8443/aai/v10/business/customers/customer/a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb/service-subscriptions/service-subscription/vRichardson"
+ },
+ {
+ "id": "3418898432",
+ "node-type": "generic-vnf",
+ "url": "https://aai.onap.org:8443/aai/v10/network/generic-vnfs/generic-vnf/8e5e3ba1-3fe6-4d86-966e-f9f03dab4855"
+ }
+ ]
+ },
+ {
+ "id": "3418898432",
+ "node-type": "generic-vnf",
+ "url": "https://aai.onap.org:8443/aai/v10/network/generic-vnfs/generic-vnf/8e5e3ba1-3fe6-4d86-966e-f9f03dab4855",
+ "properties": {
+ "vnf-id": "8e5e3ba1-3fe6-4d86-966e-f9f03dab4855",
+ "vnf-name": "zolson3amdns02test2",
+ "vnf-type": "CHARLOTTE preload 1710 0914/CHARLOTTE preload 1710 0914 0",
+ "service-id": "a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb",
+ "prov-status": "PREPROV",
+ "orchestration-status": "Created",
+ "in-maint": false,
+ "is-closed-loop-disabled": false,
+ "resource-version": "1507132024933",
+ "model-invariant-id": "e88d6582-b7e5-4dc6-ac9c-6f7130727a92",
+ "model-version-id": "1ecfa5f1-78c5-41f6-ad34-753ca1fcdc5d",
+ "model-customization-id": "cc40295f-a834-4f42-b634-32fff9d6489b",
+ "nf-type": "DNS",
+ "nf-function": "Mobile DNS",
+ "nf-role": "vMobileDNS",
+ "nf-naming-code": "null"
+ },
+ "related-to": [
+ {
+ "id": "3664617648",
+ "node-type": "vf-module",
+ "url": "https://aai.onap.org:8443/aai/v10/network/generic-vnfs/generic-vnf/8e5e3ba1-3fe6-4d86-966e-f9f03dab4855/vf-modules/vf-module/788cde64-c288-4971-8e8c-77973c5009dc"
+ },
+ {
+ "id": "3008335920",
+ "node-type": "service-instance",
+ "url": "https://aai.onap.org:8443/aai/v10/business/customers/customer/a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb/service-subscriptions/service-subscription/vRichardson/service-instances/service-instance/97315a05-e6f3-4c47-ae7e-d850c327aa08"
+ },
+ {
+ "id": "4458950808",
+ "node-type": "vserver",
+ "url": "https://aai.onap.org:8443/aai/v10/cloud-infrastructure/cloud-regions/cloud-region/irma-aic/mdt1/tenants/tenant/88a6ca3ee0394ade9403f075db23167e/vservers/vserver/047354dc-0244-4241-b24a-7d7b00413b82"
+ }
+ ]
+ }
+ ]
+}