Upgrade the H2 database to the latest version
[policy/models.git] / models-pap / src / test / java / org / onap / policy / models / pap / persistence / concepts / JpaPolicyAuditTest.java
1 /*-
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
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
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.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.policy.models.pap.persistence.concepts;
22
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;
29
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;
41
42 public class JpaPolicyAuditTest {
43
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";
47
48     PolicyAudit audit;
49
50     /**
51      * Setup an audit for usage on unit tests.
52      */
53     @Before
54     public void setup() {
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();
57     }
58
59     @Test
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)));
65
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));
70     }
71
72     @Test
73     public void testKeys() {
74         JpaPolicyAudit jpaAudit = new JpaPolicyAudit();
75         assertThat(jpaAudit.getKeys()).isNotNull();
76         assertTrue(jpaAudit.getKey().isNullKey());
77
78         jpaAudit = new JpaPolicyAudit(audit);
79         assertFalse(jpaAudit.getKey().isNullKey());
80     }
81
82     @Test
83     public void testClean() {
84         audit.setUser("   user");
85         JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
86         assertThatNoException().isThrownBy(() -> jpaAudit.clean());
87         assertEquals(USER, jpaAudit.getUserName());
88     }
89
90     @Test
91     public void testToAuthorative() {
92         audit.setUser(USER);
93         JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
94         PolicyAudit convertedAudit = jpaAudit.toAuthorative();
95
96         assertEquals(audit, convertedAudit);
97         assertEquals(USER, convertedAudit.getUser());
98
99         JpaPolicyAudit jpaAuditWithNullKey = new JpaPolicyAudit();
100         PolicyAudit convertedAudit2 = jpaAuditWithNullKey.toAuthorative();
101         assertTrue(convertedAudit2.getPolicy().asConceptKey().isNullKey());
102
103     }
104
105     @Test
106     public void testConversionsWithRequiredOnly() {
107         audit = PolicyAudit.builder().policy(MY_POLICY).action(AuditAction.DEPLOYMENT)
108                 .timestamp(Instant.now().truncatedTo(ChronoUnit.SECONDS)).build();
109
110         JpaPolicyAudit jpaAudit = new JpaPolicyAudit(audit);
111         PolicyAudit convertedAudit = jpaAudit.toAuthorative();
112
113         assertEquals(audit, convertedAudit);
114         assertTrue(jpaAudit.validate("jpaAudit").isValid());
115     }
116
117     @Test
118     public void testValidation() {
119         PolicyAudit invalidAudit = PolicyAudit.builder().pdpGroup(PDP_GROUP).user(USER).build();
120
121         JpaPolicyAudit jpaAudit = new JpaPolicyAudit(invalidAudit);
122
123         BeanValidationResult result = jpaAudit.validate("jpaAudit");
124         assertFalse(result.isValid());
125     }
126 }