555c2edcfda58c2c24c9327c721f6c3617b21701
[vid.git] / vid-automation / src / test / java / org / onap / vid / api / AaiApiTest.java
1 package org.onap.vid.api;
2
3 import static net.javacrumbs.jsonunit.JsonMatchers.jsonEquals;
4 import static org.hamcrest.CoreMatchers.containsString;
5 import static org.hamcrest.MatcherAssert.assertThat;
6 import static org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet.defaultPlacement;
7 import static org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet.ofL3Network;
8 import static org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet.ofServiceInstance;
9 import static org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet.ofVlanTag;
10 import static org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet.ofVnf;
11 import static org.onap.simulator.presetGenerator.presets.aai.PresetBaseAAICustomQuery.FORMAT.SIMPLE;
12 import static org.onap.simulator.presetGenerator.presets.ecompportal_att.EcompPortalPresetsUtils.getEcompPortalPresets;
13 import static org.testng.Assert.assertNotNull;
14 import static org.testng.Assert.assertTrue;
15 import static org.testng.AssertJUnit.assertEquals;
16 import static vid.automation.test.services.SimulatorApi.RegistrationStrategy.APPEND;
17 import static vid.automation.test.services.SimulatorApi.RegistrationStrategy.CLEAR_THEN_SET;
18 import static vid.automation.test.services.SimulatorApi.registerExpectationFromPresets;
19 import static vid.automation.test.utils.TestHelper.GET_SERVICE_MODELS_BY_DISTRIBUTION_STATUS;
20
21 import com.fasterxml.jackson.core.JsonProcessingException;
22 import com.google.common.collect.ImmutableList;
23 import com.google.common.collect.ImmutableMap;
24 import com.google.common.collect.ImmutableMultimap;
25 import java.io.IOException;
26 import java.lang.reflect.Method;
27 import java.net.URISyntaxException;
28 import java.util.List;
29 import java.util.UUID;
30 import net.javacrumbs.jsonunit.JsonAssert;
31 import net.javacrumbs.jsonunit.core.Configuration;
32 import net.javacrumbs.jsonunit.core.Option;
33 import org.apache.commons.text.StringEscapeUtils;
34 import org.apache.http.client.utils.URIBuilder;
35 import org.onap.simulator.presetGenerator.presets.BasePresets.BasePreset;
36 import org.onap.simulator.presetGenerator.presets.aai.AAIBaseGetL3NetworksByCloudRegionPreset;
37 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIBadBodyForGetServicesGet;
38 import org.onap.simulator.presetGenerator.presets.aai.PresetAAICloudRegionAndSourceFromConfigurationPut;
39 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetCloudOwnersByCloudRegionId;
40 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetHomingForVfModule;
41 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegion;
42 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest;
43 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing;
44 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetL3NetworksByCloudRegion;
45 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetL3NetworksByCloudRegionSpecificState;
46 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetails;
47 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetailsInvalidRequest;
48 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetailsRequiredMissing;
49 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetPortMirroringSourcePorts;
50 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetPortMirroringSourcePortsError;
51 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetRelatedInstanceGroupsByVnfId;
52 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetSubscribersGet;
53 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetVpnsByType;
54 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIModelVersionsByInvariantId;
55 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIStandardQueryGet;
56 import org.onap.simulator.presetGenerator.presets.aai.PresetBaseAAICustomQuery;
57 import org.onap.simulator.presetGenerator.presets.sdc.PresetSDCGetServiceMetadataGet;
58 import org.onap.simulator.presetGenerator.presets.sdc.PresetSDCGetServiceToscaModelGet;
59 import org.onap.vid.model.aai.AaiResponse;
60 import org.onap.vid.model.mso.OperationalEnvironmentList;
61 import org.onap.vid.more.LoggerFormatTest;
62 import org.onap.vid.more.LoggerFormatTest.LogName;
63 import org.springframework.core.ParameterizedTypeReference;
64 import org.springframework.http.HttpMethod;
65 import org.springframework.http.HttpStatus;
66 import org.springframework.http.ResponseEntity;
67 import org.springframework.web.client.HttpClientErrorException;
68 import org.springframework.web.client.HttpServerErrorException;
69 import org.springframework.web.util.UriComponentsBuilder;
70 import org.testng.AssertJUnit;
71 import org.testng.annotations.DataProvider;
72 import org.testng.annotations.Test;
73 import vid.automation.test.infra.FeatureTogglingTest;
74 import vid.automation.test.infra.Features;
75 import vid.automation.test.services.SimulatorApi;
76 import vid.automation.test.utils.TestHelper;
77
78 public class AaiApiTest extends BaseApiAaiTest {
79
80     private static final String AAI_HOMING_DATA_RESPONSE = "viewEdit/aaiHomingDataResponse.json";
81     public static final String GET_OPERATIONAL_ENVIRONMENTS_JSON = "get_operational_environments_aai.json";
82     public static final String GET_OPERATIONAL_ENVIRONMENTS_JSON_ERROR = "get_operational_environments_aai_error.json";
83     public static final String[] AAI_GET_SERVICES_ERROR_SIMULATOR_RESPONSES = {"getServicesAaiErrorResp.json", "create_new_instance/aai_get_full_subscribers.json"};
84     public static final String[] AAI_GET_SERVICES_FINE_SIMULATOR_RESPONSES = {"getServicesAaiFineResp.json", "create_new_instance/aai_get_full_subscribers.json"};
85     public static final String AAI_VNFS_FOR_CHANGE_MANAGEMENT_JSON = "changeManagement/get_vnf_data_by_globalid_and_service_type.json";
86     public static final String AAI_VNFS_FOR_CHANGE_MANAGEMENT_JSON_BY_PARAMS = "registration_to_simulator/changeManagement/get_vnf_data_by_globalid_and_service_type_reduced_response.json";
87     public static final String OPERATIONAL_ENVIRONMENT_TYPE = "VNF";
88     public static final String OPERATIONAL_ENVIRONMENT_STATUS = "Activate";
89     public static final String GET_INSTANCE_GROUPS_BY_CLOUDREGION_EXPECTED_RESPONSE = "{\"results\":[{\"instance-group\":{\"id\":\"AAI-12002-test3-vm230w\",\"description\":\"a9DEa0kpY\",\"instance-group-role\":\"JZmha7QSS4tJ\",\"model-invariant-id\":\"model-id3\",\"model-version-id\":\"a0efd5fc-f7be-4502-936a-a6c6392b958f\",\"instance-group-type\":\"type\",\"resource-version\":\"1520888659539\",\"instance-group-name\":\"wKmBXiO1xm8bK\",\"instance-group-function\":\"testfunction2\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"relatedToPropertyList\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}],\"related-to\":\"cloud-region\",\"related-link\":\"/aai/v13/cloud-infrastructure/cloud-regions/cloud-region/AAI-12002-vm230w/AAI-region-vm230w\",\"relationship-label\":\"org.onap.relationships.inventory.Uses\",\"relationship-data\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"related-to-property\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}]}]}}},{\"instance-group\":{\"id\":\"AAI-12002-test1-vm230w\",\"description\":\"a9DEa0kpY\",\"instance-group-role\":\"JZmha7QSS4tJ\",\"model-invariant-id\":\"model-id1\",\"model-version-id\":\"a0efd5fc-f7be-4502-936a-a6c6392b958f\",\"instance-group-type\":\"type\",\"resource-version\":\"1520886467989\",\"instance-group-name\":\"wKmBXiO1xm8bK\",\"instance-group-function\":\"testfunction2\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"relatedToPropertyList\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}],\"related-to\":\"cloud-region\",\"related-link\":\"/aai/v13/cloud-infrastructure/cloud-regions/cloud-region/AAI-12002-vm230w/AAI-region-vm230w\",\"relationship-label\":\"org.onap.relationships.inventory.Uses\",\"relationship-data\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"related-to-property\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}]}]}}},{\"instance-group\":{\"id\":\"AAI-12002-test2-vm230w\",\"description\":\"a9DEa0kpY\",\"instance-group-role\":\"JZmha7QSS4tJ\",\"model-invariant-id\":\"model-id2\",\"model-version-id\":\"version2\",\"instance-group-type\":\"type\",\"resource-version\":\"1520888629970\",\"instance-group-name\":\"wKmBXiO1xm8bK\",\"instance-group-function\":\"testfunction2\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"relatedToPropertyList\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}],\"related-to\":\"cloud-region\",\"related-link\":\"/aai/v13/cloud-infrastructure/cloud-regions/cloud-region/AAI-12002-vm230w/AAI-region-vm230w\",\"relationship-label\":\"org.onap.relationships.inventory.Uses\",\"relationship-data\":[{\"relationship-key\":\"cloud-region.cloud-owner\",\"relationship-value\":\"AAI-12002-vm230w\"},{\"relationship-key\":\"cloud-region.cloud-region-id\",\"relationship-value\":\"AAI-region-vm230w\"}],\"related-to-property\":[{\"property-key\":\"cloud-region.owner-defined-type\",\"property-value\":null}]}]}}}]}\n";
90     public static final String GET_NETWORK_COLLECTION_EXPECTED_RESPONSE = "{\"results\":{\"collection\":{\"collection-id\":\"collection-1-2018-rs804s\",\"model-invariant-id\":\"5761e0a7-defj777\",\"model-version-id\":\"5761e0a7-defj232\",\"collection-name\":\"collection-name\",\"collection-type\":\"L3-NETWORK\",\"collection-role\":\"SUB-INTERFACE\",\"collection-function\":\"collection-function\",\"collection-customization-id\":\"custom-unique-data-id\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"customer.global-customer-id\",\"relationship-value\":\"customer-1-2017-rs804s\"},{\"relationship-key\":\"service-subscription.service-type\",\"relationship-value\":\"service-value7-rs804s\"},{\"relationship-key\":\"service-instance.service-instance-id\",\"relationship-value\":\"2UJZZ01777-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"service-instance.service-instance-name\",\"property-value\":null}],\"related-to\":\"service-instance\",\"related-link\":\"/aai/v13/business/customers/customer/customer-1-2017-rs804s/service-subscriptions/service-subscription/service-value7-rs804s/service-instances/service-instance/2UJZZ01777-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"customer.global-customer-id\",\"relationship-value\":\"customer-1-2017-rs804s\"},{\"relationship-key\":\"service-subscription.service-type\",\"relationship-value\":\"service-value7-rs804s\"},{\"relationship-key\":\"service-instance.service-instance-id\",\"relationship-value\":\"2UJZZ01777-rs804s\"}],\"related-to-property\":[{\"property-key\":\"service-instance.service-instance-name\",\"property-value\":null}]},{\"relationDataList\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}],\"related-to\":\"instance-group\",\"related-link\":\"/aai/v13/network/instance-groups/instance-group/instanceGroup-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"related-to-property\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}]}]},\"resource-version\":\"1521662811309\"},\"networks\":[{\"network-id\":\"l3network-id-rs804s\",\"network-name\":\"oam-net\",\"network-type\":\"Tenant_Layer_3\",\"network-role\":\"RosemaProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662814627\",\"orchestration-status\":\"Created\",\"is-provider-network\":false,\"is-shared-network\":false,\"is-external-network\":false,\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}],\"related-to\":\"instance-group\",\"related-link\":\"/aai/v13/network/instance-groups/instance-group/instanceGroup-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"related-to-property\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}]}]}},{\"network-id\":\"l3network-id-3-rs804s\",\"network-name\":\"oam-net\",\"network-type\":\"Tenant_Layer_3\",\"network-role\":\"RosemaProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662816043\",\"orchestration-status\":\"Created\",\"is-provider-network\":false,\"is-shared-network\":false,\"is-external-network\":false,\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}],\"related-to\":\"instance-group\",\"related-link\":\"/aai/v13/network/instance-groups/instance-group/instanceGroup-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"related-to-property\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}]}]}},{\"network-id\":\"l3network-id-2-rs804s\",\"network-name\":\"oam-net\",\"network-type\":\"Tenant_Layer_3\",\"network-role\":\"RosemaProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662815304\",\"orchestration-status\":\"Created\",\"is-provider-network\":false,\"is-shared-network\":false,\"is-external-network\":false,\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}],\"related-to\":\"instance-group\",\"related-link\":\"/aai/v13/network/instance-groups/instance-group/instanceGroup-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"instance-group.id\",\"relationship-value\":\"instanceGroup-2018-rs804s\"}],\"related-to-property\":[{\"property-key\":\"instance-group.description\",\"property-value\":\"zr6h\"},{\"property-key\":\"instance-group.instance-group-name\",\"property-value\":\"wKmBXiO1xm8bK\"}]}]}}],\"service-instance\":{\"service-instance-id\":\"2UJZZ01777-rs804s\",\"resource-version\":\"1521662813382\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"collection.collection-id\",\"relationship-value\":\"collection-1-2018-rs804s\"}],\"relatedToPropertyList\":null,\"related-to\":\"collection\",\"related-link\":\"/aai/v13/network/collections/collection/collection-1-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"collection.collection-id\",\"relationship-value\":\"collection-1-2018-rs804s\"}],\"related-to-property\":null}]}},\"instance-group\":{\"id\":\"instanceGroup-2018-rs804s\",\"description\":\"zr6h\",\"instance-group-role\":\"JZmha7QSS4tJ\",\"model-invariant-id\":\"5761e0a7-defj777\",\"model-version-id\":\"5761e0a7-defj22\",\"instance-group-type\":\"7DDjOdNL\",\"resource-version\":\"1521662814023\",\"instance-group-name\":\"wKmBXiO1xm8bK\",\"instance-group-function\":\"testfunction2\",\"relationship-list\":{\"relationship\":[{\"relationDataList\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}],\"related-to\":\"l3-network\",\"related-link\":\"/aai/v13/network/l3-networks/l3-network/l3network-id-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-rs804s\"}],\"related-to-property\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}]},{\"relationDataList\":[{\"relationship-key\":\"collection.collection-id\",\"relationship-value\":\"collection-1-2018-rs804s\"}],\"relatedToPropertyList\":null,\"related-to\":\"collection\",\"related-link\":\"/aai/v13/network/collections/collection/collection-1-2018-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"collection.collection-id\",\"relationship-value\":\"collection-1-2018-rs804s\"}],\"related-to-property\":null},{\"relationDataList\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-3-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}],\"related-to\":\"l3-network\",\"related-link\":\"/aai/v13/network/l3-networks/l3-network/l3network-id-3-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-3-rs804s\"}],\"related-to-property\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}]},{\"relationDataList\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-2-rs804s\"}],\"relatedToPropertyList\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}],\"related-to\":\"l3-network\",\"related-link\":\"/aai/v13/network/l3-networks/l3-network/l3network-id-2-rs804s\",\"relationship-label\":\"org.onap.relationships.inventory.MemberOf\",\"relationship-data\":[{\"relationship-key\":\"l3-network.network-id\",\"relationship-value\":\"l3network-id-2-rs804s\"}],\"related-to-property\":[{\"property-key\":\"l3-network.network-name\",\"property-value\":\"oam-net\"}]}]}}}}\n";
91     public static final String GET_AAI_SERVIES_EXPECTED_RESULT = "{\n" +
92             "  \"services\": [{\n" +
93             "    \"uuid\": \"20c4431c-246d-11e7-93ae-92361f002671\",\n" +
94             "    \"invariantUUID\": \"78ca26d0-246d-11e7-93ae-92361f002671\",\n" +
95             "    \"name\": \"vSAMP10aDEV::base::module-0\",\n" +
96             "    \"version\": \"2\",\n" +
97             "    \"toscaModelURL\": null,\n" +
98             "    \"category\": \"resource\",\n" +
99             "    \"lifecycleState\": null,\n" +
100             "    \"lastUpdaterUserId\": null,\n" +
101             "    \"lastUpdaterFullName\": null,\n" +
102             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
103             "    \"orchestrationType\": null,\n" +
104             "    \"isInstantiationTemplateExists\": false,\n" +
105             "    \"artifacts\": null,\n" +
106             "    \"resources\": null\n" +
107             "  }, {\n" +
108             "    \"uuid\": \"797a6c41-0f80-4d35-a288-3920c4e06baa\",\n" +
109             "    \"invariantUUID\": \"5b607929-6088-4614-97ef-cac817508e0e\",\n" +
110             "    \"name\": \"CONTRAIL30_L2NODHCP\",\n" +
111             "    \"version\": \"1.0\",\n" +
112             "    \"toscaModelURL\": null,\n" +
113             "    \"category\": \"resource\",\n" +
114             "    \"lifecycleState\": null,\n" +
115             "    \"lastUpdaterUserId\": null,\n" +
116             "    \"lastUpdaterFullName\": null,\n" +
117             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_ERROR\",\n" +
118             "    \"orchestrationType\": null,\n" +
119             "    \"isInstantiationTemplateExists\": false,\n" +
120             "    \"artifacts\": null,\n" +
121             "    \"resources\": null\n" +
122             "  }, {\n" +
123             "    \"uuid\": \"f1bde010-cc5f-4765-941f-75f15b24f9fc\",\n" +
124             "    \"invariantUUID\": \"0143d57b-a517-4de9-a0a1-eb76db51f402\",\n" +
125             "    \"name\": \"BkVmxAv061917..base_vPE_AV..module-0\",\n" +
126             "    \"version\": \"2\",\n" +
127             "    \"toscaModelURL\": null,\n" +
128             "    \"category\": \"resource\",\n" +
129             "    \"lifecycleState\": null,\n" +
130             "    \"lastUpdaterUserId\": null,\n" +
131             "    \"lastUpdaterFullName\": null,\n" +
132             "    \"orchestrationType\": null,\n" +
133             "    \"isInstantiationTemplateExists\": false,\n" +
134             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
135             "    \"artifacts\": null,\n" +
136             "    \"resources\": null\n" +
137             "  }, {\n" +
138             "    \"uuid\": \"ipe-resource-id-ps-02\",\n" +
139             "    \"invariantUUID\": \"ipe-resource-id-ps-02\",\n" +
140             "    \"name\": \"abc\",\n" +
141             "    \"version\": \"v1.0\",\n" +
142             "    \"toscaModelURL\": null,\n" +
143             "    \"category\": \"resource\",\n" +
144             "    \"lifecycleState\": null,\n" +
145             "    \"lastUpdaterUserId\": null,\n" +
146             "    \"lastUpdaterFullName\": null,\n" +
147             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
148             "    \"orchestrationType\": null,\n" +
149             "    \"isInstantiationTemplateExists\": false,\n" +
150             "    \"artifacts\": null,\n" +
151             "    \"resources\": null\n" +
152             "  }, {\n" +
153             "    \"uuid\": \"lmoser410-connector-model-version-id\",\n" +
154             "    \"invariantUUID\": \"lmoser410-connector-model-id\",\n" +
155             "    \"name\": \"connector\",\n" +
156             "    \"version\": \"v1.0\",\n" +
157             "    \"toscaModelURL\": null,\n" +
158             "    \"category\": \"widget\",\n" +
159             "    \"lifecycleState\": null,\n" +
160             "    \"lastUpdaterUserId\": null,\n" +
161             "    \"lastUpdaterFullName\": null,\n" +
162             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
163             "    \"orchestrationType\": null,\n" +
164             "    \"isInstantiationTemplateExists\": false,\n" +
165             "    \"artifacts\": null,\n" +
166             "    \"resources\": null\n" +
167             "  }, {\n" +
168             "    \"uuid\": \"ff2ae348-214a-11e7-93ae-92361f002673\",\n" +
169             "    \"invariantUUID\": \"3a97db99-c4bb-498a-a13a-38f65f1ced3d\",\n" +
170             "    \"name\": \"vSAMP10aDEV::base::module-0\",\n" +
171             "    \"version\": \"1.0\",\n" +
172             "    \"toscaModelURL\": null,\n" +
173             "    \"category\": \"resource\",\n" +
174             "    \"lifecycleState\": null,\n" +
175             "    \"lastUpdaterUserId\": null,\n" +
176             "    \"lastUpdaterFullName\": null,\n" +
177             "    \"orchestrationType\": null,\n" +
178             "    \"isInstantiationTemplateExists\": false,\n" +
179             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
180             "    \"artifacts\": null,\n" +
181             "    \"resources\": null\n" +
182             "  }, {\n" +
183             "    \"uuid\": \"204c641a-3494-48c8-979a-86856f5fd32a\",\n" +
184             "    \"invariantUUID\": \"3c504d40-b847-424c-9d25-4fb7e0a3e994\",\n" +
185             "    \"name\": \"named-query-element\",\n" +
186             "    \"version\": \"1.0\",\n" +
187             "    \"toscaModelURL\": null,\n" +
188             "    \"category\": \"widget\",\n" +
189             "    \"lifecycleState\": null,\n" +
190             "    \"lastUpdaterUserId\": null,\n" +
191             "    \"lastUpdaterFullName\": null,\n" +
192             "    \"orchestrationType\": null,\n" +
193             "    \"isInstantiationTemplateExists\": false,\n" +
194             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
195             "    \"artifacts\": null,\n" +
196             "    \"resources\": null\n" +
197             "  }, {\n" +
198             "    \"uuid\": \"acba1f72-c6e0-477f-9426-ad190151e100\",\n" +
199             "    \"invariantUUID\": \"93e56950-cb19-44e6-ace4-8b50f2d02e45\",\n" +
200             "    \"name\": \"RG_6-19_Test\",\n" +
201             "    \"version\": \"1.0\",\n" +
202             "    \"toscaModelURL\": null,\n" +
203             "    \"category\": \"resource\",\n" +
204             "    \"lifecycleState\": null,\n" +
205             "    \"lastUpdaterUserId\": null,\n" +
206             "    \"lastUpdaterFullName\": null,\n" +
207             "    \"orchestrationType\": null,\n" +
208             "    \"isInstantiationTemplateExists\": false,\n" +
209             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
210             "    \"artifacts\": null,\n" +
211             "    \"resources\": null\n" +
212             "  }, {\n" +
213             "    \"uuid\": \"fc65e5e7-45c7-488a-b36d-f453ab3057fe\",\n" +
214             "    \"invariantUUID\": \"ee448504-ceee-47db-8e1b-742115f219db\",\n" +
215             "    \"name\": \"ciServicea268facd387e\",\n" +
216             "    \"version\": \"1.0\",\n" +
217             "    \"toscaModelURL\": null,\n" +
218             "    \"category\": \"service\",\n" +
219             "    \"lifecycleState\": null,\n" +
220             "    \"lastUpdaterUserId\": null,\n" +
221             "    \"lastUpdaterFullName\": null,\n" +
222             "    \"orchestrationType\": null,\n" +
223             "    \"isInstantiationTemplateExists\": false,\n" +
224             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
225             "    \"artifacts\": null,\n" +
226             "    \"resources\": null\n" +
227             "  }, {\n" +
228             "    \"uuid\": \"027948b6-25e2-4e39-b87d-d9f5797941de\",\n" +
229             "    \"invariantUUID\": \"56f2d0d3-7943-4159-bf01-b82692ec035e\",\n" +
230             "    \"name\": \"service_sanity_amir\",\n" +
231             "    \"version\": \"2.0\",\n" +
232             "    \"toscaModelURL\": null,\n" +
233             "    \"category\": \"service\",\n" +
234             "    \"lifecycleState\": null,\n" +
235             "    \"lastUpdaterUserId\": null,\n" +
236             "    \"lastUpdaterFullName\": null,\n" +
237             "    \"orchestrationType\": null,\n" +
238             "    \"isInstantiationTemplateExists\": false,\n" +
239             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
240             "    \"artifacts\": null,\n" +
241             "    \"resources\": null\n" +
242             "  }, {\n" +
243             "    \"uuid\": \"fbf96e3b-1804-4c89-bf5b-53acb7f2edc0\",\n" +
244             "    \"invariantUUID\": \"56f2d0d3-7943-4159-bf01-b82692ec035e\",\n" +
245             "    \"name\": \"service_sanity_amir\",\n" +
246             "    \"version\": \"3.0\",\n" +
247             "    \"toscaModelURL\": null,\n" +
248             "    \"category\": \"service\",\n" +
249             "    \"lifecycleState\": null,\n" +
250             "    \"lastUpdaterUserId\": null,\n" +
251             "    \"lastUpdaterFullName\": null,\n" +
252             "    \"orchestrationType\": null,\n" +
253             "    \"isInstantiationTemplateExists\": false,\n" +
254             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
255             "    \"artifacts\": null,\n" +
256             "    \"resources\": null\n" +
257             "  }],\n" +
258             "  \"readOnly\": false\n" +
259             "}";
260     private static final String AAI_GET_ACTIVE_NETWORKS = "/aai_get_active_networks";
261
262     private String getGetOperationEnvironmentsUri() {
263         return uri.toASCIIString() + "/get_operational_environments";
264     }
265
266     private String getAaiServicesUri() {
267         return uri.toASCIIString() + "/rest/models/services";
268     }
269
270     private String getGetOperationEnvironmentUriWithParameters() {
271         String url = getGetOperationEnvironmentsUri();
272         UriComponentsBuilder builder = UriComponentsBuilder.fromUriString(url)
273                 // Add query parameter
274                 .queryParam("operationalEnvironmentStatus", OPERATIONAL_ENVIRONMENT_STATUS)
275                 .queryParam("operationalEnvironmentType", OPERATIONAL_ENVIRONMENT_TYPE);
276
277         String urlWithParameters = builder.toUriString();
278         return urlWithParameters;
279
280     }
281
282     private AaiResponse<OperationalEnvironmentList> loginAndDoGetWithUrl(String url) {
283         ResponseEntity<AaiResponse<OperationalEnvironmentList>> responseEntity = restTemplate.exchange(
284                 url,
285                 HttpMethod.GET,
286                 null,
287                 new ParameterizedTypeReference<AaiResponse<OperationalEnvironmentList>>() {});
288         AaiResponse<OperationalEnvironmentList> response = responseEntity.getBody();
289         return response;
290     }
291
292     @Test
293     public void testErrorGetOperationalEnvironments() {
294         //Register required response
295         SimulatorApi.registerExpectation(GET_OPERATIONAL_ENVIRONMENTS_JSON_ERROR, APPEND);
296         String url = getGetOperationEnvironmentsUri();
297         AaiResponse<OperationalEnvironmentList> response = loginAndDoGetWithUrl(url);
298         assertEquals(HttpStatus.INTERNAL_SERVER_ERROR.value(), response.getHttpCode());
299         assertEquals("simulated error text", response.getErrorMessage());
300
301
302     }
303
304     //This test requires a simulator which runs on VID
305     @Test
306     public void testSuccessGetOperationalEnvironments() {
307         //Register required response
308         String uuidOfOperationalEnvironment = "f07ca256-96dd-40ad-b4d2-7a77e2a974ed";
309         SimulatorApi.registerExpectation(GET_OPERATIONAL_ENVIRONMENTS_JSON, ImmutableMap.of("UUID_of_Operational_Environment", uuidOfOperationalEnvironment), APPEND);
310         String url = getGetOperationEnvironmentUriWithParameters();
311         AaiResponse<OperationalEnvironmentList> response = loginAndDoGetWithUrl(url);
312         assertEquals(HttpStatus.OK.value(), response.getHttpCode());
313         OperationalEnvironmentList list = response.getT();
314         assertNotNull(list.getOperationalEnvironment());
315         assertEquals(2, list.getOperationalEnvironment().size());
316         assertEquals(uuidOfOperationalEnvironment, list.getOperationalEnvironment().get(0).getOperationalEnvironmentId());
317         assertEquals(1, list.getOperationalEnvironment().get(0).getRelationshipList().getRelationship().size());
318     }
319
320     @Test(dataProvider = "errorCodes")
321     public void getServicesWitErrorResponse(int errorCode) throws IOException, URISyntaxException {
322         TestHelper.resetAaiCache(GET_SERVICE_MODELS_BY_DISTRIBUTION_STATUS, restTemplate, uri);
323         final String expectedResult = "{\"services\":[],\"readOnly\":false}";
324
325         callAaiWithSimulatedErrorResponse(AAI_GET_SERVICES_ERROR_SIMULATOR_RESPONSES,
326                 ImmutableMap.of("500", Integer.toString(errorCode), "ERROR_PAYLOAD", StringEscapeUtils.escapeJson(expectedResult)),
327                 getAaiServicesUri(), "", 200, expectedResult, HttpMethod.GET);
328
329     }
330
331     @Test
332     public void getServicesFineRequest() throws IOException, URISyntaxException {
333         TestHelper.resetAaiCache(GET_SERVICE_MODELS_BY_DISTRIBUTION_STATUS, restTemplate, uri);
334         callAaiWithSimulatedErrorResponse(AAI_GET_SERVICES_FINE_SIMULATOR_RESPONSES,
335                 ImmutableMap.of(),
336                 getAaiServicesUri(), "", 200, GET_AAI_SERVIES_EXPECTED_RESULT, HttpMethod.GET);
337     }
338
339     @Test
340     public void whenGetServicesErrorResponse_badResponseIsNotCached() throws IOException, URISyntaxException {
341         TestHelper.resetAaiCache(GET_SERVICE_MODELS_BY_DISTRIBUTION_STATUS, restTemplate, uri);
342
343
344         final String expectedErrorResult = "{\"services\":[],\"readOnly\":false}";
345         //call AAI with bad response by clear exceptions from simulator, bad response shall not be cached
346         callAaiWithSimulatedErrorResponse(new String[]{}, ImmutableMap.of(), getAaiServicesUri(), "", 200, expectedErrorResult, HttpMethod.GET);
347
348         //call AAI with fine response
349         callAaiWithSimulatedErrorResponse(AAI_GET_SERVICES_FINE_SIMULATOR_RESPONSES,
350                 ImmutableMap.of(),
351                 getAaiServicesUri(), "", 200, GET_AAI_SERVIES_EXPECTED_RESULT, HttpMethod.GET);
352     }
353
354     @DataProvider
355     public static Object[][] errorCodes(Method test) {
356         return new Object[][]{
357                 {500},{505}, {400}, {401}, {405}
358         };
359     }
360
361     @Test
362     public void whenThrowExceptionInsAaiResponseErrorAreLogged() {
363         String notAJson = "not a json";
364         SimulatorApi.registerExpectationFromPreset(new PresetAAIBadBodyForGetServicesGet(notAJson), CLEAR_THEN_SET);
365         SimulatorApi.registerExpectationFromPresets(getEcompPortalPresets(), APPEND);
366         SimulatorApi.registerExpectationFromPreset(new PresetAAIGetSubscribersGet(), APPEND);
367
368         restTemplateErrorAgnostic.getForEntity(uri + "/aai_get_services", String.class);
369         String logLines = LoggerFormatTest.getLogLines(LogName.error, 15, 0, restTemplate, uri);
370
371         assertThat("not found in error log", logLines, containsString("Failed to parse aai response"));
372         assertThat("not found in error log", logLines, containsString(notAJson));
373         assertThat("not found in error log", logLines, containsString("GetServicesAAIRespone"));
374
375     }
376
377     @Test
378     public void portMirroringConfigData_givenValidAaiResponse_yieldCloudRegionId() {
379         SimulatorApi.registerExpectationFromPreset(new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "THE-EXPECTED-REGION-ID"), CLEAR_THEN_SET);
380
381         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
382
383         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
384                 "SOME-RANDOM-UUID", ImmutableMap.of(
385                         "cloudRegionId", "THE-EXPECTED-REGION-ID"
386                 ));
387
388         assertResponse(expected, response);
389
390         /*
391         More tests:
392         [ ]  Error responses from AAI (404 etc): descriptive error response, including what tried and what happened
393         [ ]  malformed response from AAI: descriptive error response, including the payload
394         [ ]  empty/missing value for configurationId: client-error http code
395          */
396     }
397
398
399     @Test
400     public void portMirroringSourcePorts_validAAIResponseWithSinglePort_yieldCorrectPortData() {
401         SimulatorApi.registerExpectationFromPreset(
402                 new PresetAAIGetPortMirroringSourcePorts("CONFIGURATION-ID", "INTERFACE-ID", "INTERFACE-NAME", true),
403                 CLEAR_THEN_SET
404         );
405
406         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
407
408         final ImmutableMap<String, ImmutableList> expected = ImmutableMap.of(
409                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
410                         "interfaceId", "INTERFACE-ID", "interfaceName", "INTERFACE-NAME", "isPortMirrored", true
411                 )));
412
413         assertResponse(expected, response);
414     }
415
416     @Test
417     public void portMirroringSourcePorts_nullValueForInterfaceId_yield200OkWithFineDescription() {
418         final PresetAAIGetPortMirroringSourcePorts preset = new PresetAAIGetPortMirroringSourcePorts("CONFIGURATION-ID", null, "INTERFACE-NAME", true);
419         SimulatorApi.registerExpectationFromPreset(
420                 preset,
421                 CLEAR_THEN_SET
422         );
423
424         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
425
426         final ImmutableMap<String, ImmutableList<ImmutableMap>> expected = ImmutableMap.of(
427                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
428                         "errorDescription", "Value of 'interface-id' is missing.",
429                         "rawAaiResponse", preset.getResponseBody().toString()
430                 )));
431
432         assertResponse(expected, response);
433     }
434
435     @Test
436     public void portMirroringSourcePorts_given503ErrorAaiResponse_yield200OkWithErrorMsg() {
437         final PresetAAIGetPortMirroringSourcePortsError preset = new PresetAAIGetPortMirroringSourcePortsError("CONFIGURATION-ID", "INTERFACE-ID", "INTERFACE-NAME", true);
438         SimulatorApi.registerExpectationFromPreset(
439                 preset,
440                 CLEAR_THEN_SET
441         );
442
443         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
444
445         final ImmutableMap<String, ImmutableList<ImmutableMap>> expected = ImmutableMap.of(
446                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
447                         "errorDescription", "Got 503 from aai",
448                         "rawAaiResponse", preset.getResponseBody()
449                 )));
450
451         assertResponse(expected, response);
452     }
453
454     @Test
455     public void portMirroringConfigData_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
456         SimulatorApi.clearAll();
457
458         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
459
460         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
461                 "SOME-RANDOM-UUID", ImmutableMap.of(
462                         "errorDescription", "Got 404 from aai",
463                         "rawAaiResponse", ""
464                 ));
465
466         assertResponse(expected, response);
467     }
468
469     @Test
470     public void getNetworkCollectionDetailsByServiceInstanceId_yieldValidResponse() {
471         SimulatorApi.clearAll();
472         final PresetAAIGetNetworkCollectionDetails presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetails("SOME-RANDOM-UUID");
473         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
474         final String response = restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
475
476         assertResponse(GET_NETWORK_COLLECTION_EXPECTED_RESPONSE, response);
477     }
478
479     @Test
480     public void getNetworkCollectionDetailsByServiceInstanceId_responseWithExtraFields_yieldValidResponse() {
481         SimulatorApi.clearAll();
482         final PresetAAIGetNetworkCollectionDetailsInvalidRequest presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetailsInvalidRequest("SOME-RANDOM-UUID");
483         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
484         final String response = restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
485
486         assertResponse(GET_NETWORK_COLLECTION_EXPECTED_RESPONSE, response);
487     }
488
489     @Test
490     public void getNetworkCollectionDetailsByServiceInstanceId_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
491         SimulatorApi.clearAll();
492         try {
493             restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
494         } catch (HttpClientErrorException e) {
495             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
496         }
497     }
498
499     @Test
500     public void getNetworkCollectionDetailsByServiceInstanceId_responseWithRequiredMissing() {
501         SimulatorApi.clearAll();
502         final PresetAAIGetNetworkCollectionDetailsRequiredMissing presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetailsRequiredMissing("SOME-RANDOM-UUID");
503         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
504         try {
505             restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
506         } catch (HttpServerErrorException e) {
507             assertEquals(HttpStatus.INTERNAL_SERVER_ERROR, e.getStatusCode());
508         }
509     }
510
511     @Test
512     public void getGetInstanceGroupsByCloudRegion_yieldValidResponse() {
513         SimulatorApi.clearAll();
514         final PresetAAIGetInstanceGroupsByCloudRegion presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegion("CLOUD%20OWNER", "CLOUD-REGION-ID", "NETWORK%20FUNCTION");
515         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
516         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD OWNER" + "/" + "CLOUD-REGION-ID" + "/" + "NETWORK FUNCTION", String.class);
517
518         assertResponse(GET_INSTANCE_GROUPS_BY_CLOUDREGION_EXPECTED_RESPONSE, response);
519     }
520
521     @Test
522     public void getGetInstanceGroupsByCloudRegion_responseWithExtraFields_yieldValidResponse() {
523         SimulatorApi.clearAll();
524         final PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest("CLOUD-OWNER", "CLOUD-REGION-ID", "NETWORK-FUNCTION");
525         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
526         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" + "NETWORK-FUNCTION", String.class);
527
528         assertResponse(GET_INSTANCE_GROUPS_BY_CLOUDREGION_EXPECTED_RESPONSE, response);
529     }
530
531     @Test
532     public void getGetInstanceGroupsByCloudRegion_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
533         SimulatorApi.clearAll();
534         try {
535             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" + "NETWORK-FUNCTION", String.class);
536         } catch (HttpClientErrorException e) {
537             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
538         }
539     }
540
541     @Test
542     public void getGetInstanceGroupsByCloudRegion_responseWithRequiredMissing() {
543         SimulatorApi.clearAll();
544         final PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing("CLOUD-OWNER", "CLOUD-REGION-ID", "NETWORK-FUNCTION");
545         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
546         try {
547             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" + "NETWORK-FUNCTION", String.class);
548         } catch (HttpServerErrorException e) {
549             assertEquals(HttpStatus.INTERNAL_SERVER_ERROR, e.getStatusCode());
550         }
551     }
552
553     @Test
554     public void portMirroringConfigData_emptyIdOnAaiResponse_yieldError() {
555         final PresetAAICloudRegionAndSourceFromConfigurationPut presetAAIResponseWitnProblem = new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "");
556         SimulatorApi.registerExpectationFromPreset(presetAAIResponseWitnProblem, CLEAR_THEN_SET);
557
558         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
559
560         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
561                 "SOME-RANDOM-UUID", ImmutableMap.of(
562                         "errorDescription", "Node 'properties.cloud-region-id' of node-type 'cloud-region' is blank",
563                         "rawAaiResponse", presetAAIResponseWitnProblem.getResponseBody().toString().replace(" ", "")
564                 ));
565
566         assertResponse(expected, response);
567     }
568
569     @Test
570     public void getGetRelatedInstanceGroupsByVnfId__yieldValidResponse() {
571         String vnfId = "some_vnf_id";
572         final PresetAAIGetRelatedInstanceGroupsByVnfId getRelatedInstanceGroupsByVnfId = new PresetAAIGetRelatedInstanceGroupsByVnfId(vnfId);
573         SimulatorApi.registerExpectationFromPreset(getRelatedInstanceGroupsByVnfId, CLEAR_THEN_SET);
574
575         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_vnf_instance_id/" + vnfId,
576                 String.class);
577
578         assertResponse("[{\"type\":\"instance-group\",\"name\":\"instance group name\"},{\"type\":\"instance-group\",\"name\":\"instance group name\"}]", response);
579     }
580
581     @Test
582     public void getHomingDataForVfModule(){
583         String vnfId= "0846287b-65bf-45a6-88f6-6a1af4149fac", vfModuleId= "a9b70ac0-5917-4203-a308-0e6920e6d09b";
584         SimulatorApi.registerExpectationFromPreset(new PresetAAIGetHomingForVfModule(vnfId,vfModuleId), CLEAR_THEN_SET);
585         final String response = restTemplate.getForObject(uri + "/aai_get_homing_by_vfmodule/"+ vnfId +"/"+vfModuleId, String.class);
586         String exectedResponse = TestUtils.convertRequest(objectMapper, AAI_HOMING_DATA_RESPONSE);
587         assertResponse(exectedResponse,response);
588     }
589
590     @Test
591     public void getGetRelatedInstanceGroupsByVnfId__yield404NotFound() {
592         final PresetAAIGetRelatedInstanceGroupsByVnfId getRelatedInstanceGroupsByVnfId = new PresetAAIGetRelatedInstanceGroupsByVnfId("abcd");
593         SimulatorApi.registerExpectationFromPreset(getRelatedInstanceGroupsByVnfId, CLEAR_THEN_SET);
594         try {
595             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_vnf_instance_id/" + "dcba", String.class);
596         } catch (HttpClientErrorException e) {
597             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
598         }
599
600     }
601
602     @Test
603     public void portMirroringConfigData_twoResponsesOneValidAndOneInvalid_yieldBothErrorAndOk() {
604         final PresetAAICloudRegionAndSourceFromConfigurationPut presetAAIResponseWitnProblem = new PresetAAICloudRegionAndSourceFromConfigurationPut("ANOTHER-RANDOM-UUID", "");
605         SimulatorApi.registerExpectationFromPreset(presetAAIResponseWitnProblem, CLEAR_THEN_SET);
606         SimulatorApi.registerExpectationFromPreset(new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "THE-EXPECTED-REGION-ID"), APPEND);
607
608         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID,ANOTHER-RANDOM-UUID", String.class);
609
610         final ImmutableMap<String, ImmutableMap<String, Object>> expected = ImmutableMap.of(
611                 "SOME-RANDOM-UUID", ImmutableMap.of(
612                         "cloudRegionId", "THE-EXPECTED-REGION-ID"
613                 ),
614                 "ANOTHER-RANDOM-UUID", ImmutableMap.of(
615                         "errorDescription", "Node 'properties.cloud-region-id' of node-type 'cloud-region' is blank",
616                         "rawAaiResponse", presetAAIResponseWitnProblem.getResponseBody().toString().replace(" ", "")
617                 ));
618
619         assertResponse(expected, response);
620     }
621
622     @Test
623     @FeatureTogglingTest(Features.FLAG_PRESENT_PROVIDER_NETWORKS_ASSOCIATIONS)
624     public void networksToVlans_simpleRequest_responseIsCorrect() {
625         // Prepare randomized values
626         // Some of these random values are persisted to match with the
627         // cypress preset "aaiGetNetworksToVlansByServiceInstance.json".
628         String globalCustomerId = UUID.randomUUID().toString();
629         String sdcModelUuid = "5a3ad576-c01d-4bed-8194-0e72b4a3d020";
630         String serviceType = "vMOG";
631         int vlanIdOuter = 34612;
632         int vlanIdOuter2 = 8568012;
633         int vlanIdOuter3 = 4;
634
635         // build hierarchical presets:
636         //
637         //     service instance
638         //               ║
639         //               ╠═  network 1
640         //               ║      ╠═  vlan 1
641         //               ║      ╚═  vlan 2
642         //               ║
643         //               ╠═  network 2
644         //               ║      ╚═  vlan 3
645         //               ║
646         PresetAAIStandardQueryGet vlanTagPreset1 = ofVlanTag(vlanIdOuter);
647         PresetAAIStandardQueryGet vlanTagPreset2 = ofVlanTag(vlanIdOuter2);
648         PresetAAIStandardQueryGet vlanTagPreset3 = ofVlanTag(vlanIdOuter3);
649
650         PresetAAIStandardQueryGet l3NetworkPreset1 = ofL3Network("7989a6d2-ba10-4a5d-8f15-4520bc833090", "DDDEEEFFF", "Provider Network",
651                 ImmutableMultimap.of("vlan-tag", vlanTagPreset1.getReqPath(), "vlan-tag", vlanTagPreset2.getReqPath()), "Failed");
652         PresetAAIStandardQueryGet l3NetworkPreset2 = ofL3Network("e8e2332e-1f84-4237-bc97-3b5b842f52e4","GGGHHHIII", "Network",
653                 ImmutableMultimap.of("vlan-tag", vlanTagPreset3.getReqPath()), "Assigned");
654
655         PresetAAIStandardQueryGet serviceInstance = ofServiceInstance("9cdd1b2a-43a7-47bc-a88e-759ba2399f0b",
656                 "7a6ee536-f052-46fa-aa7e-2fca9d674c44", "6e59c5de-f052-46fa-aa7e-2fca9d674c44", globalCustomerId, serviceType,
657                 ImmutableMultimap.of("l3-network", l3NetworkPreset1.getReqPath(), "l3-network", l3NetworkPreset2.getReqPath()));
658
659         SimulatorApi.registerExpectationFromPresets(ImmutableList.of(
660                 serviceInstance, l3NetworkPreset1, l3NetworkPreset2, vlanTagPreset1, vlanTagPreset2, vlanTagPreset3,
661                 new PresetSDCGetServiceMetadataGet(sdcModelUuid, UUID.randomUUID().toString(), "service-vl-with-5g-network-provider-alacarte.zip"),
662                 new PresetSDCGetServiceToscaModelGet(sdcModelUuid, "service-vl-with-5g-network-provider-alacarte.zip")
663         ), CLEAR_THEN_SET);
664
665         // THE TEST
666         final String response = restTemplate.getForObject(uri + "/aai/standardQuery/vlansByNetworks"
667                         + "?serviceInstanceId=" + serviceInstance.getInstanceId()
668                         + "&serviceType=" + serviceType
669                         + "&globalCustomerId=" + globalCustomerId
670                         + "&sdcModelUuid=" + sdcModelUuid
671                 , String.class);
672
673         assertResponse(JsonAssert.when(Option.IGNORING_ARRAY_ORDER),
674                 getResourceAsString("serviceWithNetwork/aaiGetNetworksToVlansByServiceInstance.json"),
675                 response);
676     }
677
678     @Test
679     @FeatureTogglingTest(Features.FLAG_PRESENT_PROVIDER_NETWORKS_ASSOCIATIONS)
680     public void networksWithVlansToVnf_simpleRequest_responseIsCorrect() {
681         // Prepare randomized values
682         // Some of these random values are persisted to match with the
683         // cypress preset "aaiGetNetworksWithVlansToVnfByServiceInstance.json".
684         String globalCustomerId = UUID.randomUUID().toString();
685         String sdcModelUuid = "5a3ad576-c01d-4bed-8194-0e72b4a3d020";
686         String serviceType = "vMOG";
687         int vlanIdOuter = 34123;
688         int vlanIdOuter2 = 65540;
689         int vlanIdOuter3 = 12345;
690         int vlanIdOuter4 = 67890;
691         int vlanIdOuter5 = 417695;
692         int vlanIdOuter6 = 783243;
693
694         // build hierarchical presets:
695         //
696         //     service instance
697         //               ║
698         //               ╠═  vnf 1
699         //               ║    ╚═  network 1
700         //               ║          ╠═  vlan 1
701         //               ║          ╚═  vlan 2
702         //               ║    ╚═  network 2
703         //               ║          ╠═  vlan 3
704         //               ║          ╚═  vlan 4
705         //               ║
706         //               ╠═  vnf 2
707         //               ║    ╚═  network 3
708         //               ║          ╠═  vlan 5
709         //               ║          ╚═  vlan 6
710         //               ║
711         PresetAAIStandardQueryGet vlanTagPreset1 = ofVlanTag(vlanIdOuter);
712         PresetAAIStandardQueryGet vlanTagPreset2 = ofVlanTag(vlanIdOuter2);
713         PresetAAIStandardQueryGet vlanTagPreset3 = ofVlanTag(vlanIdOuter3);
714         PresetAAIStandardQueryGet vlanTagPreset4 = ofVlanTag(vlanIdOuter4);
715         PresetAAIStandardQueryGet vlanTagPreset5 = ofVlanTag(vlanIdOuter5);
716         PresetAAIStandardQueryGet vlanTagPreset6 = ofVlanTag(vlanIdOuter6);
717
718         PresetAAIStandardQueryGet l3NetworkPreset1 = ofL3Network("36517f3d-2bc2-48f5-aaf8-418520c54330","AAAAABBBBCCCC", "Provider Network",
719                 ImmutableMultimap.of("vlan-tag", vlanTagPreset1.getReqPath(), "vlan-tag", vlanTagPreset2.getReqPath()), "Assigned");
720
721         PresetAAIStandardQueryGet l3NetworkPreset2 = ofL3Network("12347f3d-2bc2-48f5-aaf8-418520c54330","DDDEEEE", "Provider Network",
722                 ImmutableMultimap.of("vlan-tag", vlanTagPreset3.getReqPath(), "vlan-tag", vlanTagPreset4.getReqPath()), "Created");
723
724         PresetAAIStandardQueryGet vnfPreset1 = ofVnf("c015cc0f-0f37-4488-aabf-53795fd93cd3",
725                 ImmutableMultimap.of("l3-network", l3NetworkPreset1.getReqPath() , "l3-network", l3NetworkPreset2.getReqPath()),
726                 defaultPlacement());
727
728         PresetAAIStandardQueryGet l3NetworkPreset3 = ofL3Network("12aa7f3d-2bc2-48f5-aaf8-418520c54330","XXXYYYZZZ", "Network",
729                 ImmutableMultimap.of("vlan-tag", vlanTagPreset5.getReqPath(), "vlan-tag", vlanTagPreset6.getReqPath()), "Created");
730
731         PresetAAIStandardQueryGet vnfPreset2 = ofVnf("c55da606-cf38-42c7-bc3c-be8e23b19299", ImmutableMultimap.of("l3-network", l3NetworkPreset3.getReqPath()),
732                 defaultPlacement());
733
734         PresetAAIStandardQueryGet serviceInstance = ofServiceInstance("9cdd1b2a-43a7-47bc-a88e-759ba2399f0b",
735                 "7a6ee536-f052-46fa-aa7e-2fca9d674c44", "6e59c5de-f052-46fa-aa7e-2fca9d674c44", globalCustomerId, serviceType,
736                 ImmutableMultimap.of("generic-vnf", vnfPreset1.getReqPath(), "generic-vnf", vnfPreset2.getReqPath()));
737
738         SimulatorApi.registerExpectationFromPresets(ImmutableList.of(
739                 serviceInstance, vnfPreset1, vnfPreset2, l3NetworkPreset1, l3NetworkPreset2, l3NetworkPreset3, vlanTagPreset1, vlanTagPreset2, vlanTagPreset3, vlanTagPreset4, vlanTagPreset5, vlanTagPreset6,
740                 new PresetSDCGetServiceMetadataGet(sdcModelUuid, UUID.randomUUID().toString(), "service-vl-with-5g-network-provider-alacarte.zip"),
741                 new PresetSDCGetServiceToscaModelGet(sdcModelUuid, "service-vl-with-5g-network-provider-alacarte.zip")
742         ), CLEAR_THEN_SET);
743
744         // THE TEST
745         final String response = restTemplate.getForObject(uri + "/aai/standardQuery/vlansByNetworks"
746                         + "?serviceInstanceId=" + serviceInstance.getInstanceId()
747                         + "&serviceType=" + serviceType
748                         + "&globalCustomerId=" + globalCustomerId
749                         + "&sdcModelUuid=" + sdcModelUuid
750                 , String.class);
751
752         assertResponse(JsonAssert.when(Option.IGNORING_ARRAY_ORDER),
753                 getResourceAsString("serviceWithNetwork/aaiGetNetworksWithVlansToVnfByServiceInstance.json"),
754                 response);
755     }
756
757     @FeatureTogglingTest(value = Features.FLAG_FLASH_REDUCED_RESPONSE_CHANGEMG, flagActive = false)
758     @Test
759     public void getVnfDataByGlobalIdAndServiceType() {
760
761         SimulatorApi.registerExpectationFromPreset(new PresetBaseAAICustomQuery(
762             SIMPLE,
763             "business/customers/customer/a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb/service-subscriptions/service-subscription/vRichardson/service-instances",
764             "query/vnf-topology-fromServiceInstance"
765         ) {
766             @Override
767             public Object getResponseBody() {
768                 return getResourceAsString(
769                     "registration_to_simulator/changeManagement/get_vnf_data_by_globalid_and_service_type_response.json");
770             }
771         }, CLEAR_THEN_SET);
772
773         String url = uri + "/get_vnf_data_by_globalid_and_service_type/a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb/vRichardson";
774
775         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
776
777         assertResponse(JsonAssert.when(Option.IGNORING_ARRAY_ORDER),
778                 getResourceAsString("registration_to_simulator/changeManagement/get_vnf_data_by_globalid_and_service_type_response.json"),
779                 response.getBody());
780     }
781
782     @Test
783     public void whenCallAaiThroughAAIRestInterface_thenRequestRecordedInMetricsLog() {
784         registerExpectationFromPresets(ImmutableList.of(
785             new PresetAAIGetVpnsByType(),
786             new PresetAAIGetSubscribersGet()
787         ),CLEAR_THEN_SET);
788         String internalPath = "/aai_get_vpn_list";
789         String url = uri + internalPath;
790         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
791         final String requestId = response.getHeaders().getFirst("X-ECOMP-RequestID-echo");
792         LoggerFormatTest.assertHeadersAndMetricLogs(restTemplate, uri, requestId,"/network/vpn-bindings" , 1);
793         LoggerFormatTest.verifyExistenceOfIncomingReqsInAuditLogs(restTemplate, uri, requestId, internalPath);
794     }
795
796     @Test
797     public void getVpnList() {
798         SimulatorApi.registerExpectationFromPreset(new PresetAAIGetVpnsByType(), CLEAR_THEN_SET);
799         String url = uri + "/aai_get_vpn_list";
800         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
801         String expected = getResourceAsString("viewEdit/aaiGetVpnList.json");
802         assertThat(response.getBody(), jsonEquals(expected).when(Option.IGNORING_ARRAY_ORDER).when(Option.IGNORING_EXTRA_FIELDS));
803     }
804
805     @DataProvider
806     public static Object[][] getActiveNetworkAaiStates() {
807         return new Object[][] {
808                 {1, "viewEdit/aaiGetActiveNetworks.json"},
809                 {2, "viewEdit/aaiGetActiveNetworks2.json"}
810         };
811     }
812
813     @Test(dataProvider = "getActiveNetworkAaiStates")
814     public void getActiveNetworks_givenSpecificAAIState_cypressPresetMatch(int state, String expectedResultFileName) {
815         SimulatorApi.registerExpectationFromPresets(ImmutableList.of(
816             new PresetAAIGetL3NetworksByCloudRegionSpecificState(state),
817             PresetAAIGetCloudOwnersByCloudRegionId.PRESET_AUK51A_TO_ATT_NC
818         ), CLEAR_THEN_SET);
819         String url = uri + AAI_GET_ACTIVE_NETWORKS
820             + "?cloudRegion=" + AAIBaseGetL3NetworksByCloudRegionPreset.DEFAULT_CLOUD_REGION_ID
821             + "&tenantId=" + AAIBaseGetL3NetworksByCloudRegionPreset.DEFAULT_TENANT_ID;
822         String response = restTemplate.getForObject(url, String.class);
823         System.out.println("response = " + response);
824         String expected = getResourceAsString(expectedResultFileName);
825         assertThat(response, jsonEquals(expected));
826     }
827
828     @Test
829     public void getActiveNetworks() throws JsonProcessingException {
830         String networkRole = "Some role";
831         PresetAAIGetL3NetworksByCloudRegion presetAAIGetL3NetworksByCloudRegion = new PresetAAIGetL3NetworksByCloudRegion(networkRole);
832         List<BasePreset> presets = ImmutableList.of(
833                 presetAAIGetL3NetworksByCloudRegion,
834                 PresetAAIGetCloudOwnersByCloudRegionId.PRESET_AUK51A_TO_ATT_NC
835         );
836         SimulatorApi.registerExpectationFromPresets(presets, CLEAR_THEN_SET);
837         String url = uri + AAI_GET_ACTIVE_NETWORKS +
838                 "?cloudRegion=" + presetAAIGetL3NetworksByCloudRegion.getCloudRegionId() +
839                 "&tenantId=" + presetAAIGetL3NetworksByCloudRegion.getTenantId() +
840                  "&networkRole=" + networkRole;
841         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
842
843         assertResponse(JsonAssert.when(Option.IGNORING_EXTRA_FIELDS, Option.IGNORING_ARRAY_ORDER),
844                 presetAAIGetL3NetworksByCloudRegion.getActiveNetworksWithNameAndRelatedToVpnBindingAsJsonString(),
845                 response.getBody());
846     }
847
848     @Test
849     public void getNewestModelVersionByInvariant() throws JsonProcessingException {
850         String invariantId = "f6342be5-d66b-4d03-a1aa-c82c3094c4ea";
851
852         SimulatorApi.registerExpectationFromPreset(new PresetAAIModelVersionsByInvariantId(), CLEAR_THEN_SET );
853
854         String url = uri +
855                 "/aai_get_newest_model_version_by_invariant/" + invariantId;
856         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
857
858         assertTrue(response.toString().contains("the-newest-version"));
859     }
860
861     @Test
862     public void getNewestModelVersionByInvariant_modelNotExist_thenEmptyResponse() {
863         String invariantId = "f6342be5-d66b-4d03-a1aa-c82c3094c4ea";
864
865         SimulatorApi.registerExpectationFromPreset(new PresetAAIModelVersionsByInvariantId(), CLEAR_THEN_SET );
866
867         String url = uri +
868                 "/aai_get_newest_model_version_by_invariant/" + "model-not-exist";
869         ResponseEntity<String> response = restTemplate.getForEntity(url, String.class);
870
871         assertTrue(response.getStatusCode().is2xxSuccessful());
872         AssertJUnit.assertNull(response.getBody());
873     }
874
875     @Test
876     @FeatureTogglingTest(Features.FLAG_FLASH_REDUCED_RESPONSE_CHANGEMG)
877     public void getVnfsWithCustomQueryNewReducedResponse() throws URISyntaxException {
878
879         String globalCustomerId = "globalCustomerId1-360-as988q";
880         String serviceType = "TEST1-360";
881         String nfRole = "test360";
882         SimulatorApi.registerExpectationFromPreset(new PresetBaseAAICustomQuery(
883             SIMPLE,
884             "/business/customers/customer/" + globalCustomerId + "/service-subscriptions/service-subscription/"
885                 + serviceType + "/service-instances",
886             "query/vnfs-fromServiceInstance-filter?nfRole=" + nfRole
887             ) {
888             @Override
889             public Object getResponseBody() {
890                 return getResourceAsString(
891                     AAI_VNFS_FOR_CHANGE_MANAGEMENT_JSON_BY_PARAMS);
892             }
893         }, CLEAR_THEN_SET);
894         URIBuilder urlBuilder  = new URIBuilder(uri + "/get_vnf_data_by_globalid_and_service_type/" + globalCustomerId + "/" + serviceType);
895         urlBuilder.addParameter("nfRole", nfRole);
896         ResponseEntity<String> response = restTemplate.getForEntity(urlBuilder.build().toString(), String.class);
897         assertTrue(response.getStatusCode().is2xxSuccessful());
898         assertThat(response.getBody(), jsonEquals(getResourceAsString(AAI_VNFS_FOR_CHANGE_MANAGEMENT_JSON_BY_PARAMS)));
899     }
900
901     private void assertResponse(Object expected, String response) {
902         assertResponse(Configuration.empty(), expected, response);
903     }
904
905     private void assertResponse(Configuration configuration, Object expected, String response) {
906         try {
907             JsonAssert.assertJsonEquals(expected, response, configuration);
908         } catch (Exception | AssertionError e) {
909             System.err.println("response was: " + response);
910             throw e;
911         }
912     }
913 }