2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2019, 2022-2023 Nordix Foundation.
4 * ================================================================================
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 * SPDX-License-Identifier: Apache-2.0
18 * ============LICENSE_END=========================================================
21 package org.onap.policy.pap.main.rest;
23 import static org.junit.jupiter.api.Assertions.assertEquals;
24 import static org.junit.jupiter.api.Assertions.assertNotNull;
26 import jakarta.ws.rs.client.Entity;
27 import jakarta.ws.rs.client.Invocation;
28 import jakarta.ws.rs.core.MediaType;
29 import jakarta.ws.rs.core.Response;
30 import java.util.List;
31 import org.junit.jupiter.api.Test;
32 import org.onap.policy.models.pap.concepts.PdpGroupUpdateResponse;
33 import org.onap.policy.models.pdp.concepts.PdpGroup;
34 import org.onap.policy.models.pdp.concepts.PdpGroups;
35 import org.onap.policy.models.pdp.concepts.PdpSubGroup;
36 import org.springframework.test.context.ActiveProfiles;
39 * Note: this tests failure cases; success cases are tested by tests in the "e2e" package.
41 @ActiveProfiles({ "test", "default" })
42 class TestPdpGroupCreateOrUpdateControllerV1 extends CommonPapRestServer {
44 private static final String CREATEORUPDATE_GROUPS_ENDPOINT = "pdps/groups/batch";
47 void testSwagger() throws Exception {
48 super.testSwagger(CREATEORUPDATE_GROUPS_ENDPOINT);
52 void testCreateOrUpdateGroups() throws Exception {
53 Entity<PdpGroups> entgrp = makePdpGroupsEntity();
55 Invocation.Builder invocationBuilder = sendRequest(CREATEORUPDATE_GROUPS_ENDPOINT);
56 Response rawresp = invocationBuilder.post(entgrp);
57 PdpGroupUpdateResponse resp = rawresp.readEntity(PdpGroupUpdateResponse.class);
58 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), rawresp.getStatus());
59 assertNotNull(resp.getErrorDetails());
61 rawresp = invocationBuilder.post(entgrp);
62 resp = rawresp.readEntity(PdpGroupUpdateResponse.class);
63 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), rawresp.getStatus());
64 assertNotNull(resp.getErrorDetails());
66 // verify it fails when no authorization info is included
67 checkUnauthRequest(CREATEORUPDATE_GROUPS_ENDPOINT, req -> req.post(entgrp));
70 private Entity<PdpGroups> makePdpGroupsEntity() {
71 PdpSubGroup subgrp = new PdpSubGroup();
72 subgrp.setPdpType("drools");
74 PdpGroup group = new PdpGroup();
75 group.setName("drools-group");
76 group.setDescription("my description");
77 group.setPdpSubgroups(List.of(subgrp));
78 PdpGroups groups = new PdpGroups();
79 groups.setGroups(List.of(group));
80 return Entity.entity(groups, MediaType.APPLICATION_JSON);