Merge "Removing so-monitoring module"
[so.git] / so-etsi-nfvo / so-etsi-nfvo-ns-lcm / so-etsi-nfvo-ns-lcm-database-service / src / test / java / org / onap / so / etsi / nfvo / ns / lcm / database / DatabaseServiceProviderTest.java
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2020 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 package org.onap.so.etsi.nfvo.ns.lcm.database;
21
22 import static org.junit.Assert.assertEquals;
23 import static org.junit.Assert.assertFalse;
24 import static org.junit.Assert.assertTrue;
25 import java.time.LocalDateTime;
26 import java.time.temporal.ChronoUnit;
27 import java.util.List;
28 import java.util.Optional;
29 import java.util.UUID;
30 import org.junit.Test;
31 import org.junit.runner.RunWith;
32 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.JobAction;
33 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.JobStatusEnum;
34 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NfvoJob;
35 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NfvoJobStatus;
36 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NfvoNfInst;
37 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NfvoNsInst;
38 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NsLcmOpOcc;
39 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NsLcmOpType;
40 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.OperationStateEnum;
41 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.State;
42 import org.onap.so.etsi.nfvo.ns.lcm.database.service.DatabaseServiceProvider;
43 import org.springframework.beans.factory.annotation.Autowired;
44 import org.springframework.boot.test.context.SpringBootTest;
45 import org.springframework.test.context.ActiveProfiles;
46 import org.springframework.test.context.junit4.SpringRunner;
47
48 /**
49  * @author Waqas Ikram (waqas.ikram@est.tech)
50  *
51  */
52 @RunWith(SpringRunner.class)
53 @SpringBootTest(classes = TestApplication.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
54 @ActiveProfiles("test")
55 public class DatabaseServiceProviderTest {
56
57     private static final String RANDOM_ID = UUID.randomUUID().toString();
58     private static final String DUMMY_NAME = "NAME";
59     private static final LocalDateTime CURRENT_DATE_TIME = LocalDateTime.now().truncatedTo(ChronoUnit.MILLIS);
60     @Autowired
61     private DatabaseServiceProvider databaseServiceProvider;
62
63     @Test
64     public void testAddJob_StoredInDatabase() {
65         final NfvoJob expected = new NfvoJob().jobType("TYPE").jobAction(JobAction.CREATE).resourceId(RANDOM_ID)
66                 .resourceName(DUMMY_NAME).startTime(CURRENT_DATE_TIME).status(JobStatusEnum.STARTED);
67         databaseServiceProvider.addJob(expected);
68
69         Optional<NfvoJob> actual = databaseServiceProvider.getJob(expected.getJobId());
70         assertEquals(expected, actual.get());
71
72         actual = databaseServiceProvider.getRefreshedJob(expected.getJobId());
73         assertEquals(expected, actual.get());
74
75     }
76
77     @Test
78     public void testAddJobWithJobStatus_StoredInDatabase() {
79         final NfvoJob job = new NfvoJob().jobType("TYPE").jobAction(JobAction.CREATE).resourceId(RANDOM_ID)
80                 .resourceName(DUMMY_NAME).startTime(CURRENT_DATE_TIME).status(JobStatusEnum.STARTED);
81         databaseServiceProvider.addJob(job);
82
83         final NfvoJobStatus jobStatus = new NfvoJobStatus().status(JobStatusEnum.STARTED)
84                 .description("Create NS workflow process started").updatedTime(CURRENT_DATE_TIME);
85         databaseServiceProvider.addJob(job.nfvoJobStatus(jobStatus));
86
87         final Optional<NfvoJob> actual = databaseServiceProvider.getJob(job.getJobId());
88         final NfvoJob actualNfvoJob = actual.get();
89
90         assertEquals(job.getJobId(), actualNfvoJob.getJobId());
91         assertFalse(actualNfvoJob.getNfvoJobStatuses().isEmpty());
92         assertEquals(job.getJobId(), actualNfvoJob.getNfvoJobStatuses().get(0).getNfvoJob().getJobId());
93
94     }
95
96     @Test
97     public void testAddNsInst_StoredInDatabase_ableTofindByQuery() {
98
99         final NfvoNsInst nsInst = new NfvoNsInst().name(DUMMY_NAME).nsdId(RANDOM_ID).status(State.NOT_INSTANTIATED)
100                 .nsdInvariantId(RANDOM_ID).statusUpdatedTime(CURRENT_DATE_TIME);
101
102         databaseServiceProvider.saveNfvoNsInst(nsInst);
103
104         Optional<NfvoNsInst> actual = databaseServiceProvider.getNfvoNsInst(nsInst.getNsInstId());
105         NfvoNsInst actualNfvoNsInst = actual.get();
106         assertEquals(nsInst.getNsInstId(), actualNfvoNsInst.getNsInstId());
107         assertEquals(RANDOM_ID, actualNfvoNsInst.getNsdId());
108         assertEquals(State.NOT_INSTANTIATED, actualNfvoNsInst.getStatus());
109         assertEquals(RANDOM_ID, actualNfvoNsInst.getNsdInvariantId());
110         assertEquals(CURRENT_DATE_TIME, actualNfvoNsInst.getStatusUpdatedTime());
111
112         actual = databaseServiceProvider.getNfvoNsInstByName(DUMMY_NAME);
113         actualNfvoNsInst = actual.get();
114
115         assertEquals(nsInst.getNsInstId(), actualNfvoNsInst.getNsInstId());
116         assertEquals(RANDOM_ID, actualNfvoNsInst.getNsdId());
117         assertEquals(State.NOT_INSTANTIATED, actualNfvoNsInst.getStatus());
118         assertEquals(RANDOM_ID, actualNfvoNsInst.getNsdInvariantId());
119         assertEquals(CURRENT_DATE_TIME, actualNfvoNsInst.getStatusUpdatedTime());
120
121
122         assertTrue(databaseServiceProvider.isNsInstExists(DUMMY_NAME));
123     }
124
125     @Test
126     public void testAddNfInst_StoredInDatabase_ableTofindByQuery() {
127
128         final NfvoNsInst nsInst = new NfvoNsInst().name(DUMMY_NAME).nsdId(RANDOM_ID).status(State.NOT_INSTANTIATED)
129                 .nsdInvariantId(RANDOM_ID).statusUpdatedTime(CURRENT_DATE_TIME);
130
131         databaseServiceProvider.saveNfvoNsInst(nsInst);
132
133         final NfvoNfInst nfInst = new NfvoNfInst().nfvoNsInst(nsInst).name(DUMMY_NAME).vnfdId(RANDOM_ID)
134                 .status(State.NOT_INSTANTIATED).createTime(CURRENT_DATE_TIME).lastUpdateTime(CURRENT_DATE_TIME);
135         databaseServiceProvider.saveNfvoNfInst(nfInst);
136
137         final Optional<NfvoNfInst> actual = databaseServiceProvider.getNfvoNfInst(nfInst.getNfInstId());
138         final NfvoNfInst actualNfvoNfInst = actual.get();
139         assertEquals(nsInst.getNsInstId(), actualNfvoNfInst.getNsInst().getNsInstId());
140         assertEquals(nfInst.getNfInstId(), actualNfvoNfInst.getNfInstId());
141         assertEquals(nfInst.getName(), actualNfvoNfInst.getName());
142         assertEquals(nfInst.getVnfdId(), actualNfvoNfInst.getVnfdId());
143         assertEquals(nfInst.getStatus(), actualNfvoNfInst.getStatus());
144         assertEquals(nfInst.getCreateTime(), actualNfvoNfInst.getCreateTime());
145         assertEquals(nfInst.getLastUpdateTime(), actualNfvoNfInst.getLastUpdateTime());
146
147
148         List<NfvoNfInst> nfvoNfInstList = databaseServiceProvider.getNfvoNfInstByNsInstId(nsInst.getNsInstId());
149         assertFalse(nfvoNfInstList.isEmpty());
150         assertEquals(nsInst.getNsInstId(), nfvoNfInstList.get(0).getNsInst().getNsInstId());
151
152         nfvoNfInstList = databaseServiceProvider.getNfvoNfInstByNsInstIdAndNfName(nsInst.getNsInstId(), DUMMY_NAME);
153
154         assertFalse(nfvoNfInstList.isEmpty());
155         assertEquals(nsInst.getNsInstId(), nfvoNfInstList.get(0).getNsInst().getNsInstId());
156         assertEquals(DUMMY_NAME, nfvoNfInstList.get(0).getName());
157     }
158
159     @Test
160     public void testAddNsLcmOpOcc_StoredInDatabase_ableTofindByQuery() {
161
162         final NfvoNsInst nsInst = new NfvoNsInst().name(DUMMY_NAME).nsdId(RANDOM_ID).status(State.NOT_INSTANTIATED)
163                 .nsdInvariantId(RANDOM_ID).statusUpdatedTime(CURRENT_DATE_TIME);
164
165         databaseServiceProvider.saveNfvoNsInst(nsInst);
166
167         final NsLcmOpOcc nsLcmOpOcc = new NsLcmOpOcc().nfvoNsInst(nsInst).operationState(OperationStateEnum.PROCESSING)
168                 .isCancelPending(false).isAutoInvocation(false).operation(NsLcmOpType.INSTANTIATE)
169                 .startTime(CURRENT_DATE_TIME).stateEnteredTime(CURRENT_DATE_TIME).operationParams("");
170
171
172         databaseServiceProvider.addNSLcmOpOcc(nsLcmOpOcc);
173
174         final Optional<NsLcmOpOcc> actual = databaseServiceProvider.getNsLcmOpOcc(nsLcmOpOcc.getId());
175         final NsLcmOpOcc actualLcmOpOcc = actual.get();
176         assertEquals(nsLcmOpOcc.getId(), actualLcmOpOcc.getId());
177
178         assertEquals(nsInst.getNsInstId(), actualLcmOpOcc.getNfvoNsInst().getNsInstId());
179
180     }
181 }