2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6 * Copyright (C) 2021 Nokia. All rights reserved.
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
22 package org.onap.sdc.frontend.ci.tests.dataProvider;
24 import org.onap.sdc.backend.ci.tests.datatypes.enums.XnfTypeEnum;
25 import org.onap.sdc.backend.ci.tests.utils.general.OnboardingUtils;
26 import org.onap.sdc.frontend.ci.tests.utilities.FileHandling;
27 import org.openecomp.sdc.logging.api.Logger;
28 import org.openecomp.sdc.logging.api.LoggerFactory;
29 import org.testng.Assert;
30 import org.testng.annotations.DataProvider;
32 import java.util.ArrayList;
33 import java.util.Arrays;
34 import java.util.Collections;
35 import java.util.List;
37 public class OnbordingDataProviders {
38 private static final Logger LOGGER = LoggerFactory.getLogger(OnbordingDataProviders.class);
40 private static final String VSP_VGW_CSAR = "vsp-vgw.csar";
41 private static final int NUMBER_OF_RANDOMLY_ONBOARD_VNF = 3;
42 protected static String filepath = FileHandling.getVnfRepositoryPath();
44 // -----------------------dataProviders-----------------------------------------
45 @DataProvider(name = "randomVNF_List", parallel = false)
46 private static Object[][] randomVnfList() throws Exception {
47 int randomElementNumber = NUMBER_OF_RANDOMLY_ONBOARD_VNF; //how many VNFs to onboard randomly
48 List<String> fileNamesFromFolder = OnboardingUtils.getVnfNamesFileListExcludeToscaParserFailure();
49 List<String> newRandomFileNamesFromFolder = getRandomElements(randomElementNumber, fileNamesFromFolder);
50 return provideData(newRandomFileNamesFromFolder, filepath);
53 @DataProvider(name = "VNF_List", parallel = true)
54 private static Object[][] VnfList() throws Exception {
55 List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.VNF);
56 return provideData(fileNamesFromFolder, filepath);
59 @DataProvider(name = "CNF_List", parallel = true)
60 private static Object[][] cnfList() {
61 List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.CNF);
62 return provideData(fileNamesFromFolder, FileHandling.getCnfRepositoryPath());
65 @DataProvider(name = "CNF_Helm_Validator_List", parallel = true)
66 private static Object[][] cnfForHelmValidatorList() {
67 List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.CNF_HELM);
68 return provideData(fileNamesFromFolder, FileHandling.getCnfForHelmValidatorRepositoryPath());
71 @DataProvider(name = "CNF_With_Warning_Helm_Validator_List", parallel = true)
72 private static Object[][] cnfWithWarningForHelmValidatorList() {
73 List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesWithWarningsFileList(XnfTypeEnum.CNF_HELM);
74 Object[][] objects = provideData(fileNamesFromFolder,
75 FileHandling.getCnfWithWarningForHelmValidatorRepositoryPath());
79 @DataProvider(name = "Invalid_CNF_Helm_Validator_List", parallel = true)
80 private static Object[][] invalidCnfForHelmValidatorList() {
81 List<String> fileNamesFromFolder = OnboardingUtils.getInvalidXnfNamesFileList(XnfTypeEnum.CNF_HELM);
82 return provideData(fileNamesFromFolder, FileHandling.getInvalidCnfForHelmValidatorRepositoryPath());
85 @DataProvider(name = "Invalid_CNF_List", parallel = true)
86 private static Object[][] invalidCnfList() {
87 List<String> fileNamesFromFolder = OnboardingUtils.getInvalidXnfNamesFileList(XnfTypeEnum.CNF);
88 return provideData(fileNamesFromFolder, FileHandling.getCnfRepositoryPath());
91 @DataProvider(name = "updateList")
92 private static Object[][] updateList() throws Exception {
94 Object[][] objectArr = new Object[2][];
96 Object[][] filteredArObject = null;
98 objectArr[0] = new Object[] {"1-2016-20-visbc3vf-(VOIP)_v2.1.zip",
99 "2-2016-20-visbc3vf-(VOIP)_v2.1_RenameResourceToShay.zip"};
100 objectArr[1] = new Object[] {"1-2017-404_vUSP_vCCF_AIC3.0-(VOIP)_v6.0.zip",
101 "2-2017-404_vUSP_vCCF_AIC3.0-(VOIP)_v6.0_Added2TestParameters.zip"};
103 filteredArObject = OnboardingUtils.filterObjectArrWithExcludedVnfs(objectArr);
105 return filteredArObject;
110 @DataProvider(name = "Single_Vsp_Test_Csar", parallel = true)
111 private static Object[][] singleVspTestCsar() throws Exception {
113 List<String> fileNamesFromFolder = OnboardingUtils.getXnfNamesFileList(XnfTypeEnum.VNF);
114 if (!fileNamesFromFolder.contains(VSP_VGW_CSAR)) {
115 Assert.fail("Vsp Test file is not exits in the path");
117 return provideData(Arrays.asList(VSP_VGW_CSAR), filepath);
120 // -----------------------methods-----------------------------------------
121 static Object[][] provideData(List<String> fileNamesFromFolder, String filepath) {
122 LOGGER.info(String.format("There are %s zip file(s) to test", fileNamesFromFolder.size()));
123 Object[][] arObject = new Object[fileNamesFromFolder.size()][];
125 for (Object obj : fileNamesFromFolder) {
126 arObject[index++] = new Object[] {filepath, obj};
131 static List<String> getRandomElements(int randomElementNumber, List<String> fileNamesFromFolder) {
132 if (fileNamesFromFolder.size() == 0 || fileNamesFromFolder.size() < randomElementNumber) {
135 List<Integer> indexList = new ArrayList<>();
136 List<String> newRandomFileNamesFromFolder = new ArrayList<>();
137 for (int i = 0; i < fileNamesFromFolder.size(); i++) {
140 Collections.shuffle(indexList);
141 Integer[] randomArray = indexList.subList(0, randomElementNumber).toArray(new Integer[randomElementNumber]);
142 for (Integer integer : randomArray) {
143 newRandomFileNamesFromFolder.add(fileNamesFromFolder.get(integer));
145 return newRandomFileNamesFromFolder;