88b1a661b9c086c0555605c7466f6f5924e945cc
[sdc.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2019 Nordix Foundation
4  *  Copyright (C) 2021 Nokia. All rights reserved.
5  *  ================================================================================
6  *  Licensed under the Apache License, Version 2.0 (the "License");
7  *  you may not use this file except in compliance with the License.
8  *  You may obtain a copy of the License at
9  *
10  *        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.
16  *
17  *  SPDX-License-Identifier: Apache-2.0
18  *  ============LICENSE_END=========================================================
19  */
20
21 package org.onap.sdc.backend.ci.tests.data.providers;
22
23 import static org.testng.Assert.fail;
24
25 import java.util.ArrayList;
26 import java.util.Arrays;
27 import java.util.Collections;
28 import java.util.List;
29 import java.util.Optional;
30 import org.apache.commons.collections4.CollectionUtils;
31 import org.onap.sdc.backend.ci.tests.datatypes.enums.XnfTypeEnum;
32 import org.onap.sdc.backend.ci.tests.utils.general.FileHandling;
33 import org.onap.sdc.backend.ci.tests.utils.general.OnboardingUtils;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
36 import org.testng.annotations.DataProvider;
37
38 public final class OnboardingDataProviders {
39
40     private static final Logger LOGGER = LoggerFactory.getLogger(OnboardingDataProviders.class);
41     private static final String VNF_FILE_PATH = FileHandling.getXnfRepositoryPath(XnfTypeEnum.VNF);
42
43     private OnboardingDataProviders() {
44
45     }
46
47     @DataProvider(name = "randomVNF_List")
48     private static Object[][] randomVnfList() {
49         final int randomElementNumber = 3; //how many VNFs to onboard randomly
50         final List<String> fileNamesFromFolder = OnboardingUtils.getVnfNamesFileListExcludeToscaParserFailure();
51         final List<String> newRandomFileNamesFromFolder = getRandomElements(randomElementNumber, fileNamesFromFolder);
52         if (CollectionUtils.isEmpty(newRandomFileNamesFromFolder)) {
53             fail("Required number of VNF files not exists under " + VNF_FILE_PATH);
54             return new Object[0][];
55         }
56         LOGGER.debug(String.format("There are %s zip file(s) to test", newRandomFileNamesFromFolder.size()));
57         return provideData(newRandomFileNamesFromFolder, VNF_FILE_PATH);
58     }
59
60     @DataProvider(name = "VNF_List", parallel = true)
61     private static Object[][] vnfList() {
62         final List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.VNF);
63         LOGGER.debug(String.format("There are %s package file(s) to test", fileNamesFromFolder.size()));
64         return provideData(fileNamesFromFolder, VNF_FILE_PATH);
65     }
66
67     @DataProvider(name = "PNF_List", parallel = true)
68     private static Object[][] pnfList() {
69         return provideData(OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.PNF),
70             FileHandling.getXnfRepositoryPath(XnfTypeEnum.PNF));
71     }
72
73     @DataProvider(name = "CNF_List", parallel = true)
74     private static Object[][] cnfList() {
75         final List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.CNF);
76         LOGGER.debug(String.format("There are %s package file(s) to test", fileNamesFromFolder.size()));
77         return provideData(fileNamesFromFolder, FileHandling.getXnfRepositoryPath(XnfTypeEnum.CNF));
78     }
79
80     @DataProvider(name = "Invalid_CNF_List", parallel = true)
81     private static Object[][] invalidCnfList() {
82         final List<String> fileNamesFromFolder = OnboardingUtils.getInvalidXnfNamesFileList(XnfTypeEnum.CNF);
83         LOGGER.debug(String.format("There are %s package file(s) to test", fileNamesFromFolder.size()));
84         return provideData(fileNamesFromFolder, FileHandling.getXnfRepositoryPath(XnfTypeEnum.CNF));
85     }
86
87     @DataProvider(name = "Single_VNF", parallel = true)
88     private static Object[][] singleVNF() {
89         final List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.VNF);
90         final List<String> newList = new ArrayList<>();
91         newList.add(fileNamesFromFolder.get(0));
92         LOGGER.debug(String.format("There are %s zip file(s) to test", fileNamesFromFolder.size()));
93         return provideData(newList, VNF_FILE_PATH);
94     }
95
96     @DataProvider(name = "softwareInformationPnf", parallel = true)
97     private static Object[][] softwareInformationPnf() {
98         final List<String> pnfPackageFileNameList = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.PNF);
99         if (CollectionUtils.isEmpty(pnfPackageFileNameList)) {
100             fail("Could not create softwareInformationPnf datasource");
101         }
102         final String pnfPackage = "sample-pnf-1.0.1-SNAPSHOT.csar";
103         final Optional<String> softwareInformationPnfPackage = pnfPackageFileNameList.stream()
104             .filter(pnfPackage::equals).findFirst();
105         if (!softwareInformationPnfPackage.isPresent()) {
106             fail(String.format("Could not create softwareInformationPnf datasource, the package '%s' was not found",
107                 pnfPackage));
108         }
109
110         final String folderPath = FileHandling.getXnfRepositoryPath(XnfTypeEnum.PNF);
111         final Object[][] parametersArray = new Object[1][];
112         parametersArray[0] = new Object[]{folderPath, softwareInformationPnfPackage.get(),
113             Arrays.asList("5gDUv18.05.201", "5gDUv18.06.205")};
114         return parametersArray;
115     }
116
117     private static Object[][] provideData(final List<String> fileNamesFromFolder, final String folderPath) {
118         final Object[][] parametersArray = new Object[fileNamesFromFolder.size()][];
119         int index = 0;
120         for (final Object obj : fileNamesFromFolder) {
121             parametersArray[index++] = new Object[]{folderPath, obj};
122         }
123         return parametersArray;
124     }
125
126     public static List<String> getRandomElements(final int randomElementNumber,
127                                                  final List<String> fileNamesFromFolder) {
128         if (fileNamesFromFolder.isEmpty() || fileNamesFromFolder.size() < randomElementNumber) {
129             return Collections.emptyList();
130         } else {
131             final List<Integer> indexList = new ArrayList<>();
132             final List<String> newRandomFileNamesFromFolder = new ArrayList<>();
133             for (int i = 0; i < fileNamesFromFolder.size(); i++) {
134                 indexList.add(i);
135             }
136             Collections.shuffle(indexList);
137             final Integer[] randomArray = indexList.subList(0, randomElementNumber)
138                 .toArray(new Integer[randomElementNumber]);
139             for (final Integer randomNumber : randomArray) {
140                 newRandomFileNamesFromFolder.add(fileNamesFromFolder.get(randomNumber));
141             }
142             return newRandomFileNamesFromFolder;
143         }
144     }
145
146
147 }