import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNull;
import static org.junit.jupiter.api.Assertions.assertTrue;
-import static org.mockito.ArgumentMatchers.contains;
import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import reactor.core.publisher.Mono;
class PolicyAgentApiImplTest {
- private static final String URL_POLICY_SCHEMAS = "/v2/policy-types";
+ private static final String URL_POLICY_SCHEMAS = "/a1-policy/v2/policy-types";
private static final String POLICY_TYPE_1_ID = "type1";
private static final String POLICY_TYPE_1_VALID = "{\"title\":\"type1\"}";
private static final String POLICY_TYPE_1_INVALID = "\"title\":\"type1\"}";
private static final String RIC_1_INFO_INVALID = "{\"ric_id\":\"ric1\",\"policytype_ids\":\"type1\"]}";
private static final String CLIENT_ERROR_MESSAGE = "XXXXXXX";
private static final String SERVICE_ID = "controlpanel";
-
+ private static final String TIMESTAMP = "2021-01-12T09:59:33.392470Z";
+ private static final String STATUS =
+ "{\"last_modified\": \"" + TIMESTAMP + "\",\"status\":{\"enforceStatus\": \"\",\"enforceReason\": \"\"}}";
private static com.google.gson.Gson gson = new GsonBuilder() //
.serializeNulls() //
.create(); //
}
private String urlPolicyInstances(String type) {
- return "/v2/policies?policytype_id=" + type;
+ return "/a1-policy/v2/policies?policytype_id=" + type;
}
@Test
whenGetReturnOK(urlPolicyInstances(POLICY_TYPE_1_ID), HttpStatus.OK, policyInstances);
whenGetReturnOK(urlPolicyInstance(POLICY_1_ID), HttpStatus.OK, POLICY_1_VALID);
+ whenGetReturnOK(urlPolicyStatus(POLICY_1_ID), HttpStatus.OK, STATUS);
ResponseEntity<String> returnedResp = apiUnderTest.getPolicyInstancesForType(POLICY_TYPE_1_ID);
assertEquals(returnedResp.getBody(), policyInstancesJson);
}
private String urlPolicyInstance(String id) {
- return "/v2/policies/" + id;
+ return "/a1-policy/v2/policies/" + id;
+ }
+
+ private String urlPolicyStatus(String id) {
+ return "/a1-policy/v2/policies/" + id + "/status";
}
@Test
void testGetPolicyInstance() {
whenGetReturnOK(urlPolicyInstance(POLICY_1_ID), HttpStatus.OK, POLICY_1_VALID);
+ whenGetReturnOK(urlPolicyStatus(POLICY_1_ID), HttpStatus.OK, STATUS);
ResponseEntity<Object> returnedResp = apiUnderTest.getPolicyInstance(POLICY_1_ID);
}
private String urlPutPolicy() {
- return "/v2/policies/";
+ return "/a1-policy/v2/policies/";
}
private void whenPutReturnOK(String url, String putBody, HttpStatus status, String body) {
ResponseEntity<String> ret = new ResponseEntity<>(body, status);
- when(restClient.putForEntity(eq(url), contains(SERVICE_ID))).thenReturn(Mono.just(ret));
+ when(restClient.putForEntity(eq(url), eq(putBody))).thenReturn(Mono.just(ret));
}
private void whenPutReturnFailure(String url, String putBody, HttpStatus status, String body) {
HttpServerErrorException e =
new HttpServerErrorException(status, body, body.getBytes(StandardCharsets.UTF_8), StandardCharsets.UTF_8);
- when(restClient.putForEntity(eq(url), contains(SERVICE_ID))).thenReturn(Mono.error(e));
+ when(restClient.putForEntity(eq(url), eq(putBody))).thenReturn(Mono.error(e));
}
@Test
void testPutPolicyFailure() {
String url = urlPutPolicy();
-
+ JsonElement data = JsonParser.parseString(POLICY_DATA).getAsJsonObject();
PolicyInstance i = PolicyInstance.builder() //
.policyId(POLICY_1_ID) //
.policyTypeId(POLICY_TYPE_1_ID) //
.ricId(RIC_1_ID) //
- .policyData(POLICY_DATA) //
+ .policyData(data) //
.serviceId(SERVICE_ID) //
.build(); //
- String jsonStr = gson.toJson(i, PolicyInstance.class);
+ String jsonStr = gson.toJson(i);
whenPutReturnFailure(url, jsonStr, HttpStatus.NOT_FOUND, CLIENT_ERROR_MESSAGE);
ResponseEntity<String> returnedResp =
@Test
void testPutPolicySuccess() {
String url = urlPutPolicy();
+ JsonElement data = JsonParser.parseString(POLICY_DATA).getAsJsonObject();
PolicyInstance i = PolicyInstance.builder() //
.policyId(POLICY_1_ID) //
.policyTypeId(POLICY_TYPE_1_ID) //
.ricId(RIC_1_ID) //
- .policyData(POLICY_DATA) //
+ .policyData(data) //
.serviceId(SERVICE_ID) //
.build(); //
- String jsonStr = gson.toJson(i, PolicyInstance.class);
-
+ String jsonStr = gson.toJson(i);
whenPutReturnOK(url, jsonStr, HttpStatus.OK, POLICY_1_VALID);
ResponseEntity<String> returnedResp =
}
private String deletePolicyUrl(String id) {
- return "/v2/policies/" + id;
+ return "/a1-policy/v2/policies/" + id;
}
@Test
}
private String urlRicInfo(String typeName) {
- return "/v2/rics?policytype_id=" + typeName;
+ return "/a1-policy/v2/rics?policytype_id=" + typeName;
}
@Test
.ricId(RIC_1_ID) //
.policyData(data) //
.serviceId(SERVICE_ID) //
+ .lastModified(TIMESTAMP) //
.build(); //
res.add(i);
}