2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2021 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.models.pap.persistence.concepts;
23 import static org.assertj.core.api.Assertions.assertThat;
24 import static org.assertj.core.api.Assertions.assertThatNoException;
25 import static org.junit.Assert.assertEquals;
26 import static org.junit.Assert.assertFalse;
27 import static org.junit.Assert.assertNotEquals;
28 import static org.junit.Assert.assertTrue;
30 import java.time.Instant;
31 import java.time.temporal.ChronoUnit;
32 import org.junit.Before;
33 import org.junit.Test;
34 import org.onap.policy.common.parameters.BeanValidationResult;
35 import org.onap.policy.models.pap.concepts.PolicyAudit;
36 import org.onap.policy.models.pap.concepts.PolicyAudit.AuditAction;
37 import org.onap.policy.models.pdp.concepts.PdpPolicyStatus;
38 import org.onap.policy.models.pdp.concepts.PdpPolicyStatus.State;
39 import org.onap.policy.models.pdp.persistence.concepts.JpaPdpPolicyStatus;
40 import org.onap.policy.models.tosca.authorative.concepts.ToscaConceptIdentifier;
42 public class JpaPolicyAuditTest {
44 private static final ToscaConceptIdentifier MY_POLICY = new ToscaConceptIdentifier("MyPolicy", "1.2.3");
45 private static final String PDP_GROUP = "pdpGroupxyz";
46 private static final String USER = "user";
51 * Setup an audit for usage on unit tests.
55 audit = PolicyAudit.builder().auditId(1L).pdpGroup(PDP_GROUP).pdpType("pdpType").policy(MY_POLICY)
56 .action(AuditAction.DEPLOYMENT).timestamp(Instant.now().truncatedTo(ChronoUnit.SECONDS)).build();
60 public void testCompareTo() {
61 JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
62 assertEquals(-1, jpaAudit.compareTo(null));
63 assertEquals(0, jpaAudit.compareTo(jpaAudit));
64 assertEquals(0, jpaAudit.compareTo(new JpaPolicyAudit(jpaAudit)));
66 PdpPolicyStatus idw = PdpPolicyStatus.builder().deploy(true).state(State.SUCCESS).pdpGroup(PDP_GROUP)
67 .pdpId("wId").policy(MY_POLICY).policyType(MY_POLICY).build();
68 JpaPdpPolicyStatus jpaStatus = new JpaPdpPolicyStatus(idw);
69 assertNotEquals(0, jpaAudit.compareTo(jpaStatus));
73 public void testKeys() {
74 JpaPolicyAudit jpaAudit = new JpaPolicyAudit();
75 assertThat(jpaAudit.getKeys()).isNotNull();
76 assertTrue(jpaAudit.getKey().isNullKey());
78 jpaAudit = new JpaPolicyAudit(audit);
79 assertFalse(jpaAudit.getKey().isNullKey());
83 public void testClean() {
84 audit.setUser(" user");
85 JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
86 assertThatNoException().isThrownBy(() -> jpaAudit.clean());
87 assertEquals(USER, jpaAudit.getUserName());
91 public void testToAuthorative() {
93 JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
94 PolicyAudit convertedAudit = jpaAudit.toAuthorative();
96 assertEquals(audit, convertedAudit);
97 assertEquals(USER, convertedAudit.getUser());
99 JpaPolicyAudit jpaAuditWithNullKey = new JpaPolicyAudit();
100 PolicyAudit convertedAudit2 = jpaAuditWithNullKey.toAuthorative();
101 assertTrue(convertedAudit2.getPolicy().asConceptKey().isNullKey());
106 public void testConversionsWithRequiredOnly() {
107 audit = PolicyAudit.builder().policy(MY_POLICY).action(AuditAction.DEPLOYMENT)
108 .timestamp(Instant.now().truncatedTo(ChronoUnit.SECONDS)).build();
110 JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
111 PolicyAudit convertedAudit = jpaAudit.toAuthorative();
113 assertEquals(audit, convertedAudit);
114 assertTrue(jpaAudit.validate("jpaAudit").isValid());
118 public void testValidation() {
119 PolicyAudit invalidAudit = PolicyAudit.builder().pdpGroup(PDP_GROUP).user(USER).build();
121 JpaPolicyAudit jpaAudit = new JpaPolicyAudit(invalidAudit);
123 BeanValidationResult result = jpaAudit.validate("jpaAudit");
124 assertFalse(result.isValid());