2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2019 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.Assert.assertEquals;
24 import static org.junit.Assert.assertNotNull;
26 import java.util.Arrays;
27 import javax.ws.rs.client.Entity;
28 import javax.ws.rs.client.Invocation;
29 import javax.ws.rs.core.MediaType;
30 import javax.ws.rs.core.Response;
31 import org.junit.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;
38 * Note: this tests failure cases; success cases are tested by tests in the "e2e" package.
40 public class TestPdpGroupCreateOrUpdateControllerV1 extends CommonPapRestServer {
42 private static final String CREATEORUPDATE_GROUPS_ENDPOINT = "pdps/groups/batch";
45 public void testSwagger() throws Exception {
46 super.testSwagger(CREATEORUPDATE_GROUPS_ENDPOINT);
50 public void testCreateOrUpdateGroups() throws Exception {
51 Entity<PdpGroups> entgrp = makePdpGroupsEntity();
53 Invocation.Builder invocationBuilder = sendRequest(CREATEORUPDATE_GROUPS_ENDPOINT);
54 Response rawresp = invocationBuilder.post(entgrp);
55 PdpGroupUpdateResponse resp = rawresp.readEntity(PdpGroupUpdateResponse.class);
56 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), rawresp.getStatus());
57 assertNotNull(resp.getErrorDetails());
59 rawresp = invocationBuilder.post(entgrp);
60 resp = rawresp.readEntity(PdpGroupUpdateResponse.class);
61 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), rawresp.getStatus());
62 assertNotNull(resp.getErrorDetails());
64 // verify it fails when no authorization info is included
65 checkUnauthRequest(CREATEORUPDATE_GROUPS_ENDPOINT, req -> req.post(entgrp));
68 private Entity<PdpGroups> makePdpGroupsEntity() {
69 PdpSubGroup subgrp = new PdpSubGroup();
70 subgrp.setPdpType("drools");
72 PdpGroup group = new PdpGroup();
73 group.setName("drools-group");
74 group.setDescription("my description");
75 group.setPdpSubgroups(Arrays.asList(subgrp));
76 PdpGroups groups = new PdpGroups();
77 groups.setGroups(Arrays.asList(group));
78 return Entity.entity(groups, MediaType.APPLICATION_JSON);