7d558940d645ad1f0e2874ef19657cf6296bc460
[vid.git] / vid-automation / src / test / java / org / onap / vid / api / AaiApiTest.java
1 package org.onap.vid.api;
2
3 import com.google.common.collect.ImmutableList;
4 import com.google.common.collect.ImmutableMap;
5 import net.javacrumbs.jsonunit.JsonAssert;
6 import org.apache.commons.text.StringEscapeUtils;
7 import org.codehaus.jackson.map.ObjectMapper;
8 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIBadBodyForGetServicesGet;
9 import org.onap.simulator.presetGenerator.presets.aai.PresetAAICloudRegionAndSourceFromConfigurationPut;
10 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegion;
11 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest;
12 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing;
13 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetails;
14 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetailsInvalidRequest;
15 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetNetworkCollectionDetailsRequiredMissing;
16 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetPortMirroringSourcePorts;
17 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetPortMirroringSourcePortsError;
18 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetRelatedInstanceGroupsByVnfId;
19 import org.onap.simulator.presetGenerator.presets.aai.PresetAAIGetSubscribersGet;
20 import org.onap.vid.model.aai.AaiResponse;
21 import org.onap.vid.model.mso.OperationalEnvironmentList;
22 import org.onap.vid.more.LoggerFormatTest;
23 import org.springframework.core.ParameterizedTypeReference;
24 import org.springframework.http.HttpMethod;
25 import org.springframework.http.HttpStatus;
26 import org.springframework.http.ResponseEntity;
27 import org.springframework.web.client.HttpClientErrorException;
28 import org.springframework.web.client.HttpServerErrorException;
29 import org.springframework.web.util.UriComponentsBuilder;
30 import org.testng.annotations.DataProvider;
31 import org.testng.annotations.Test;
32 import vid.automation.test.services.SimulatorApi;
33
34 import java.io.IOException;
35 import java.lang.reflect.Method;
36 import java.net.URISyntaxException;
37
38 import static org.hamcrest.CoreMatchers.containsString;
39 import static org.junit.Assert.*;
40 import static org.onap.simulator.presetGenerator.presets.ecompportal_att.EcompPortalPresetsUtils.getEcompPortalPresets;
41 import static vid.automation.test.services.SimulatorApi.RegistrationStrategy.APPEND;
42 import static vid.automation.test.services.SimulatorApi.RegistrationStrategy.CLEAR_THEN_SET;
43
44 public class AaiApiTest extends BaseApiAaiTest {
45
46
47     public static final String GET_OPERATIONAL_ENVIRONMENTS_JSON = "get_operational_environments_aai.json";
48     public static final String GET_OPERATIONAL_ENVIRONMENTS_JSON_ERROR = "get_operational_environments_aai_error.json";
49     public static final String[] AAI_GET_SERVICES_ERROR_SIMULATOR_RESPONSES = {"getServicesAaiErrorResp.json", "aai_get_full_subscribers.json"};
50     public static final String[] AAI_GET_SERVICES_FINE_SIMULATOR_RESPONSES = {"getServicesAaiFineResp.json", "aai_get_full_subscribers.json"};
51
52     public static final String OPERATIONAL_ENVIRONMENT_TYPE = "VNF";
53     public static final String OPERATIONAL_ENVIRONMENT_STATUS = "Activate";
54     public static final String BASE_GET_SERVICES_AAI_REQUEST_BODY = "{\"start\" : \"service-design-and-creation/models\", \"query\" : \"query/serviceModels-byDistributionStatus?distributionStatus=DISTRIBUTION_COMPLETE_OK\";}";
55     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";
56     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\":\"HngwProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662814627\",\"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\":\"HngwProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662816043\",\"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\":\"HngwProtectedOam.OAM\",\"network-technology\":\"Contrail\",\"is-bound-to-vpn\":false,\"resource-version\":\"1521662815304\",\"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";
57     public static final String GET_AAI_SERVIES_EXPECTED_RESULT = "{\n" +
58             "  \"services\": [{\n" +
59             "    \"uuid\": \"20c4431c-246d-11e7-93ae-92361f002671\",\n" +
60             "    \"invariantUUID\": \"78ca26d0-246d-11e7-93ae-92361f002671\",\n" +
61             "    \"name\": \"vSAMP10aDEV::base::module-0\",\n" +
62             "    \"version\": \"2\",\n" +
63             "    \"toscaModelURL\": null,\n" +
64             "    \"category\": \"resource\",\n" +
65             "    \"lifecycleState\": null,\n" +
66             "    \"lastUpdaterUserId\": null,\n" +
67             "    \"lastUpdaterFullName\": null,\n" +
68             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
69             "    \"artifacts\": null,\n" +
70             "    \"resources\": null\n" +
71             "  }, {\n" +
72             "    \"uuid\": \"797a6c41-0f80-4d35-a288-3920c4e06baa\",\n" +
73             "    \"invariantUUID\": \"5b607929-6088-4614-97ef-cac817508e0e\",\n" +
74             "    \"name\": \"CONTRAIL30_L2NODHCP\",\n" +
75             "    \"version\": \"1.0\",\n" +
76             "    \"toscaModelURL\": null,\n" +
77             "    \"category\": \"resource\",\n" +
78             "    \"lifecycleState\": null,\n" +
79             "    \"lastUpdaterUserId\": null,\n" +
80             "    \"lastUpdaterFullName\": null,\n" +
81             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_ERROR\",\n" +
82             "    \"artifacts\": null,\n" +
83             "    \"resources\": null\n" +
84             "  }, {\n" +
85             "    \"uuid\": \"f1bde010-cc5f-4765-941f-75f15b24f9fc\",\n" +
86             "    \"invariantUUID\": \"0143d57b-a517-4de9-a0a1-eb76db51f402\",\n" +
87             "    \"name\": \"BkVmxAv061917..base_vPE_AV..module-0\",\n" +
88             "    \"version\": \"2\",\n" +
89             "    \"toscaModelURL\": null,\n" +
90             "    \"category\": \"resource\",\n" +
91             "    \"lifecycleState\": null,\n" +
92             "    \"lastUpdaterUserId\": null,\n" +
93             "    \"lastUpdaterFullName\": null,\n" +
94             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
95             "    \"artifacts\": null,\n" +
96             "    \"resources\": null\n" +
97             "  }, {\n" +
98             "    \"uuid\": \"ipe-resource-id-ps-02\",\n" +
99             "    \"invariantUUID\": \"ipe-resource-id-ps-02\",\n" +
100             "    \"name\": \"abc\",\n" +
101             "    \"version\": \"v1.0\",\n" +
102             "    \"toscaModelURL\": null,\n" +
103             "    \"category\": \"resource\",\n" +
104             "    \"lifecycleState\": null,\n" +
105             "    \"lastUpdaterUserId\": null,\n" +
106             "    \"lastUpdaterFullName\": null,\n" +
107             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
108             "    \"artifacts\": null,\n" +
109             "    \"resources\": null\n" +
110             "  }, {\n" +
111             "    \"uuid\": \"lmoser410-connector-model-version-id\",\n" +
112             "    \"invariantUUID\": \"lmoser410-connector-model-id\",\n" +
113             "    \"name\": \"connector\",\n" +
114             "    \"version\": \"v1.0\",\n" +
115             "    \"toscaModelURL\": null,\n" +
116             "    \"category\": \"widget\",\n" +
117             "    \"lifecycleState\": null,\n" +
118             "    \"lastUpdaterUserId\": null,\n" +
119             "    \"lastUpdaterFullName\": null,\n" +
120             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
121             "    \"artifacts\": null,\n" +
122             "    \"resources\": null\n" +
123             "  }, {\n" +
124             "    \"uuid\": \"ff2ae348-214a-11e7-93ae-92361f002673\",\n" +
125             "    \"invariantUUID\": \"3a97db99-c4bb-498a-a13a-38f65f1ced3d\",\n" +
126             "    \"name\": \"vSAMP10aDEV::base::module-0\",\n" +
127             "    \"version\": \"1.0\",\n" +
128             "    \"toscaModelURL\": null,\n" +
129             "    \"category\": \"resource\",\n" +
130             "    \"lifecycleState\": null,\n" +
131             "    \"lastUpdaterUserId\": null,\n" +
132             "    \"lastUpdaterFullName\": null,\n" +
133             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
134             "    \"artifacts\": null,\n" +
135             "    \"resources\": null\n" +
136             "  }, {\n" +
137             "    \"uuid\": \"204c641a-3494-48c8-979a-86856f5fd32a\",\n" +
138             "    \"invariantUUID\": \"3c504d40-b847-424c-9d25-4fb7e0a3e994\",\n" +
139             "    \"name\": \"named-query-element\",\n" +
140             "    \"version\": \"1.0\",\n" +
141             "    \"toscaModelURL\": null,\n" +
142             "    \"category\": \"widget\",\n" +
143             "    \"lifecycleState\": null,\n" +
144             "    \"lastUpdaterUserId\": null,\n" +
145             "    \"lastUpdaterFullName\": null,\n" +
146             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
147             "    \"artifacts\": null,\n" +
148             "    \"resources\": null\n" +
149             "  }, {\n" +
150             "    \"uuid\": \"acba1f72-c6e0-477f-9426-ad190151e100\",\n" +
151             "    \"invariantUUID\": \"93e56950-cb19-44e6-ace4-8b50f2d02e45\",\n" +
152             "    \"name\": \"RG_6-19_Test\",\n" +
153             "    \"version\": \"1.0\",\n" +
154             "    \"toscaModelURL\": null,\n" +
155             "    \"category\": \"resource\",\n" +
156             "    \"lifecycleState\": null,\n" +
157             "    \"lastUpdaterUserId\": null,\n" +
158             "    \"lastUpdaterFullName\": null,\n" +
159             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
160             "    \"artifacts\": null,\n" +
161             "    \"resources\": null\n" +
162             "  }, {\n" +
163             "    \"uuid\": \"fc65e5e7-45c7-488a-b36d-f453ab3057fe\",\n" +
164             "    \"invariantUUID\": \"ee448504-ceee-47db-8e1b-742115f219db\",\n" +
165             "    \"name\": \"ciServicea268facd387e\",\n" +
166             "    \"version\": \"1.0\",\n" +
167             "    \"toscaModelURL\": null,\n" +
168             "    \"category\": \"service\",\n" +
169             "    \"lifecycleState\": null,\n" +
170             "    \"lastUpdaterUserId\": null,\n" +
171             "    \"lastUpdaterFullName\": null,\n" +
172             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
173             "    \"artifacts\": null,\n" +
174             "    \"resources\": null\n" +
175             "  }, {\n" +
176             "    \"uuid\": \"027948b6-25e2-4e39-b87d-d9f5797941de\",\n" +
177             "    \"invariantUUID\": \"56f2d0d3-7943-4159-bf01-b82692ec035e\",\n" +
178             "    \"name\": \"service_sanity_amir\",\n" +
179             "    \"version\": \"2.0\",\n" +
180             "    \"toscaModelURL\": null,\n" +
181             "    \"category\": \"service\",\n" +
182             "    \"lifecycleState\": null,\n" +
183             "    \"lastUpdaterUserId\": null,\n" +
184             "    \"lastUpdaterFullName\": null,\n" +
185             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
186             "    \"artifacts\": null,\n" +
187             "    \"resources\": null\n" +
188             "  }, {\n" +
189             "    \"uuid\": \"fbf96e3b-1804-4c89-bf5b-53acb7f2edc0\",\n" +
190             "    \"invariantUUID\": \"56f2d0d3-7943-4159-bf01-b82692ec035e\",\n" +
191             "    \"name\": \"service_sanity_amir\",\n" +
192             "    \"version\": \"3.0\",\n" +
193             "    \"toscaModelURL\": null,\n" +
194             "    \"category\": \"service\",\n" +
195             "    \"lifecycleState\": null,\n" +
196             "    \"lastUpdaterUserId\": null,\n" +
197             "    \"lastUpdaterFullName\": null,\n" +
198             "    \"distributionStatus\": \"DISTRIBUTION_COMPLETE_OK\",\n" +
199             "    \"artifacts\": null,\n" +
200             "    \"resources\": null\n" +
201             "  }],\n" +
202             "  \"readOnly\": false\n" +
203             "}";
204
205     static final ObjectMapper om = new ObjectMapper();
206
207     private String getGetOperationEnvironmentsUri() {
208         return uri.toASCIIString() + "/get_operational_environments";
209     }
210
211     private String getAaiServicesUri() {
212         return uri.toASCIIString() + "/rest/models/services";
213     }
214
215     private String getGetOperationEnvironmentUriWithParameters() {
216         String url = getGetOperationEnvironmentsUri();
217         UriComponentsBuilder builder = UriComponentsBuilder.fromUriString(url)
218                 // Add query parameter
219                 .queryParam("operationalEnvironmentStatus", OPERATIONAL_ENVIRONMENT_STATUS)
220                 .queryParam("operationalEnvironmentType", OPERATIONAL_ENVIRONMENT_TYPE);
221
222         String urlWithParameters = builder.toUriString();
223         return urlWithParameters;
224
225     }
226
227     private AaiResponse<OperationalEnvironmentList> loginAndDoGetWithUrl(String url) {
228         ResponseEntity<AaiResponse<OperationalEnvironmentList>> responseEntity = restTemplate.exchange(
229                 url,
230                 HttpMethod.GET,
231                 null,
232                 new ParameterizedTypeReference<AaiResponse<OperationalEnvironmentList>>() {});
233         AaiResponse<OperationalEnvironmentList> response = responseEntity.getBody();
234         return response;
235     }
236
237     @Test
238     public void testErrorGetOperationalEnvironments() {
239         //Register required response
240         SimulatorApi.registerExpectation(GET_OPERATIONAL_ENVIRONMENTS_JSON_ERROR, APPEND);
241         String url = getGetOperationEnvironmentsUri();
242         AaiResponse<OperationalEnvironmentList> response = loginAndDoGetWithUrl(url);
243         assertEquals(HttpStatus.INTERNAL_SERVER_ERROR.value(), response.getHttpCode());
244         assertEquals("simulated error text", response.getErrorMessage());
245
246
247     }
248
249     //This test requires a simulator which runs on VID
250     @Test
251     public void testSuccessGetOperationalEnvironments() {
252         //Register required response
253         String uuidOfOperationalEnvironment = "f07ca256-96dd-40ad-b4d2-7a77e2a974ed";
254         SimulatorApi.registerExpectation(GET_OPERATIONAL_ENVIRONMENTS_JSON, ImmutableMap.of("UUID_of_Operational_Environment", uuidOfOperationalEnvironment), APPEND);
255         String url = getGetOperationEnvironmentUriWithParameters();
256         AaiResponse<OperationalEnvironmentList> response = loginAndDoGetWithUrl(url);
257         assertEquals(HttpStatus.OK.value(), response.getHttpCode());
258         OperationalEnvironmentList list = response.getT();
259         assertNotEquals(null, list.getOperationalEnvironment());
260         assertEquals(2, list.getOperationalEnvironment().size());
261         assertEquals(uuidOfOperationalEnvironment, list.getOperationalEnvironment().get(0).getOperationalEnvironmentId());
262         assertEquals(1, list.getOperationalEnvironment().get(0).getRelationshipList().getRelationship().size());
263     }
264
265
266     @Test
267     public void testVoid(){
268         SimulatorApi.registerExpectation(SimulatorApi.RegistrationStrategy.CLEAR_THEN_SET,
269                 "add_subinterface/aai_get_tenants.json"
270                 , "add_subinterface/aai_get_services.json"
271         );
272     }
273
274
275     @Test(dataProvider = "errorCodes")
276     public void getServicesWitErrorResponse(int errorCode) throws IOException, URISyntaxException {
277         final String expectedResult = "{\"services\":[],\"readOnly\":false}";
278
279         callAaiWithSimulatedErrorResponse(AAI_GET_SERVICES_ERROR_SIMULATOR_RESPONSES,
280                 ImmutableMap.of("500", Integer.toString(errorCode), "ERROR_PAYLOAD", StringEscapeUtils.escapeJson(expectedResult)),
281                 getAaiServicesUri(), "", 200, expectedResult, HttpMethod.GET);
282
283     }
284
285     @Test
286     public void getServicesFineRequest() throws IOException, URISyntaxException {
287
288         callAaiWithSimulatedErrorResponse(AAI_GET_SERVICES_FINE_SIMULATOR_RESPONSES,
289                 ImmutableMap.of(),
290                 getAaiServicesUri(), "", 200, GET_AAI_SERVIES_EXPECTED_RESULT, HttpMethod.GET);
291
292     }
293
294     @DataProvider
295     public static Object[][] errorCodes(Method test) {
296         return new Object[][]{
297                 {500},{505}, {400}, {401}, {405}
298         };
299     }
300
301     @Test
302     public void whenThrowExceptionInsAaiResponseErrorAreLogged() {
303         String notAJson = "not a json";
304         SimulatorApi.registerExpectationFromPreset(new PresetAAIBadBodyForGetServicesGet(notAJson), CLEAR_THEN_SET);
305         SimulatorApi.registerExpectationFromPresets(getEcompPortalPresets(), APPEND);
306         SimulatorApi.registerExpectationFromPreset(new PresetAAIGetSubscribersGet(), APPEND);
307
308         restTemplateErrorAgnostic.getForEntity(uri + "/aai_get_services",String.class);
309         String logLines = LoggerFormatTest.getLogLines("error", 15, 0, restTemplate, uri);
310
311         assertThat("not found in error log", logLines, containsString("Failed to parse aai response"));
312         assertThat("not found in error log", logLines, containsString(notAJson));
313         assertThat("not found in error log", logLines, containsString("GetServicesAAIRespone"));
314
315     }
316
317     @Test
318     public void portMirroringConfigData_givenValidAaiResponse_yieldCloudRegionId() {
319         SimulatorApi.registerExpectationFromPreset(new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "THE-EXPECTED-REGION-ID"), CLEAR_THEN_SET);
320
321         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
322
323         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
324                 "SOME-RANDOM-UUID", ImmutableMap.of(
325                         "cloudRegionId", "THE-EXPECTED-REGION-ID"
326                 ));
327
328         assertResponse(expected, response);
329
330         /*
331         More tests:
332         [ ]  Error responses from AAI (404 etc): descriptive error response, including what tried and what happened
333         [ ]  malformed response from AAI: descriptive error response, including the payload
334         [ ]  empty/missing value for configurationId: client-error http code
335          */
336     }
337
338
339     @Test
340     public void portMirroringSourcePorts_validAAIResponseWithSinglePort_yieldCorrectPortData() {
341         SimulatorApi.registerExpectationFromPreset(
342                 new PresetAAIGetPortMirroringSourcePorts("CONFIGURATION-ID", "INTERFACE-ID", "INTERFACE-NAME", true),
343                 CLEAR_THEN_SET
344         );
345
346         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
347
348         final ImmutableMap<String, ImmutableList> expected = ImmutableMap.of(
349                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
350                         "interfaceId", "INTERFACE-ID", "interfaceName", "INTERFACE-NAME", "isPortMirrored", true
351                 )));
352
353         assertResponse(expected, response);
354     }
355
356     @Test
357     public void portMirroringSourcePorts_nullValueForInterfaceId_yield200OkWithFineDescription() {
358         final PresetAAIGetPortMirroringSourcePorts preset = new PresetAAIGetPortMirroringSourcePorts("CONFIGURATION-ID", null, "INTERFACE-NAME", true);
359         SimulatorApi.registerExpectationFromPreset(
360                 preset,
361                 CLEAR_THEN_SET
362         );
363
364         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
365
366         final ImmutableMap<String, ImmutableList<ImmutableMap>> expected = ImmutableMap.of(
367                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
368                         "errorDescription", "Value of 'interface-id' is missing.",
369                         "rawAaiResponse", preset.getResponseBody().toString()
370                 )));
371
372         assertResponse(expected, response);
373     }
374
375     @Test
376     public void portMirroringSourcePorts_given503ErrorAaiResponse_yield200OkWithErrorMsg() {
377         final PresetAAIGetPortMirroringSourcePortsError preset = new PresetAAIGetPortMirroringSourcePortsError("CONFIGURATION-ID", "INTERFACE-ID", "INTERFACE-NAME", true);
378         SimulatorApi.registerExpectationFromPreset(
379                 preset,
380                 CLEAR_THEN_SET
381         );
382
383         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringSourcePorts?configurationIds=" + "CONFIGURATION-ID", String.class);
384
385         final ImmutableMap<String, ImmutableList<ImmutableMap>> expected = ImmutableMap.of(
386                 "CONFIGURATION-ID", ImmutableList.of(ImmutableMap.of(
387                         "errorDescription", "Got 503 from aai",
388                         "rawAaiResponse", preset.getResponseBody()
389                 )));
390
391         assertResponse(expected, response);
392     }
393
394     @Test
395     public void portMirroringConfigData_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
396         SimulatorApi.clearAll();
397
398         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
399
400         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
401                 "SOME-RANDOM-UUID", ImmutableMap.of(
402                         "errorDescription", "Got 404 from aai",
403                         "rawAaiResponse", ""
404                 ));
405
406         assertResponse(expected, response);
407     }
408
409     @Test
410     public void getNetworkCollectionDetailsByServiceInstanceId_yieldValidResponse() {
411         SimulatorApi.clearAll();
412         final PresetAAIGetNetworkCollectionDetails presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetails("SOME-RANDOM-UUID");
413         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
414         final String response = restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
415
416         assertResponse(GET_NETWORK_COLLECTION_EXPECTED_RESPONSE, response);
417     }
418
419     @Test
420     public void getNetworkCollectionDetailsByServiceInstanceId_responseWithExtraFields_yieldValidResponse() {
421         SimulatorApi.clearAll();
422         final PresetAAIGetNetworkCollectionDetailsInvalidRequest presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetailsInvalidRequest("SOME-RANDOM-UUID");
423         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
424         final String response = restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
425
426         assertResponse(GET_NETWORK_COLLECTION_EXPECTED_RESPONSE, response);
427     }
428     @Test
429     public void getNetworkCollectionDetailsByServiceInstanceId_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
430         SimulatorApi.clearAll();
431         try {
432             restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
433         }catch (HttpClientErrorException e){
434             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
435         }
436     }
437
438     @Test
439     public void getNetworkCollectionDetailsByServiceInstanceId_responseWithRequiredMissing() {
440         SimulatorApi.clearAll();
441         final PresetAAIGetNetworkCollectionDetailsRequiredMissing presetAAIGetNetworkCollectionDetails = new PresetAAIGetNetworkCollectionDetailsRequiredMissing("SOME-RANDOM-UUID");
442         SimulatorApi.registerExpectationFromPreset(presetAAIGetNetworkCollectionDetails, CLEAR_THEN_SET);
443         try {
444             restTemplate.getForObject(uri + "/aai_get_network_collection_details/" + "SOME-RANDOM-UUID", String.class);
445         }catch (HttpServerErrorException e){
446             assertEquals(HttpStatus.INTERNAL_SERVER_ERROR, e.getStatusCode());
447         }
448     }
449
450     @Test
451     public void getGetInstanceGroupsByCloudRegion_yieldValidResponse() {
452         SimulatorApi.clearAll();
453         final PresetAAIGetInstanceGroupsByCloudRegion presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegion("CLOUD-OWNER", "CLOUD-REGION-ID", "NETWORK-FUNCTION");
454         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
455         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" +"NETWORK-FUNCTION", String.class);
456
457         assertResponse(GET_INSTANCE_GROUPS_BY_CLOUDREGION_EXPECTED_RESPONSE, response);
458     }
459
460     @Test
461     public void getGetInstanceGroupsByCloudRegion_responseWithExtraFields_yieldValidResponse() {
462         SimulatorApi.clearAll();
463         final PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegionInvalidRequest("CLOUD-OWNER", "CLOUD-REGION-ID", "NETWORK-FUNCTION");
464         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
465         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" +"NETWORK-FUNCTION", String.class);
466
467         assertResponse(GET_INSTANCE_GROUPS_BY_CLOUDREGION_EXPECTED_RESPONSE, response);
468     }
469     @Test
470     public void getGetInstanceGroupsByCloudRegion_given404ErrorAaiResponse_yield200OkWithErrorMsg() {
471         SimulatorApi.clearAll();
472         try {
473             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" +"NETWORK-FUNCTION", String.class);
474         }catch (HttpClientErrorException e){
475             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
476         }
477     }
478
479     @Test
480     public void getGetInstanceGroupsByCloudRegion_responseWithRequiredMissing() {
481         SimulatorApi.clearAll();
482         final PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing presetAAIGetInstanceGroupsByCloudRegion = new PresetAAIGetInstanceGroupsByCloudRegionRequiredMissing("CLOUD-OWNER", "CLOUD-REGION-ID", "NETWORK-FUNCTION");
483         SimulatorApi.registerExpectationFromPreset(presetAAIGetInstanceGroupsByCloudRegion, CLEAR_THEN_SET);
484         try {
485             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_cloudregion/" + "CLOUD-OWNER" + "/" + "CLOUD-REGION-ID" + "/" +"NETWORK-FUNCTION", String.class);
486         }catch (HttpServerErrorException e){
487             assertEquals(HttpStatus.INTERNAL_SERVER_ERROR, e.getStatusCode());
488         }
489     }
490
491     @Test
492     public void portMirroringConfigData_emptyIdOnAaiResponse_yieldError() {
493         final PresetAAICloudRegionAndSourceFromConfigurationPut presetAAIResponseWitnProblem = new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "");
494         SimulatorApi.registerExpectationFromPreset(presetAAIResponseWitnProblem, CLEAR_THEN_SET);
495
496         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID", String.class);
497
498         final ImmutableMap<String, ImmutableMap<String, String>> expected = ImmutableMap.of(
499                 "SOME-RANDOM-UUID", ImmutableMap.of(
500                         "errorDescription", "Node 'properties.cloud-region-id' of node-type 'cloud-region' is blank",
501                         "rawAaiResponse", presetAAIResponseWitnProblem.getResponseBody().toString().replace(" ", "")
502                 ));
503
504         assertResponse(expected, response);
505     }
506
507     @Test
508     public void getGetRelatedInstanceGroupsByVnfId__yieldValidResponse() {
509         String vnfId = "some_vnf_id";
510         final PresetAAIGetRelatedInstanceGroupsByVnfId getRelatedInstanceGroupsByVnfId = new PresetAAIGetRelatedInstanceGroupsByVnfId(vnfId);
511         SimulatorApi.registerExpectationFromPreset(getRelatedInstanceGroupsByVnfId, CLEAR_THEN_SET);
512
513         final String response = restTemplate.getForObject(uri + "/aai_get_instance_groups_by_vnf_instance_id/" + vnfId, String.class);
514
515         assertResponse("[{\"type\":\"instance-group\",\"name\":\"instance group name\"},{\"type\":\"instance-group\",\"name\":\"instance group name\"}]", response);
516     }
517
518     @Test
519     public void getGetRelatedInstanceGroupsByVnfId__yield404NotFound() {
520         final PresetAAIGetRelatedInstanceGroupsByVnfId getRelatedInstanceGroupsByVnfId = new PresetAAIGetRelatedInstanceGroupsByVnfId("abcd");
521         SimulatorApi.registerExpectationFromPreset(getRelatedInstanceGroupsByVnfId, CLEAR_THEN_SET);
522         try {
523             restTemplate.getForObject(uri + "/aai_get_instance_groups_by_vnf_instance_id/" + "dcba", String.class);
524         } catch (HttpClientErrorException e){
525             assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());
526         }
527
528     }
529
530     @Test
531     public void portMirroringConfigData_twoResponsesOneValidAndOneInvalid_yieldBothErrorAndOk() {
532         final PresetAAICloudRegionAndSourceFromConfigurationPut presetAAIResponseWitnProblem = new PresetAAICloudRegionAndSourceFromConfigurationPut("ANOTHER-RANDOM-UUID", "");
533         SimulatorApi.registerExpectationFromPreset(presetAAIResponseWitnProblem, CLEAR_THEN_SET);
534         SimulatorApi.registerExpectationFromPreset(new PresetAAICloudRegionAndSourceFromConfigurationPut("SOME-RANDOM-UUID", "THE-EXPECTED-REGION-ID"), APPEND);
535
536         final String response = restTemplate.getForObject(uri + "/aai_getPortMirroringConfigsData?configurationIds=" + "SOME-RANDOM-UUID,ANOTHER-RANDOM-UUID", String.class);
537
538         final ImmutableMap<String, ImmutableMap<String, Object>> expected = ImmutableMap.of(
539                 "SOME-RANDOM-UUID", ImmutableMap.of(
540                         "cloudRegionId", "THE-EXPECTED-REGION-ID"
541                 ),
542                 "ANOTHER-RANDOM-UUID", ImmutableMap.of(
543                         "errorDescription", "Node 'properties.cloud-region-id' of node-type 'cloud-region' is blank",
544                         "rawAaiResponse", presetAAIResponseWitnProblem.getResponseBody().toString().replace(" ", "")
545                 ));
546
547         assertResponse(expected, response);
548     }
549
550     private void assertResponse(Object expected, String response) {
551         try {
552             JsonAssert.assertJsonEquals(expected, response);
553         } catch (Exception | AssertionError e) {
554             System.err.println("response was: " + response);
555             throw e;
556         }
557     }
558 }