Merge "update code"
authorMichael Lando <ml636r@att.com>
Thu, 14 Sep 2017 03:00:19 +0000 (03:00 +0000)
committerGerrit Code Review <gerrit@onap.org>
Thu, 14 Sep 2017 03:00:19 +0000 (03:00 +0000)
14 files changed:
.gitignore
pom.xml
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ComponentBaseTest.java
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ExtentManager.java
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ExtentTestActions.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ExtentTestManager.java
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/dataProviders/OnbordingDataProviders.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/AmdocsLicenseMembers.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/VendorSoftwareProductObject.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/sanity/Onboard.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/FileHandling.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtillViaApis.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtils.java [new file with mode: 0644]
test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/SnmpTypeEnum.java [new file with mode: 0644]

index 5cf5bb2..631577f 100644 (file)
@@ -160,3 +160,4 @@ common/openecomp-sdc-artifact-generator-lib/openecomp-sdc-artifact-generator-cor
 /sdc-os-chef/sdc-backend/chef-repo/cookbooks/sdc-catalog-be/files/default/logback.xml
 
 /utils/webseal-simulator/sdc-simulator/chef-repo/cookbooks/sdc-simulator/files/default/logback.xml
+sdc-os-chef/sdc-sanity/chef-repo/cookbooks/sdc-sanity/files/default/testSuites/*
diff --git a/pom.xml b/pom.xml
index eab52ef..fe89499 100644 (file)
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
        <artifactId>sdc-main</artifactId>
        <version>1.1.0-SNAPSHOT</version>
        <packaging>pom</packaging>
-       
+        <name>sdc</name>       
 
        <properties>
 
index a9cc119..cfd132d 100644 (file)
@@ -35,7 +35,6 @@ import java.util.function.Consumer;
 import java.util.stream.Collectors;
 
 import org.apache.commons.collections.CollectionUtils;
-import org.apache.commons.io.FileUtils;
 import org.apache.commons.lang3.tuple.ImmutablePair;
 import org.apache.commons.lang3.tuple.ImmutableTriple;
 import org.apache.log4j.Logger;
@@ -60,7 +59,6 @@ import org.openecomp.sdc.ci.tests.utils.Utils;
 import org.openecomp.sdc.ci.tests.utils.cassandra.CassandraUtils;
 import org.openecomp.sdc.ci.tests.utils.general.AtomicOperationUtils;
 import org.openecomp.sdc.ci.tests.utils.general.ElementFactory;
-import org.openecomp.sdc.ci.tests.utils.rest.AutomationUtils;
 import org.openecomp.sdc.ci.tests.utils.rest.BaseRestUtils;
 import org.openecomp.sdc.ci.tests.utils.rest.CatalogRestUtils;
 import org.openecomp.sdc.ci.tests.utils.rest.CategoryRestUtils;
@@ -71,13 +69,8 @@ import org.openecomp.sdc.ci.tests.utils.rest.ServiceRestUtils;
 import org.slf4j.LoggerFactory;
 import org.testng.ITestContext;
 import org.testng.ITestResult;
-import org.testng.annotations.AfterClass;
-import org.testng.annotations.AfterMethod;
-import org.testng.annotations.AfterSuite;
-import org.testng.annotations.BeforeMethod;
-import org.testng.annotations.BeforeSuite;
+import org.testng.annotations.*;
 
-import com.aventstack.extentreports.ExtentReports;
 import com.aventstack.extentreports.ExtentTest;
 import com.aventstack.extentreports.Status;
 import com.thinkaurelius.titan.core.TitanFactory;
@@ -94,17 +87,16 @@ public abstract class ComponentBaseTest {
        protected static Logger logger= Logger.getLogger(ComponentBaseTest.class);      
        
 
-       // public ComponentBaseTest(TestName testName, String className) {
-       // super(testName, className);
-       // }
+//      public ComponentBaseTest(TestName testName, String className) {
+//      super(testName, className);
+//      }
 
-       protected static ExtentReports extentReport;
-       public static final String REPORT_FOLDER = "./ExtentReport/";
+       protected static final String REPORT_FOLDER = "." + File.separator + "ExtentReport" + File.separator;
        private static final String VERSIONS_INFO_FILE_NAME = "versions.info";
        private static final String REPORT_FILE_NAME = "SDC_CI_Extent_Report.html";
        protected static TitanGraph titanGraph;
-       private static Config myconfig;
        public static Config config;
+       protected static ITestContext myContext;
        
        
        
@@ -125,104 +117,45 @@ public abstract class ComponentBaseTest {
                lc.getLogger("io.netty").setLevel(Level.INFO);
                lc.getLogger("c.d").setLevel(Level.INFO);
        }
+       
+       public static String getReportFolder() {
+               return REPORT_FOLDER;
+       }
 
        @BeforeSuite(alwaysRun = true)
-       public static void openTitan(ITestContext context) throws Exception {
-                               
-               logger.info("<<<BeforeSuite>>>");
-               myconfig = Utils.getConfig();
+       public void setupBeforeSuite(ITestContext context) throws Exception {
                config = Utils.getConfig();
-
-               File dir = new File(REPORT_FOLDER);
-               try {
-                       FileUtils.deleteDirectory(dir);
-               } catch (IOException e) {
-               }
-               dir.mkdir();
-               
-               System.out.println("BeforeSuite  - get reporter");
-               extentReport = ExtentManager.getReporter(REPORT_FOLDER + REPORT_FILE_NAME);
-               
-               String onboardVersion = AutomationUtils.getOnboardVersion();
-               String osVersion = AutomationUtils.getOSVersion();
-               String envData = myconfig.getUrl();
-               // TODO: uncomment config file
-//             extentReport.loadConfig(AutomationUtils.getConfigFile(CONFIG_FILE));
-               
-               extentReport.setSystemInfo("Onboard Version", onboardVersion);
-               extentReport.setSystemInfo("OS Version", osVersion);
-               extentReport.setSystemInfo("ExecutedOn", envData);
-               extentReport.setSystemInfo("SuiteName", context.getName());
-               AutomationUtils.createVersionsInfoFile(REPORT_FOLDER + VERSIONS_INFO_FILE_NAME, onboardVersion, osVersion, envData);
-
-               System.out.println("BeforeSuite - open titan");
-               openTitanLogic();
-               
-               System.out.println("BeforeSuite - createConsumer");
+               myContext=context;
+               ExtentManager.initReporter(getReportFolder(), REPORT_FILE_NAME, context);       
                AtomicOperationUtils.createDefaultConsumer(true);
-               
-               System.out.println("BeforeSuite - performClean");
+               openTitanLogic();
                performClean();
-       }
-
-       protected static void openTitanLogic() throws Exception {
-       
-               logger.trace(config.toString());
-               String titanConfigFilePath = myconfig.getTitanPropertiesFile();
-               titanGraph = TitanFactory.open(titanConfigFilePath);
-               assertNotNull(titanGraph);
-               
-       }
-       
-       @AfterClass(alwaysRun = true)
-       public synchronized static void cleanAfterClass() throws Exception{
-               
-//             System.out.println("<<<<<<<<class name>>>>>"+method.getDeclaringClass());
-//             System.out.println("<<<<<<<<class name>>>>>"+method.getName());
                
                
-               System.out.println("delete components AfterClass");
-               deleteCreatedComponents(getCatalogAsMap());
-//             extentReport.flush();
 
        }
        
-       @AfterSuite(alwaysRun = true)
-       public static void shutdownTitan() throws Exception {
-               
-               System.out.println("AfterSuite  - flush report");
-               extentReport.flush();
-               System.out.println("AfterSuite  - perform clean");
-               performClean();
-               System.out.println("AfterSuite  - close report");
-//             extentReport.close();
-               System.out.println("AfterSuite  - close titan");
-               shutdownTitanLogic();
-               System.out.println("AfterSuite  - suite ended");
-       }
-
-       protected static void shutdownTitanLogic() {
-               if (titanGraph.isOpen()) {
-                       titanGraph.close();
-               }
-               CassandraUtils.close();
-       }
-
        @BeforeMethod(alwaysRun = true)
-       public void beforeState(java.lang.reflect.Method method) throws Exception {
-
-
-               ExtentTestManager.startTest(method.getName());
-               String[] parts = this.getClass().getName().toString().split("\\.");
-               String lastOne1 = parts[parts.length-1];
-               String lastOne2 = parts[parts.length-2];
-               getExtendTest().assignCategory(lastOne2 + "-" + lastOne1);
-               getExtendTest().log(Status.INFO, "Test started");
+       public void setBrowserBeforeTest(java.lang.reflect.Method method, ITestContext context) throws Exception {
+
+      
+    boolean emptyDataProvider = method.getAnnotation(Test.class).dataProvider().isEmpty();
+       String className = method.getDeclaringClass().getName();
+               if (emptyDataProvider && !className.contains("ToscaValidationTest") ) {
+                       System.out.println("ExtentReport instance started from BeforeMethod...");
+                       String suiteName = ExtentManager.getSuiteName(context);
+                       ExtentTestManager.startTest(method.getName());
+                       ExtentTestManager.assignCategory(this.getClass());
+                       
+               } else {
+                       System.out.println("ExtentReport instance started from Test...");
+               }
+      
 
        }
        
        @AfterMethod(alwaysRun = true)
-       public void afterState(ITestResult result) throws Exception {
+       public void quitAfterTest(ITestResult result, ITestContext context) throws Exception {
 
                String testName = result.getName();
                Throwable throwable = result.getThrowable();
@@ -248,8 +181,55 @@ public abstract class ComponentBaseTest {
 
 
                ExtentTestManager.endTest();
-       extentReport.flush();
+       
+               
+       }
+
+       @AfterClass(alwaysRun = true)
+       public synchronized static void cleanAfterClass() throws Exception{
+
+//             System.out.println("<<<<<<<<class name>>>>>"+method.getDeclaringClass());
+//             System.out.println("<<<<<<<<class name>>>>>"+method.getName());
+
+
+               System.out.println("delete components AfterClass");
+               deleteCreatedComponents(getCatalogAsMap());
+//             extentReport.flush();
+
+       }
+       
+       @AfterSuite(alwaysRun = true)
+       public static void shutdownTitan() throws Exception {
+               
+               performClean();
+               shutdownTitanLogic();
+
+       }
+
+       protected static void openTitanLogic() throws Exception {
+       
+               logger.trace(config.toString());
+               String titanConfigFilePath = config.getTitanPropertiesFile();
+               titanGraph = TitanFactory.open(titanConfigFilePath);
+               assertNotNull(titanGraph);
                
+       }
+
+
+       protected static void shutdownTitanLogic() {
+               if (titanGraph.isOpen()) {
+                       titanGraph.close();
+               }
+               CassandraUtils.close();
+       }
+
+       
+
+       public void setLog(String fromDataProvider) {
+
+               String suiteName = ExtentManager.getSuiteName(myContext);
+               ExtentTestManager.startTest(Thread.currentThread().getStackTrace()[2].getMethodName() + "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" + fromDataProvider);
+               ExtentTestManager.assignCategory(this.getClass());
 
        }
 
index 2b970fd..ae16f74 100644 (file)
 
 package org.openecomp.sdc.ci.tests.api;
 
-import org.openecomp.sdc.ci.tests.utils.rest.AutomationUtils;
-
 import com.aventstack.extentreports.ExtentReports;
 import com.aventstack.extentreports.reporter.ExtentHtmlReporter;
 import com.aventstack.extentreports.reporter.ExtentXReporter;
 import com.aventstack.extentreports.reporter.configuration.Protocol;
 import com.aventstack.extentreports.reporter.configuration.Theme;
+import org.openecomp.sdc.ci.tests.config.Config;
+
+import org.openecomp.sdc.ci.tests.utils.Utils;
+import org.openecomp.sdc.ci.tests.utils.general.FileHandling;
+import org.openecomp.sdc.ci.tests.utils.rest.AutomationUtils;
+import org.testng.ITestContext;
+
+import java.io.File;
 
 public class ExtentManager {
+       
+       private static final String VERSIONS_INFO_FILE_NAME = "versions.info";
+       private static ExtentReports extent;
+       private static ExtentHtmlReporter htmlReporter;
+       private static ExtentXReporter extentxReporter;
+       private static final String icon = "$(document).ready(function() {" +"\n"+
+                    "$('.brand-logo').html('').prepend(\"<span><img src='' style='display: block; margin-left: auto; margin-right: auto; margin-top: 7px; width: 89px;'/></span>\").width(\"120px\").css(\"float\",\"left\").css(\"padding-left\",\"0\");$('.report-name').css(\"font-weight\",\"bold\");"+"\n"+
+//                    "$('.logo-content' ).remove();"+"\n"+
+//                    "$('#slide-out li:first-child').on('click', function(){ $('#charts-row').hide() }) ; $('#slide-out li:last-child').on('click', function(){ $('#charts-row').show() });"+"\n"+
+//                    "$('.charts div:nth-child(2)').remove();"+"\n"+
+                                       "})";
 
-    private static ExtentReports extent;
+       public enum suiteNameXml {
+               
+               TESTNG_FAILED_XML_NAME("testng-failed.xml");
+               
+               suiteNameXml(String value) {
+                       this.value = value;
+                   }
+               
+               private String value;
+               
+           public String getValue() {
+               return value;
+           }
+               
+       }
     
-    public synchronized static ExtentReports getReporter(String filePath) {
-        if (extent == null) {
-               // initialize the HtmlReporter
-               ExtentHtmlReporter htmlReporter = new ExtentHtmlReporter(filePath);
-               
-               // initialize ExtentReports and attach the HtmlReporter
-               extent = new ExtentReports();
+    public synchronized static ExtentReports setReporter(String filePath, String htmlFile, Boolean isAppend) throws Exception {
+       String dbIp = Utils.getConfig().getReportDBhost();
+       int dbPort = Utils.getConfig().getReportDBport();
 
-               // attach all reporters
-               extent.attachReporter(htmlReporter);
-
-            
+       if (extent == null) {
+               extentxReporter = new ExtentXReporter(dbIp, dbPort);
+               extent = new ExtentReports();
+               initAndSetExtentHtmlReporter(filePath, htmlFile, isAppend);
+                       
+               if(extentxReporter.config().getReportObjectId() != null){
+                               setExtentXReporter(isAppend);
+                       }else{
+                               extentxReporter.stop();
+                       }
         }
-        
         return extent;
     }
     
-    public synchronized static ExtentHtmlReporter setConfiguration(ExtentHtmlReporter htmlReporter) {
+    public synchronized static void setExtentXReporter(Boolean isAppend){
+       extentxReporter.setAppendExisting(isAppend);
+               extent.attachReporter(extentxReporter);
+    }
+    
+    public synchronized static void initAndSetExtentHtmlReporter(String filePath, String htmlFile, Boolean isAppend) throws Exception{
+       htmlReporter = new ExtentHtmlReporter(filePath + htmlFile);
+       setConfiguration(htmlReporter);
+               htmlReporter.setAppendExisting(isAppend);
+               extent.attachReporter(htmlReporter);
+    }
+
+    public synchronized static ExtentReports getReporter() {
+        return extent;
+    }
+
+       public static void initReporter(String filepath, String htmlFile, ITestContext context) throws Exception {
+               
+               String onboardVersion = AutomationUtils.getOnboardVersion();
+               String osVersion = AutomationUtils.getOSVersion();
+               Config config = Utils.getConfig();
+               String envData = config.getUrl();
+               String suiteName = getSuiteName(context);
+               
+               if(suiteName.equals(suiteNameXml.TESTNG_FAILED_XML_NAME.getValue())){
+                       if (config.getUseBrowserMobProxy())
+                           setTrafficCaptue(config);
+                       
+                       setReporter(filepath, htmlFile, true);
+                       String suiteNameFromVersionInfoFile = FileHandling.getKeyByValueFromPropertyFormatFile(filepath + VERSIONS_INFO_FILE_NAME, "suiteName");
+                       reporterDataDefinition(onboardVersion, osVersion, envData, suiteNameFromVersionInfoFile);
+               }else{
+                       FileHandling.deleteDirectory(ComponentBaseTest.getReportFolder());
+                       FileHandling.createDirectory(filepath);
+                       setReporter(filepath, htmlFile, false);
+                       reporterDataDefinition(onboardVersion, osVersion, envData, suiteName);
+                       AutomationUtils.createVersionsInfoFile(filepath + VERSIONS_INFO_FILE_NAME, onboardVersion, osVersion, envData, suiteName);
+               }
+               
+       }
+
+       public static void reporterDataDefinition(String onboardVersion, String osVersion, String envData, String suiteNameFromVersionInfoFile) throws Exception {
+               extent.setSystemInfo("Onboard Version", onboardVersion);
+               extent.setSystemInfo("OS Version", osVersion);
+//             extent.setSystemInfo("Host Name Address", RestCDUtils.getExecutionHostAddress());
+               extent.setSystemInfo("ExecutedOn", envData);
+               extent.setSystemInfo("SuiteName", suiteNameFromVersionInfoFile);
+       }
+
+       public static  String getSuiteName(ITestContext context) {
+               String suitePath = context.getSuite().getXmlSuite().getFileName();
+               if(suitePath != null){
+                       File file = new File(suitePath);
+                       String suiteName = file.getName();
+                       return suiteName;
+               }
+               return null;
+       }
+       
+       public synchronized static ExtentHtmlReporter setConfiguration(ExtentHtmlReporter htmlReporter) throws Exception {
+               
        htmlReporter.config().setTheme(Theme.STANDARD);
-       
        htmlReporter.config().setEncoding("UTF-8");
-       
        htmlReporter.config().setProtocol(Protocol.HTTPS);
-       
-       htmlReporter.config().setDocumentTitle("ASDC Automation Report");
-       
+       htmlReporter.config().setDocumentTitle("SDC Automation Report");
        htmlReporter.config().setChartVisibilityOnOpen(true);
-       
-       htmlReporter.config().setReportName(AutomationUtils.getOSVersion());
-       
+//     htmlReporter.config().setReportName(AutomationUtils.getATTVersion());
+       htmlReporter.config().setReportName("SDC Automation Report");
+       htmlReporter.config().setChartVisibilityOnOpen(false);
+       htmlReporter.config().setJS(icon);
        return htmlReporter;
     }
-    
-    public synchronized static ExtentReports getReporter() {
-        return extent;
-    }
+       
+       public static void closeReporter(){
+               extent.flush();
+       }
+       
+       public static void setTrafficCaptue(Config config) {
+               boolean mobProxyStatus = config.getUseBrowserMobProxy();
+               if (mobProxyStatus){
+                       config.setCaptureTraffic(true);;
+               }
+       }       
 }
 
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ExtentTestActions.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/api/ExtentTestActions.java
new file mode 100644 (file)
index 0000000..f865ef1
--- /dev/null
@@ -0,0 +1,111 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.api;
+
+import com.aventstack.extentreports.ExtentTest;
+import com.aventstack.extentreports.MediaEntityBuilder;
+import com.aventstack.extentreports.Status;
+import com.aventstack.extentreports.markuputils.ExtentColor;
+import com.aventstack.extentreports.markuputils.Markup;
+import com.aventstack.extentreports.markuputils.MarkupHelper;
+
+import java.io.File;
+
+
+public class ExtentTestActions {
+       
+       public static void log(Status logStatus, Markup mark){
+               ExtentTest test = ExtentTestManager.getTest();
+               test.log(logStatus, mark);
+       }
+
+       public static void log(Status logStatus, String message){
+               ExtentTest test = ExtentTestManager.getTest();
+               test.log(logStatus, message);
+       }
+       
+       public static void log(Status logStatus, String message, String duration){
+               log(logStatus, message + addDurationTag(duration));
+       }
+       
+       public static void log(Status logStatus, Throwable throwabel){
+               ExtentTest test = ExtentTestManager.getTest();
+               test.log(logStatus, throwabel);
+       }
+       
+       public static void addTag(Status logStatus, String message){
+               Markup m = null;
+               switch(logStatus){
+               case PASS:
+                       m = MarkupHelper.createLabel(message, ExtentColor.GREEN);
+                       break;
+               case FAIL:
+                       m = MarkupHelper.createLabel(message, ExtentColor.RED);
+                       break;
+               case SKIP:
+                       m = MarkupHelper.createLabel(message, ExtentColor.BLUE);
+                       break;
+               case FATAL:
+                       m = MarkupHelper.createLabel(message, ExtentColor.BROWN);
+                       break;
+               default:
+                       break;
+               }
+               
+               if (m != null){
+                       log(logStatus, m);
+               }
+       }
+       
+//     public static String addScreenshot(Status logStatus, String screenshotName, String message) throws IOException{
+//             String imageFilePath = null;
+//             String uuid = UUID.randomUUID().toString();
+//             String[] stringArray = uuid.split("-");
+//             screenshotName = screenshotName + "-" + stringArray[stringArray.length - 1];
+//             try {
+//                     File imageFile = GeneralUIUtils.takeScreenshot(screenshotName, SetupCDTest.getScreenshotFolder());
+//                     imageFilePath = new File(SetupCDTest.getReportFolder()).toURI().relativize(imageFile.toURI()).getPath();
+//             } catch (IOException e) {
+//                     e.printStackTrace();
+//             }
+//
+//             ExtentTest test = ExtentTestManager.getTest();
+//             test.log(logStatus, message, MediaEntityBuilder.createScreenCaptureFromPath(imageFilePath).build());
+//             return imageFilePath;
+//     }
+       
+       private static String addDurationTag(String duration){
+               return "<td width=\"80px\">" + duration + "</td>";
+       }
+       
+       public static String addLinkTag(String fileName, String pathToFile){
+               return String.format("<a download=\"%s\" href=\"%s\">HAR file</a>", fileName, pathToFile);
+       }
+
+       public static void addFileToReportAsLink(File harFile, String pathToFileFromReportDirectory, String message) {
+               log(Status.INFO, message, addLinkTag(harFile.getName(), pathToFileFromReportDirectory));
+       }
+       
+       
+       
+
+
+}
index 9c4acd4..3d8c6a9 100644 (file)
 
 package org.openecomp.sdc.ci.tests.api;
 
-import java.util.HashMap;
-
 import com.aventstack.extentreports.ExtentReports;
 import com.aventstack.extentreports.ExtentTest;
 
+import java.util.HashMap;
 
 public class ExtentTestManager {
 
@@ -37,8 +36,6 @@ public class ExtentTestManager {
 
            public static synchronized void endTest() {
 //             extent.endTest(extentTestMap.get(Thread.currentThread().getId()));
-//             extentTestMap.get(Thread.currentThread().getId()); // This is test
-               // TODO: maybe uncomment becuase we will need it only at the end
                extent.flush();
            }
 
@@ -52,5 +49,14 @@ public class ExtentTestManager {
 
                return test;
            }
+           
+           public static synchronized <T> void assignCategory(Class<T> clazz){
+                       String[] parts = clazz.getName().split("\\.");
+                       String lastOne1 = parts[parts.length-1];
+                       String lastOne2 = parts[parts.length-2];
+                       getTest().assignCategory(lastOne2 + "-" + lastOne1);
+           }
+           
+               
 }
 
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/dataProviders/OnbordingDataProviders.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/dataProviders/OnbordingDataProviders.java
new file mode 100644 (file)
index 0000000..8b58ca9
--- /dev/null
@@ -0,0 +1,72 @@
+package org.openecomp.sdc.ci.tests.dataProviders;
+
+import org.openecomp.sdc.ci.tests.utils.general.FileHandling;
+import org.openecomp.sdc.ci.tests.utils.general.OnboardingUtils;
+import org.testng.annotations.DataProvider;
+
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+public class OnbordingDataProviders {
+
+       protected static String filepath = FileHandling.getVnfRepositoryPath();
+       
+//     -----------------------dataProviders-----------------------------------------   
+       @DataProvider(name = "randomVNF_List", parallel = false)
+       private static final Object[][] randomVnfList() throws Exception {
+               int randomElementNumber = 3; //how many VNFs to onboard randomly
+               List<String> fileNamesFromFolder = OnboardingUtils.getVnfNamesFileListExcludeToscaParserFailure();
+               List<String> newRandomFileNamesFromFolder = getRandomElements(randomElementNumber, fileNamesFromFolder);
+               System.out.println(String.format("There are %s zip file(s) to test", newRandomFileNamesFromFolder.size()));
+               return provideData(newRandomFileNamesFromFolder, filepath);
+       }
+       
+       @DataProvider(name = "VNF_List" , parallel = true)
+       private static final Object[][] VnfList() throws Exception {
+               
+               List<String> fileNamesFromFolder = OnboardingUtils.getVnfNamesFileList();
+               
+               System.out.println(String.format("There are %s zip file(s) to test", fileNamesFromFolder.size()));
+               return provideData(fileNamesFromFolder, filepath);
+       }
+       
+//     -----------------------factories-----------------------------------------
+
+       
+       
+       
+//     -----------------------methods-----------------------------------------
+       public static Object[][] provideData(List<String> fileNamesFromFolder, String filepath) {
+               
+               Object[][] arObject = new Object[fileNamesFromFolder.size()][];
+               int index = 0;
+               for (Object obj : fileNamesFromFolder) {
+                       arObject[index++] = new Object[] { filepath, obj };
+               }
+               return arObject;
+       }
+       
+       private static List<String> getRandomElements(int randomElementNumber, List<String> fileNamesFromFolder) {
+               if(fileNamesFromFolder.size() == 0 || fileNamesFromFolder.size() < randomElementNumber){
+                       return null;
+               }else{
+                       List<Integer> indexList = new ArrayList<>();
+                       List<String> newRandomFileNamesFromFolder = new ArrayList<>(); 
+                       for(int i = 0; i < fileNamesFromFolder.size(); i++){
+                               indexList.add(i);
+                       }
+                       Collections.shuffle(indexList);
+                       Integer[] randomArray = indexList.subList(0, randomElementNumber).toArray(new Integer[randomElementNumber]);
+                       for(int i = 0; i < randomArray.length; i++){
+                               newRandomFileNamesFromFolder.add(fileNamesFromFolder.get(randomArray[i]));
+                       }
+                       return newRandomFileNamesFromFolder;
+               }
+       }
+       
+       
+       
+       
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/AmdocsLicenseMembers.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/AmdocsLicenseMembers.java
new file mode 100644 (file)
index 0000000..9c2cfa8
--- /dev/null
@@ -0,0 +1,56 @@
+package org.openecomp.sdc.ci.tests.datatypes;
+
+public class AmdocsLicenseMembers {
+
+       private String vendorId;
+       private String vendorLicenseName;
+       private String vendorLicenseAgreementId;
+       private String featureGroupId;
+
+       public AmdocsLicenseMembers(String vendorId, String vendorLicenseName, String vendorLicenseAgreementId, String featureGroupId) {
+               super();
+               this.vendorId = vendorId;
+               this.vendorLicenseName = vendorLicenseName;
+               this.vendorLicenseAgreementId = vendorLicenseAgreementId;
+               this.featureGroupId = featureGroupId;
+       }
+
+       public String getVendorId() {
+               return vendorId;
+       }
+
+       public void setVendorId(String vendorId) {
+               this.vendorId = vendorId;
+       }
+
+       public String getVendorLicenseName() {
+               return vendorLicenseName;
+       }
+
+       public void setVendorLicenseName(String vendorLicenseName) {
+               this.vendorLicenseName = vendorLicenseName;
+       }
+
+       public String getVendorLicenseAgreementId() {
+               return vendorLicenseAgreementId;
+       }
+
+       public void setVendorLicenseAgreementId(String vendorLicenseAgreementId) {
+               this.vendorLicenseAgreementId = vendorLicenseAgreementId;
+       }
+
+       public String getFeatureGroupId() {
+               return featureGroupId;
+       }
+
+       public void setFeatureGroupId(String featureGroupId) {
+               this.featureGroupId = featureGroupId;
+       }
+
+       @Override
+       public String toString() {
+               return "AmdocsLicenseMembers [vendorId=" + vendorId + ", vendorLicenseName=" + vendorLicenseName + ", vendorLicenseAgreementId=" + vendorLicenseAgreementId + ", featureGroupId=" + featureGroupId + "]";
+       }
+       
+       
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/VendorSoftwareProductObject.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/datatypes/VendorSoftwareProductObject.java
new file mode 100644 (file)
index 0000000..fbdb88e
--- /dev/null
@@ -0,0 +1,102 @@
+package org.openecomp.sdc.ci.tests.datatypes;
+
+public class VendorSoftwareProductObject {
+
+       private String vendorName;
+       private String vspId;
+       private String category;
+       private String subCategory;
+       private String componentId;
+       private String description;
+       private String attContact;
+       private String vspName;
+       
+       public VendorSoftwareProductObject() {
+               super();
+               // TODO Auto-generated constructor stub
+       }
+
+       public VendorSoftwareProductObject(String vendorName, String vspId, String category, String subCategory, String componentId, String description, String attContact) {
+               super();
+               this.vendorName = vendorName;
+               this.vspId = vspId;
+               this.category = category;
+               this.subCategory = subCategory;
+               this.componentId = componentId;
+               this.description = description;
+               this.attContact = attContact;
+       }
+
+       
+       public String getVspName() {
+               return vspName;
+       }
+
+       public void setVspName(String vspName) {
+               this.vspName = vspName;
+       }
+
+       public String getVendorName() {
+               return vendorName;
+       }
+
+       public void setVendorName(String vendorName) {
+               this.vendorName = vendorName;
+       }
+
+       public String getVspId() {
+               return vspId;
+       }
+
+       public void setVspId(String vspId) {
+               this.vspId = vspId;
+       }
+
+       public String getCategory() {
+               return category;
+       }
+
+       public void setCategory(String category) {
+               this.category = category;
+       }
+
+       public String getSubCategory() {
+               return subCategory;
+       }
+
+       public void setSubCategory(String subCategory) {
+               this.subCategory = subCategory;
+       }
+
+       public String getComponentId() {
+               return componentId;
+       }
+
+       public void setComponentId(String componentId) {
+               this.componentId = componentId;
+       }
+
+       public String getDescription() {
+               return description;
+       }
+
+       public void setDescription(String description) {
+               this.description = description;
+       }
+
+       public String getAttContact() {
+               return attContact;
+       }
+
+       public void setAttContact(String attContact) {
+               this.attContact = attContact;
+       }
+
+       @Override
+       public String toString() {
+               return "VendorSoftwareProductObject [vendorName=" + vendorName + ", vspId=" + vspId + ", category=" + category + ", subCategory=" + subCategory + ", componentId=" + componentId + ", description=" + description + ", attContact="
+                               + attContact + "]";
+       }
+       
+       
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/sanity/Onboard.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/sanity/Onboard.java
new file mode 100644 (file)
index 0000000..2b341f5
--- /dev/null
@@ -0,0 +1,126 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.sanity;
+
+
+
+
+
+import org.junit.Rule;
+import org.junit.rules.TestName;
+import org.openecomp.sdc.be.model.ComponentInstance;
+import org.openecomp.sdc.be.model.Resource;
+import org.openecomp.sdc.be.model.Service;
+import org.openecomp.sdc.be.model.User;
+import org.openecomp.sdc.ci.tests.api.ComponentBaseTest;
+import org.openecomp.sdc.ci.tests.api.ExtentTestActions;
+import org.openecomp.sdc.ci.tests.dataProviders.OnbordingDataProviders;
+import org.openecomp.sdc.ci.tests.datatypes.ResourceReqDetails;
+import org.openecomp.sdc.ci.tests.datatypes.ServiceReqDetails;
+import org.openecomp.sdc.ci.tests.datatypes.VendorSoftwareProductObject;
+import org.openecomp.sdc.ci.tests.datatypes.enums.LifeCycleStatesEnum;
+import org.openecomp.sdc.ci.tests.datatypes.enums.UserRoleEnum;
+import org.openecomp.sdc.ci.tests.datatypes.http.RestResponse;
+import org.openecomp.sdc.ci.tests.utils.general.AtomicOperationUtils;
+import org.openecomp.sdc.ci.tests.utils.general.ElementFactory;
+import org.openecomp.sdc.ci.tests.utils.general.OnboardingUtillViaApis;
+import org.testng.annotations.BeforeMethod;
+import org.testng.annotations.Optional;
+import org.testng.annotations.Parameters;
+import org.testng.annotations.Test;
+
+import com.aventstack.extentreports.Status;
+import com.clearspring.analytics.util.Pair;
+
+import fj.data.Either;
+
+
+
+
+
+
+public class Onboard extends ComponentBaseTest {
+       
+       
+       @Rule
+       public static TestName name = new TestName();
+       
+       public Onboard() {
+               super(name, Onboard.class.getName());
+       }
+
+       protected String makeDistributionValue;
+
+
+
+       @Parameters({ "makeDistribution" })
+       @BeforeMethod
+       public void beforeTestReadParams(@Optional("true") String makeDistributionReadValue) {
+               makeDistributionValue = makeDistributionReadValue;                             
+       }
+       
+
+       @Test(dataProviderClass = OnbordingDataProviders.class, dataProvider = "VNF_List")
+       public void onboardVNFShotFlow(String filepath, String vnfFile) throws Exception, Throwable {
+               setLog(vnfFile);
+               System.out.println("print - >" + makeDistributionValue);
+               runOnboardToDistributionFlow(filepath, vnfFile);
+       }
+       
+
+       
+
+       
+       public void runOnboardToDistributionFlow(String filepath, String vnfFile) throws Exception {
+
+               ExtentTestActions.log(Status.INFO, String.format("Going to onboard the VNF %s", vnfFile));
+               User user = ElementFactory.getDefaultUser(UserRoleEnum.DESIGNER);
+     
+               Pair<String, VendorSoftwareProductObject> createVendorSoftwareProduct = OnboardingUtillViaApis.createVspViaApis(filepath, vnfFile, user);
+               VendorSoftwareProductObject vendorSoftwareProductObject = createVendorSoftwareProduct.right;
+               vendorSoftwareProductObject.setVspName(createVendorSoftwareProduct.left);
+
+               //              create VF base on VNF imported from previous step - have, resourceReqDetails object include part of resource metadata
+               ResourceReqDetails resourceReqDetails = OnboardingUtillViaApis.prepareOnboardedResourceDetailsBeforeCreate(vendorSoftwareProductObject, vendorSoftwareProductObject.getVspName());
+               ExtentTestActions.log(Status.INFO, String.format("Create VF %s From VSP", resourceReqDetails.getName()));
+               Resource resource = OnboardingUtillViaApis.createResourceFromVSP(resourceReqDetails, vendorSoftwareProductObject.getVspName());
+               ExtentTestActions.log(Status.INFO, String.format("Certify VF"));
+               resource = (Resource) AtomicOperationUtils.changeComponentState(resource, UserRoleEnum.DESIGNER, LifeCycleStatesEnum.CERTIFY, true).getLeft();
+
+               //--------------------------SERVICE--------------------------------     
+               ServiceReqDetails serviceReqDetails = OnboardingUtillViaApis.prepareServiceDetailsBeforeCreate(user);
+               ExtentTestActions.log(Status.INFO, String.format("Create Service %s", serviceReqDetails.getName()));
+               Service service = AtomicOperationUtils.createCustomService(serviceReqDetails, UserRoleEnum.DESIGNER, true).left().value();
+               ExtentTestActions.log(Status.INFO, String.format("add VF to Service"));
+               Either<ComponentInstance, RestResponse> addComponentInstanceToComponentContainer = AtomicOperationUtils.addComponentInstanceToComponentContainer(resource, service, UserRoleEnum.DESIGNER, true);
+               addComponentInstanceToComponentContainer.left().value();
+               ExtentTestActions.log(Status.INFO, String.format("Certify Service"));
+               service = (Service) AtomicOperationUtils.changeComponentState(service, UserRoleEnum.DESIGNER, LifeCycleStatesEnum.CERTIFY, true).getLeft();
+
+               ExtentTestActions.log(Status.INFO, String.format("Distribute Service"));
+               AtomicOperationUtils.distributeService(service, true);
+               
+               ExtentTestActions.log(Status.INFO, String.format("The onboarding %s test is passed ! ", vnfFile));
+       }
+
+
+
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/FileHandling.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/FileHandling.java
new file mode 100644 (file)
index 0000000..77be6df
--- /dev/null
@@ -0,0 +1,542 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.utils.general;
+
+import com.aventstack.extentreports.Status;
+import com.clearspring.analytics.util.Pair;
+import org.apache.commons.io.FileUtils;
+import org.openecomp.sdc.be.model.DataTypeDefinition;
+import org.openecomp.sdc.ci.tests.api.ComponentBaseTest;
+import org.openecomp.sdc.ci.tests.config.Config;
+
+import org.openecomp.sdc.common.util.GeneralUtility;
+import org.yaml.snakeyaml.Yaml;
+
+import java.io.*;
+import java.nio.file.Paths;
+import java.util.*;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipException;
+import java.util.zip.ZipFile;
+import java.util.zip.ZipInputStream;
+
+import static org.testng.AssertJUnit.assertTrue;
+
+public class FileHandling {
+
+//     ------------------yaml parser methods----------------------------
+       public static Map<?, ?> parseYamlFile(String filePath) throws Exception {
+               Yaml yaml = new Yaml();
+               File file = new File(filePath);
+               InputStream inputStream = new FileInputStream(file);
+               Map<?, ?> map = (Map<?, ?>) yaml.load(inputStream);
+               return map;
+       }
+       
+       /**
+        * The method return map fetched objects by pattern from yaml file 
+        * @param yamlFile
+        * @param pattern
+        * @return
+        * @throws Exception
+        */
+       public static Map<String, Object> parseYamlFileToMapByPattern(File yamlFile, String pattern) throws Exception {
+               Map<?, ?> yamlFileToMap = FileHandling.parseYamlFile(yamlFile.toString());
+               Map<String, Object> objectMap = getObjectMapByPattern(yamlFileToMap, pattern);
+               return objectMap;
+       }
+       
+       @SuppressWarnings("unchecked")
+       public static Map<String, Object> getObjectMapByPattern(Map<?, ?> parseUpdetedEnvFile, String pattern) {
+               Map<String, Object> objectMap = null;
+               
+               Object objectUpdetedEnvFile = parseUpdetedEnvFile.get(pattern);
+               if(objectUpdetedEnvFile instanceof HashMap){
+                       objectMap = (Map<String, Object>) objectUpdetedEnvFile;
+               }
+               return objectMap;
+       }
+       
+       
+       public static Map<String, DataTypeDefinition> parseDataTypesYaml(String filePath) throws Exception {
+               @SuppressWarnings("unchecked")
+               Map<String, DataTypeDefinition> dataTypesMap = (Map<String, DataTypeDefinition>) parseYamlFile(filePath);
+               return dataTypesMap;
+       }
+//     -------------------------------------------------------------------------------------------------
+       
+       public static String getFilePath(String folder) {
+               String filepath = System.getProperty("filepath");
+               if (filepath == null && System.getProperty("os.name").contains("Windows")) {
+                       filepath = FileHandling.getResourcesFilesPath() + folder + File.separator;
+               }
+               
+               else if(filepath.isEmpty() && !System.getProperty("os.name").contains("Windows")){
+                               filepath = FileHandling.getBasePath() + "Files" + File.separator + folder + File.separator;
+               }
+               
+               System.out.println(filepath);
+               
+               return filepath;
+       }
+
+       public static String getBasePath() {
+               return System.getProperty("user.dir") + File.separator;
+       }
+       
+       public static String getSdcVnfsPath() {
+               return  getBasePath() + Paths.get("..", "..", "sdc-vnfs").toString();
+       }
+       
+       public static String getDriversPath() {
+               return getBasePath() + "src" + File.separator + "main" + File.separator + "resources"
+                               + File.separator + "ci" + File.separator + "drivers" + File.separator;
+       }
+
+       public static String getResourcesFilesPath() {
+//             return getBasePath() + "src" + File.separator + "main" + File.separator + "resources"
+//                             + File.separator + "Files" + File.separator;
+
+               return getSdcVnfsPath()+ File.separator + "ui-tests" + File.separator + "Files" + File.separator;
+       }
+       
+       public static String getResourcesEnvFilesPath() {
+               return getBasePath() + File.separator + "src" + File.separator + "main" + File.separator + "resources"
+                               + File.separator + "Files" + File.separator + "ResourcesEnvFiles" +File.separator;
+       }
+
+       public static String getCiFilesPath() {
+               return getBasePath() + "src" + File.separator + "main" + File.separator + "resources"
+                               + File.separator + "ci";
+       }
+
+       public static String getConfFilesPath() {
+               return getCiFilesPath() + File.separator + "conf" + File.separator;
+       }
+
+       public static String getTestSuitesFilesPath() {
+               return getCiFilesPath() + File.separator + "testSuites" + File.separator;
+       }
+       
+       public static String getVnfRepositoryPath() {
+               return getFilePath("VNFs");
+       }
+       
+       public static File getConfigFile(String configFileName) throws Exception {
+               File configFile = new File(FileHandling.getBasePath() + File.separator + "conf" + File.separator + configFileName);
+               if (!configFile.exists()) {
+                       configFile = new File(FileHandling.getConfFilesPath() + configFileName);
+               }
+               return configFile;
+       }
+
+       public static Object[] filterFileNamesFromFolder(String filepath, String extension) {
+               try {
+                       File dir = new File(filepath);
+                       List<String> filenames = new ArrayList<String>();
+                       
+                       FilenameFilter extensionFilter = new FilenameFilter() {
+                               public boolean accept(File dir, String name) {
+                                       return name.endsWith(extension);
+                               }
+                       };
+                       
+                       if (dir.isDirectory()) {
+                               for (File file : dir.listFiles(extensionFilter)) {
+                                       filenames.add(file.getName());
+                               }
+                               return filenames.toArray();
+                       }
+
+               } catch (Exception e) {
+                       e.printStackTrace();
+               }
+               return null;
+       }
+
+       public static List<String> filterFileNamesListFromFolder(String filepath, String extension) {
+               try {
+                       File dir = new File(filepath);
+                       List<String> filenames = new ArrayList<String>();
+                       
+                       FilenameFilter extensionFilter = new FilenameFilter() {
+                               public boolean accept(File dir, String name) {
+                                       return name.endsWith(extension);
+                               }
+                       };
+                       
+                       if (dir.isDirectory()) {
+                               for (File file : dir.listFiles(extensionFilter)) {
+                                       filenames.add(file.getName());
+                               }
+                               return filenames;
+                       }
+
+               } catch (Exception e) {
+                       e.printStackTrace();
+               }
+               return null;
+       }
+       
+       public static String[] getArtifactsFromZip(String filepath, String zipFilename){
+               try{
+                       ZipFile zipFile = new ZipFile(filepath + File.separator + zipFilename);
+                       Enumeration<? extends ZipEntry> entries = zipFile.entries();
+                       
+                       String[] artifactNames = new String[zipFile.size() - 1];
+
+                       int i = 0;
+                       while(entries.hasMoreElements()){
+                               ZipEntry nextElement = entries.nextElement();
+                               if (!nextElement.isDirectory()){ 
+                                       if (!nextElement.getName().equals("MANIFEST.json")){
+                                               String name = nextElement.getName();
+                                               artifactNames[i++] = name;
+                                       }
+                               }
+                       }
+                       zipFile.close();
+                       return artifactNames;
+               }
+               catch(ZipException zipEx){
+                       System.err.println("Error in zip file named : " +  zipFilename);        
+                       zipEx.printStackTrace();
+               } catch (IOException e) {
+                       System.err.println("Unhandled exception : ");
+                       e.printStackTrace();
+               }
+               
+               return null;
+               
+       }
+
+//     public static Object[] getZipFileNamesFromFolder(String filepath) {
+//             return filterFileNamesFromFolder(filepath, ".zip");
+//     }
+       
+       public static List<String> getZipFileNamesFromFolder(String filepath) {
+               return filterFileNamesListFromFolder(filepath, ".zip");
+       }
+
+       public static int countFilesInZipFile(String[] artifactsArr, String reqExtension){
+               int fileCounter = 0;
+               for (String artifact : artifactsArr){
+                       String extensionFile = artifact.substring(artifact.lastIndexOf(".") + 1 , artifact.length());
+                       if (extensionFile.equals(reqExtension)){
+                               fileCounter++;
+                       }
+               }
+               return fileCounter;
+       }
+       
+
+       /**
+        * @return last modified file name from default directory
+        * @throws Exception
+        */
+//     TODO add download directory capability
+//     public static synchronized File getLastModifiedFileNameFromDir() throws Exception{
+//             return getLastModifiedFileNameFromDir(ComponentBaseTest.getWindowTest().getDownloadDirectory());
+//     }
+       
+       /**
+        * @param dirPath
+        * @return last modified file name from dirPath directory
+        */
+       public static synchronized File getLastModifiedFileNameFromDir(String dirPath){
+           File dir = new File(dirPath);
+           File[] files = dir.listFiles();
+           if (files == null) {
+               assertTrue("File not found under directory " + dirPath, false);
+               return null;
+           }
+
+           File lastModifiedFile = files[0];
+           for (int i = 1; i < files.length; i++) {
+               if(files[i].isDirectory()) {
+                       continue;
+               }
+               if (lastModifiedFile.lastModified()  < files[i].lastModified()) {
+                  lastModifiedFile = files[i];
+               }
+           }
+           return lastModifiedFile;
+       }
+
+       public static void deleteDirectory(String directoryPath) {
+               File dir = new File(directoryPath);
+               try {
+                       FileUtils.deleteDirectory(dir);
+               } catch (IOException e) {
+                       System.out.println("Failed to delete " + dir);
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Failed to delete " + dir);
+               }
+       }
+       
+       public static void createDirectory(String directoryPath) {
+               File directory = new File(String.valueOf(directoryPath));
+           if (! directory.exists()){
+               directory.mkdir();
+           }
+       }
+
+
+       /**
+        * The method append data to existing file, if file not exists - create it
+        * @param pathToFile
+        * @param text
+        * @param leftSpaceCount
+        * @throws IOException
+        */
+       public static synchronized void writeToFile(File pathToFile, Object text, Integer leftSpaceCount) throws IOException{
+
+               BufferedWriter bw = null;
+               FileWriter fw = null;
+               if(!pathToFile.exists()){
+                       createEmptyFile(pathToFile);
+               }
+               try {
+                       fw = new FileWriter(pathToFile, true);
+                       bw = new BufferedWriter(fw);
+                       StringBuilder sb = new StringBuilder();
+                       if(leftSpaceCount > 0 ){
+                               for(int i = 0; i < leftSpaceCount; i++){
+                                       sb.append(" ");
+                               }
+                       }
+                       bw.write(sb.toString() + text);
+                       bw.newLine();
+                       bw.close();
+                       fw.close();
+               } catch (Exception e) {
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Unable to write to flie " + pathToFile);
+               }
+       }
+       
+//     public static synchronized void writeToFile(File pathToFile, Map<String, Pair<String, Object>> dataMap, Integer leftSpaceCount) throws IOException{
+//
+//             BufferedWriter bw = null;
+//             FileWriter fw = null;
+//             try {
+//                     if(!pathToFile.exists()){
+//                             createEmptyFile(pathToFile);
+//                     }
+//                     fw = new FileWriter(pathToFile, true);
+//                     bw = new BufferedWriter(fw);
+//                     StringBuilder sb = new StringBuilder();
+//                     if(leftSpaceCount > 0 ){
+//                             for(int i = 0; i < leftSpaceCount; i++){
+//                                     sb.append(" ");
+//                             }
+//                     }
+//                     for(Map.Entry<String, Pair<String, Object>> entry : dataMap.entrySet()){
+//                             Object record = ArtifactUIUtils.getFormatedData(entry.getKey(), entry.getValue().right);
+//                             bw.write(sb.toString() + record);
+//                             bw.newLine();
+//                     }
+//                     bw.close();
+//                     fw.close();
+//             } catch (Exception e) {
+//                     ComponentBaseTest.getExtendTest().log(Status.INFO, "Unable to write to flie " + pathToFile);
+//             }
+//     }
+       
+       public static void deleteLastDowloadedFiles(List<File> files) throws IOException {
+               for (File file : files) {
+                       File fileToDelete =new File(Config.instance().getWindowsDownloadDirectory()+file.getName());
+                       fileToDelete.delete();
+               }
+       }
+// TODO add work with directory capaability
+//     public static void cleanCurrentDownloadDir() throws IOException {
+//             try{
+//                     ExtentTestActions.log(Status.INFO, "Cleaning directory " + ComponentBaseTest.getWindowTest().getDownloadDirectory());
+//                     System.gc();
+//                     FileUtils.cleanDirectory(new File(ComponentBaseTest.getWindowTest().getDownloadDirectory()));
+//             }
+//             catch(Exception e){
+//
+//             }
+//     }
+       
+       public static boolean isFileDownloaded(String downloadPath, String fileName) {
+               boolean flag = false;
+               File dir = new File(downloadPath);
+               File[] dir_contents = dir.listFiles();
+               for (int i = 0; i < dir_contents.length; i++) {
+                       if (dir_contents[i].getName().equals(fileName))
+                               return flag = true;
+               }
+               return flag;
+       }
+       
+       public static String getMD5OfFile(File file) throws IOException {
+               String content = FileUtils.readFileToString(file);
+               String md5 = GeneralUtility.calculateMD5Base64EncodedByString(content);
+               return md5;
+       }
+       
+       public static File createEmptyFile(String fileToCreate) {
+               File file= new File(fileToCreate);
+               try {
+                       if(file.exists()){
+                               deleteFile(file);
+                       }
+                       file.createNewFile();
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Create file " + fileToCreate);
+               } catch (IOException e) {
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Failed to create file " + fileToCreate);
+                       e.printStackTrace();
+               }
+               return file;
+       }
+       
+       public static File createEmptyFile(File fileToCreate) {
+               try {
+                       if(fileToCreate.exists()){
+                               deleteFile(fileToCreate);
+                       }
+                       fileToCreate.createNewFile();
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Create file " + fileToCreate);
+               } catch (IOException e) {
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Failed to create file " + fileToCreate);
+                       e.printStackTrace();
+               }
+               return fileToCreate;
+       }
+       
+       public static void deleteFile(File file){
+               
+               try{
+               if(file.exists()){
+                       file.deleteOnExit();
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "File " + file.getName() + "has been deleted");
+               }else{
+                       ComponentBaseTest.getExtendTest().log(Status.INFO, "Failed to delete file " + file.getName());
+               }
+       }catch(Exception e){
+               e.printStackTrace();
+       }
+
+       }
+       
+       
+       /**
+        * get file list from directory by extension array
+        * @param directory
+        * @param okFileExtensions
+        * @return
+        */
+       public static List<File> getHeatAndHeatEnvArtifactsFromZip(File directory, String[] okFileExtensions){
+               
+                       List<File> fileList = new ArrayList<>();
+                       File[] files = directory.listFiles();
+                       
+                       for (String extension : okFileExtensions){
+                               for(File file : files){
+                                       if (file.getName().toLowerCase().endsWith(extension)){
+                                               fileList.add(file);
+                                       }
+                               }
+                       }
+                       return fileList;
+       }
+       
+       private static final int BUFFER_SIZE = 4096;
+//    public static void unzip(String zipFilePath, String destDirectory) throws IOException {
+//        File destDir = new File(destDirectory);
+//        if (!destDir.exists()) {
+//            destDir.mkdir();
+//        }
+//        ZipInputStream zipIn = new ZipInputStream(new FileInputStream(zipFilePath));
+//        ZipEntry entry = zipIn.getNextEntry();
+////         iterates over entries in the zip file
+//        while (entry != null) {
+//             String entryName;
+//             if(System.getProperty("os.name").contains("Windows")){
+//                     entryName = entry.getName().replaceAll("/", "\\"+File.separator);
+//             }else{
+//                     entryName = entry.getName();
+//             }
+//            String filePath = destDirectory + entryName;
+//            String currPath = destDirectory;
+//            String[] dirs = entryName.split("\\"+File.separator);
+//            String currToken;
+//            for(int i = 0; i<dirs.length;++i){
+//             currToken = dirs[i];
+//             if(!entry.isDirectory() && i==dirs.length-1){
+//                      extractFile(zipIn, filePath);
+//             } else {
+//                     if(currPath.endsWith(File.separator)){
+//                             currPath = currPath + currToken;
+//                     }else{
+//                             currPath = currPath + File.separator + currToken;
+//                     }
+////                     if the entry is a directory, make the directory
+//                    File dir = new File(currPath);
+//                    dir.mkdir();
+//                }
+//            }
+//            zipIn.closeEntry();
+//            entry = zipIn.getNextEntry();
+//        }
+//        zipIn.close();
+//    }
+
+    private static void extractFile(ZipInputStream zipIn, String filePath) throws IOException {
+        BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(filePath));
+        byte[] bytesIn = new byte[BUFFER_SIZE];
+        int read = 0;
+        while ((read = zipIn.read(bytesIn)) != -1) {
+            bos.write(bytesIn, 0, read);
+        }
+        bos.close();
+    }
+       
+//    public static int getFileCountFromDefaulDownloadDirectory(){
+//     return new File(ComponentBaseTest.getWindowTest().getDownloadDirectory()).listFiles().length;
+//    }
+    
+    
+    public static String getKeyByValueFromPropertyFormatFile(String fullPath, String key) {
+               Properties prop = new Properties();
+               InputStream input = null;
+               String value = null;
+               try {
+                       input = new FileInputStream(fullPath);
+                       prop.load(input);
+                       value = (prop.getProperty(key));
+
+               } catch (IOException ex) {
+                       ex.printStackTrace();
+               } finally {
+                       if (input != null) {
+                               try {
+                                       input.close();
+                               } catch (IOException e) {
+                                       e.printStackTrace();
+                               }
+                       }
+               }
+
+               return value.replaceAll("\"","");
+       }
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtillViaApis.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtillViaApis.java
new file mode 100644 (file)
index 0000000..12f04e2
--- /dev/null
@@ -0,0 +1,293 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.utils.general;
+
+import com.aventstack.extentreports.Status;
+import com.clearspring.analytics.util.Pair;
+import com.google.gson.Gson;
+import fj.data.Either;
+
+import org.openecomp.sdc.be.model.Component;
+import org.openecomp.sdc.be.model.Resource;
+import org.openecomp.sdc.be.model.User;
+import org.openecomp.sdc.ci.tests.api.ExtentTestActions;
+import org.openecomp.sdc.ci.tests.api.Urls;
+import org.openecomp.sdc.ci.tests.config.Config;
+import org.openecomp.sdc.ci.tests.datatypes.AmdocsLicenseMembers;
+import org.openecomp.sdc.ci.tests.datatypes.ResourceReqDetails;
+import org.openecomp.sdc.ci.tests.datatypes.ServiceReqDetails;
+
+import org.openecomp.sdc.ci.tests.datatypes.VendorSoftwareProductObject;
+import org.openecomp.sdc.ci.tests.datatypes.enums.ResourceCategoryEnum;
+import org.openecomp.sdc.ci.tests.datatypes.enums.ServiceCategoriesEnum;
+import org.openecomp.sdc.ci.tests.datatypes.enums.UserRoleEnum;
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpHeaderEnum;
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpRequest;
+import org.openecomp.sdc.ci.tests.datatypes.http.RestResponse;
+import org.openecomp.sdc.ci.tests.utils.Utils;
+import org.openecomp.sdc.ci.tests.utils.rest.BaseRestUtils;
+
+import java.io.*;
+import java.nio.charset.StandardCharsets;
+import java.util.*;
+import org.apache.commons.codec.binary.Base64;
+
+
+
+import static org.testng.AssertJUnit.assertTrue;
+
+public class OnboardingUtillViaApis {
+
+       protected static Map<String, String> prepareHeadersMap(String userId) {
+               Map<String, String> headersMap = new HashMap<String, String>();
+               headersMap.put(HttpHeaderEnum.CONTENT_TYPE.getValue(), "application/json");
+               headersMap.put(HttpHeaderEnum.ACCEPT.getValue(), "application/json");
+               headersMap.put(HttpHeaderEnum.USER_ID.getValue(), userId);
+               return headersMap;
+       }
+       
+       public static Pair<String, VendorSoftwareProductObject> createVspViaApis(String filepath, String vnfFile, User user) throws Exception {
+               
+               VendorSoftwareProductObject vendorSoftwareProductObject = new VendorSoftwareProductObject();
+               ExtentTestActions.log(Status.INFO, String.format("Create Vendor License"));
+               AmdocsLicenseMembers amdocsLicenseMembers = OnboardingUtils.createVendorLicense(user);
+               ExtentTestActions.log(Status.INFO, String.format("Create Vendor Software Product"));
+               Pair<String, Map<String, String>> createVendorSoftwareProduct = OnboardingUtils.createVendorSoftwareProduct(vnfFile, filepath, user, amdocsLicenseMembers);
+               Map<String, String> map = createVendorSoftwareProduct.right;
+               vendorSoftwareProductObject.setAttContact(map.get("attContact"));
+               vendorSoftwareProductObject.setCategory(map.get("category"));
+               vendorSoftwareProductObject.setComponentId(map.get("componentId"));
+               vendorSoftwareProductObject.setDescription(map.get("description"));
+               vendorSoftwareProductObject.setSubCategory(map.get("subCategory"));
+               vendorSoftwareProductObject.setVendorName(map.get("vendorName"));
+               vendorSoftwareProductObject.setVspId(map.get("vspId"));
+               Pair<String, VendorSoftwareProductObject> pair = new Pair<String, VendorSoftwareProductObject>(createVendorSoftwareProduct.left, vendorSoftwareProductObject);
+               return pair;
+       }
+       
+/*     public static Resource createResourceFromVSP(Pair<String, Map<String, String>> createVendorSoftwareProduct, String vspName) throws Exception {
+               List<String> tags = new ArrayList<>();
+               tags.add(vspName);
+               Map<String, String> map = createVendorSoftwareProduct.right;
+               ResourceReqDetails resourceDetails = new ResourceReqDetails();
+               resourceDetails.setCsarUUID(map.get("vspId"));
+               resourceDetails.setCsarVersion("1.0");
+               resourceDetails.setName(vspName);
+               resourceDetails.setTags(tags);
+               resourceDetails.setDescription(map.get("description"));
+               resourceDetails.setResourceType(map.get("componentType"));
+               resourceDetails.addCategoryChain(ResourceCategoryEnum.GENERIC_DATABASE.getCategory(), ResourceCategoryEnum.GENERIC_DATABASE.getSubCategory());
+               resourceDetails.setVendorName(map.get("vendorName"));
+               resourceDetails.setVendorRelease("1.0");
+               resourceDetails.setResourceType("VF");
+               resourceDetails.setResourceVendorModelNumber("666");
+               resourceDetails.setContactId(map.get("attContact"));
+               resourceDetails.setIcon("defaulticon");
+               Resource resource = AtomicOperationUtils.createResourceByResourceDetails(resourceDetails, UserRoleEnum.DESIGNER, true).left().value();
+               
+               return resource; 
+       }*/
+       public static Resource createResourceFromVSP(ResourceReqDetails resourceDetails, String vspName) throws Exception {
+//             List<String> tags = new ArrayList<>();
+//             tags.add(vspName);
+//             Map<String, String> map = createVendorSoftwareProduct.right;
+//             ResourceReqDetails resourceDetails = new ResourceReqDetails();
+//             resourceDetails.setCsarUUID(map.get("vspId"));
+//             resourceDetails.setCsarVersion("1.0");
+//             resourceDetails.setName(vspName);
+//             resourceDetails.setTags(tags);
+//             resourceDetails.setDescription(map.get("description"));
+//             resourceDetails.setResourceType(map.get("componentType"));
+//             resourceDetails.addCategoryChain(ResourceCategoryEnum.GENERIC_DATABASE.getCategory(), ResourceCategoryEnum.GENERIC_DATABASE.getSubCategory());
+//             resourceDetails.setVendorName(map.get("vendorName"));
+//             resourceDetails.setVendorRelease("1.0");
+//             resourceDetails.setResourceType("VF");
+//             resourceDetails.setResourceVendorModelNumber("666");
+//             resourceDetails.setContactId(map.get("attContact"));
+//             resourceDetails.setIcon("defaulticon");
+               Resource resource = AtomicOperationUtils.createResourceByResourceDetails(resourceDetails, UserRoleEnum.DESIGNER, true).left().value();
+               
+               return resource; 
+       }
+       public static void downloadToscaCsarToDirectory(Component component, File file) {
+               try {
+                       Either<String, RestResponse> componentToscaArtifactPayload = AtomicOperationUtils.getComponenetArtifactPayload(component, "assettoscacsar");
+                       if(componentToscaArtifactPayload.left().value() != null){
+                               convertPayloadToFile(componentToscaArtifactPayload.left().value(), file);
+                       }
+               } catch (Exception e) {
+                       // TODO Auto-generated catch block
+                       e.printStackTrace();
+               }
+       }
+       
+//     public static void convertPayloadToFile(String payload, File file, boolean isBased64, boolean isSdcFormat) throws IOException{
+//             
+//             Gson gson = new Gson();
+//             byte[] byteArray = null;
+//             Map<String, String> fromJson;
+//             @SuppressWarnings("unchecked")
+//             String string = null;// = fromJson.get("base64Contents").toString();
+//             if(isSdcFormat){
+//                     fromJson = gson.fromJson(payload, Map.class);
+//                     string = fromJson.get("base64Contents").toString();
+//             }else if (isBased64) {
+//                     byteArray = Base64.decode(string.getBytes(StandardCharsets.UTF_8));
+//             }else{
+//                     byteArray = payload.getBytes(StandardCharsets.UTF_8);
+//             }
+//             File downloadedFile = new File(file.getAbsolutePath());
+//             FileOutputStream fos = new FileOutputStream(downloadedFile);
+//             fos.write(byteArray);
+//             fos.flush();
+//             fos.close();
+//             
+//     }
+
+       public static void convertPayloadToFile(String payload, File file) throws IOException{
+               
+               Gson gson = new Gson();
+               @SuppressWarnings("unchecked")
+               Map<String, String> fromJson = gson.fromJson(payload, Map.class);
+               String string = fromJson.get("base64Contents").toString();
+               byte[] byteArray = Base64.decodeBase64(string.getBytes(StandardCharsets.UTF_8));
+               File downloadedFile = new File(file.getAbsolutePath());
+               FileOutputStream fos = new FileOutputStream(downloadedFile);
+               fos.write(byteArray);
+               fos.flush();
+               fos.close();
+       }
+       
+       
+       public static void convertPayloadToZipFile(String payload, File file) throws IOException{
+               
+               byte[] byteArray = payload.getBytes(StandardCharsets.ISO_8859_1);
+               File downloadedFile = new File(file.getAbsolutePath());
+               FileOutputStream fos = new FileOutputStream(downloadedFile);
+               fos.write(byteArray);
+               fos.flush();
+               fos.close();
+               
+               
+//             ZipOutputStream fos = null;
+//             
+//             
+//             for (Charset charset : Charset.availableCharsets().values()) {
+//                     try{
+//             //              System.out.println("How to do it???");
+//                             File downloadedFile = new File(file.getAbsolutePath() + "_" + charset +".csar");
+//                             fos = new ZipOutputStream(new FileOutputStream(downloadedFile));
+//                             byte[] byteArray = payload.getBytes(charset);
+//                             fos.write(byteArray);
+//                             fos.flush();
+//                             
+//                     }
+//                     catch(Exception e){
+//                             fos.close();
+//                     }
+//             }
+               System.out.println("");
+               
+//             ZipInputStream zipStream = new ZipInputStream(new ByteArrayInputStream(byteArray));
+//             ZipEntry entry = null;
+//             while ((entry = zipStream.getNextEntry()) != null) {
+//
+//                 String entryName = entry.getName();
+//
+//                 FileOutputStream out = new FileOutputStream(file+"/"+entryName);
+//
+//                 byte[] byteBuff = new byte[4096];
+//                 int bytesRead = 0;
+//                 while ((bytesRead = zipStream.read(byteBuff)) != -1)
+//                 {
+//                     out.write(byteBuff, 0, bytesRead);
+//                 }
+//
+//                 out.close();
+//                 zipStream.closeEntry();
+//             }
+//             zipStream.close();
+//             
+               
+               
+               
+               BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(payload.getBytes(StandardCharsets.ISO_8859_1)));
+               String filePath = file.toString();
+               BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(new File(filePath)));
+               int inByte;
+               while((inByte = bis.read()) != -1) bos.write(inByte);
+               bis.close();
+               bos.close();
+       }
+       
+       public static Either<String, RestResponse> getVendorSoftwareProduct(String vspId, User user, Boolean validateState) throws Exception {
+
+               Config config = Utils.getConfig();
+               String url = String.format(Urls.GET_VENDOR_SOFTWARE_PRODUCT, config.getCatalogBeHost(), config.getCatalogBePort(), vspId);
+               String userId = user.getUserId();
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+               headersMap.put(HttpHeaderEnum.X_ECOMP_REQUEST_ID_HEADER.getValue(), "123456");
+               headersMap.put(HttpHeaderEnum.ACCEPT.getValue(), "*/*");
+               headersMap.put("Accept-Encoding", "gzip, deflate, br");
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendGet(url, headersMap);
+               if (validateState) {
+                       assertTrue("add property to resource failed: " + response.getResponseMessage(), response.getErrorCode() == BaseRestUtils.STATUS_CODE_SUCCESS);
+               }
+               if (response.getErrorCode() != BaseRestUtils.STATUS_CODE_SUCCESS && response.getResponse().getBytes() == null && response.getResponse().getBytes().length == 0) {
+                       return Either.right(response);
+               }
+               return Either.left(response.getResponse());
+               
+       }
+       
+       public static ResourceReqDetails prepareOnboardedResourceDetailsBeforeCreate(VendorSoftwareProductObject vendorSoftwareProductObject, String vspName) {
+
+               List<String> tags = new ArrayList<>();
+               tags.add(vspName);
+               ResourceReqDetails resourceDetails = new ResourceReqDetails();
+               resourceDetails.setCsarUUID(vendorSoftwareProductObject.getVspId());
+               resourceDetails.setCsarVersion("1.0");
+               resourceDetails.setName(vspName);
+               resourceDetails.setTags(tags);
+               resourceDetails.setDescription(vendorSoftwareProductObject.getDescription());
+               resourceDetails.addCategoryChain(ResourceCategoryEnum.GENERIC_DATABASE.getCategory(), ResourceCategoryEnum.GENERIC_DATABASE.getSubCategory());
+               resourceDetails.setVendorName(vendorSoftwareProductObject.getVendorName());
+               resourceDetails.setVendorRelease("1.0");
+               resourceDetails.setResourceType("VF");
+               resourceDetails.setResourceVendorModelNumber("666");
+               resourceDetails.setContactId(vendorSoftwareProductObject.getAttContact());
+               resourceDetails.setIcon("defaulticon");
+               
+               return resourceDetails;
+       }
+       
+       public static ServiceReqDetails prepareServiceDetailsBeforeCreate(User user) {
+
+               ServiceReqDetails serviceDetails = ElementFactory.getDefaultService(ServiceCategoriesEnum.NETWORK_L4, user);
+               serviceDetails.setServiceType("MyServiceType");
+               serviceDetails.setServiceRole("MyServiceRole");
+               serviceDetails.setNamingPolicy("MyServiceNamingPolicy");
+               serviceDetails.setEcompGeneratedNaming(false);
+               
+               return serviceDetails;
+       }
+}
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtils.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/OnboardingUtils.java
new file mode 100644 (file)
index 0000000..a1838b6
--- /dev/null
@@ -0,0 +1,799 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.utils.general;
+
+import com.aventstack.extentreports.Status;
+import com.clearspring.analytics.util.Pair;
+import org.apache.commons.io.IOUtils;
+import org.apache.http.HttpEntity;
+import org.apache.http.client.ClientProtocolException;
+import org.apache.http.client.methods.CloseableHttpResponse;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.entity.mime.MultipartEntityBuilder;
+import org.apache.http.entity.mime.content.FileBody;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.apache.http.impl.client.HttpClients;
+import org.json.JSONException;
+import org.json.JSONObject;
+import org.json.simple.JSONArray;
+import org.json.simple.JSONValue;
+import org.openecomp.sdc.be.model.User;
+import org.openecomp.sdc.ci.tests.api.ComponentBaseTest;
+import org.openecomp.sdc.ci.tests.api.ExtentTestActions;
+import org.openecomp.sdc.ci.tests.config.Config;
+
+import org.openecomp.sdc.ci.tests.datatypes.AmdocsLicenseMembers;
+import org.openecomp.sdc.ci.tests.datatypes.HeatMetaFirstLevelDefinition;
+
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpHeaderEnum;
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpRequest;
+import org.openecomp.sdc.ci.tests.datatypes.http.RestResponse;
+import org.openecomp.sdc.ci.tests.execute.devCI.ArtifactFromCsar;
+
+import org.openecomp.sdc.ci.tests.utils.Utils;
+import org.openecomp.sdc.ci.tests.utils.rest.ResponseParser;
+
+import org.testng.Assert;
+
+import java.io.*;
+import java.nio.file.FileSystems;
+import java.util.*;
+import java.util.stream.Collectors;
+
+import static org.testng.AssertJUnit.assertEquals;
+
+public class OnboardingUtils {
+
+       protected static List<String> exludeVnfList = Arrays.asList("2016-197_vscp_vscp-fw_1610_e2e.zip", "2016-281_vProbes_BE_11_1_f_30_1610_e2e.zip", 
+                       "2016-282_vProbes_FE_11_1_f_30_1610_e2e.zip", "2016-044_vfw_fnat_30_1607_e2e.zip", "2017-376_vMOG_11_1.zip", "vMOG.zip", 
+                       
+                       
+                       "vMRF_USP_AIC3.0_1702.zip", "2016-211_vprobesbe_vprobes_be_30_1610_e2e.zip", "2016-005_vprobesfe_vprobes_fe_30_1607_e2e.zip", 
+                       "vMRF_RTT.zip", "2016-006_vvm_vvm_30_1607_e2e.zip", "2016-001_vvm_vvm_30_1607_e2e.zip");
+
+       protected static List<String> exludeVnfListForToscaParser = Arrays.asList("2016-043_vsaegw_fdnt_30_1607_e2e.zip", "vIRC_CC.zip", 
+                       "2016-045_vlb_lmsp_30_1607_e2e.zip", "2016-050_vdns_vmdns_30_1607_e2e.zip", 
+                       "2016-247_mns_mns_30_1610_e2e.zip", "2016-044_vfw_fcgi_30_1607_e2e.zip");
+       
+       public OnboardingUtils() {
+       }
+
+       public static Pair<String, Map<String, String>> createVendorSoftwareProduct(String HeatFileName, String filepath, User user, AmdocsLicenseMembers amdocsLicenseMembers)
+                       throws Exception {
+               Pair<String, Map<String, String>> pair = createVSP(HeatFileName, filepath, user, amdocsLicenseMembers);
+               
+               String vspid = pair.right.get("vspId");
+                               
+               prepareVspForUse(user, vspid);
+               
+               return pair;
+       }
+
+       public static void prepareVspForUse(User user, String vspid) throws Exception {
+               RestResponse checkin = checkinVendorSoftwareProduct(vspid, user);
+               assertEquals("did not succeed to checking new VSP", 200, checkin.getErrorCode().intValue());
+
+               RestResponse submit = submitVendorSoftwareProduct(vspid, user);
+               assertEquals("did not succeed to submit new VSP", 200, submit.getErrorCode().intValue());
+
+               RestResponse createPackage = createPackageOfVendorSoftwareProduct(vspid, user);
+               assertEquals("did not succeed to create package of new VSP ", 200, createPackage.getErrorCode().intValue());
+
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Succeeded in creating the vendor software product");
+       }
+
+       public static Pair<String, Map<String, String>> createVSP(String HeatFileName, String filepath, User user, AmdocsLicenseMembers amdocsLicenseMembers) throws Exception {
+               String vspName = handleFilename(HeatFileName);
+               
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Starting to create the vendor software product");
+               
+               Pair<RestResponse, Map<String, String>> createNewVspPair = createNewVendorSoftwareProduct(vspName, amdocsLicenseMembers, user);
+               RestResponse createNewVendorSoftwareProduct = createNewVspPair.left;
+               assertEquals("did not succeed to create new VSP", 200,createNewVendorSoftwareProduct.getErrorCode().intValue());
+               String vspid = ResponseParser.getValueFromJsonResponse(createNewVendorSoftwareProduct.getResponse(), "vspId");
+               String componentId = ResponseParser.getValueFromJsonResponse(createNewVendorSoftwareProduct.getResponse(), "componentId");
+               
+               Map<String, String> vspMeta = createNewVspPair.right;
+               Map<String, String> vspObject = new HashMap<String, String>();
+               Iterator<String> iterator = vspMeta.keySet().iterator();
+               while(iterator.hasNext()){
+                       Object key = iterator.next();
+                       Object value = vspMeta.get(key);
+                       vspObject.put(key.toString(), value.toString());
+               }
+               vspObject.put("vspId", vspid);
+               vspObject.put("componentId", componentId);
+               vspObject.put("vendorName", amdocsLicenseMembers.getVendorLicenseName());
+               vspObject.put("attContact", user.getUserId());
+               
+               RestResponse uploadHeatPackage = uploadHeatPackage(filepath, HeatFileName, vspid, user);
+               assertEquals("did not succeed to upload HEAT package", 200, uploadHeatPackage.getErrorCode().intValue());
+               
+               RestResponse validateUpload = validateUpload(vspid, user);
+               assertEquals("did not succeed to validate upload process", 200, validateUpload.getErrorCode().intValue());
+               
+               Pair<String, Map<String, String>> pair = new Pair<String, Map<String, String>>(vspName, vspObject);
+               
+               return pair;
+       }
+       
+       public static void updateVspWithVfcArtifacts(String filepath, String vspId, String updatedSnmpPoll, String updatedSnmpTrap, String componentId, User user) throws Exception{
+               RestResponse checkout = checkoutVendorSoftwareProduct(vspId, user);
+               assertEquals("did not succeed to checkout new VSP", 200, checkout.getErrorCode().intValue());
+               ExtentTestActions.log(Status.INFO, "Deleting SNMP POLL");
+               deleteSnmpArtifact(componentId, vspId, user, SnmpTypeEnum.SNMP_POLL);
+               ExtentTestActions.log(Status.INFO, "Deleting SNMP TRAP");
+               deleteSnmpArtifact(componentId, vspId, user, SnmpTypeEnum.SNMP_TRAP);
+               addVFCArtifacts(filepath, updatedSnmpPoll, updatedSnmpTrap, vspId, user, componentId);
+               prepareVspForUse(user, vspId);
+       }
+       
+       public static String updateVendorSoftwareProduct(String vspId, String HeatFileName, String filepath, User user)
+                       throws Exception, Throwable {
+               String vspName = handleFilename(HeatFileName);
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Starting to update the vendor software product");
+
+               RestResponse checkout = checkoutVendorSoftwareProduct(vspId, user);
+               assertEquals("did not succeed to checkout new VSP", 200, checkout.getErrorCode().intValue());
+
+               RestResponse uploadHeatPackage = uploadHeatPackage(filepath, HeatFileName, vspId, user);
+               assertEquals("did not succeed to upload HEAT package", 200, uploadHeatPackage.getErrorCode().intValue());
+               
+               RestResponse validateUpload = validateUpload(vspId, user);
+               assertEquals("did not succeed to validate upload process", 200, validateUpload.getErrorCode().intValue());
+               
+               RestResponse checkin = checkinVendorSoftwareProduct(vspId, user);
+               assertEquals("did not succeed to checking VSP", 200, checkin.getErrorCode().intValue());
+
+
+               RestResponse submit = submitVendorSoftwareProduct(vspId, user);
+               assertEquals("did not succeed to submit VSP", 200, submit.getErrorCode().intValue());
+
+               RestResponse createPackage = createPackageOfVendorSoftwareProduct(vspId, user);
+               assertEquals("did not succeed to update package of VSP ", 200, createPackage.getErrorCode().intValue());
+
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Succeeded in updating the vendor software product");
+
+               return vspName;
+       }
+
+       public static String handleFilename(String heatFileName) {
+               final String namePrefix = "ciVFOnboarded-";
+               final String nameSuffix = "-" + getShortUUID();
+
+               String subHeatFileName = heatFileName.substring(0, heatFileName.lastIndexOf("."));
+
+               if ((namePrefix + subHeatFileName + nameSuffix).length() >= 50) {
+                       subHeatFileName = subHeatFileName.substring(0, 50 - namePrefix.length() - nameSuffix.length());
+               }
+
+               if (subHeatFileName.contains("(") || subHeatFileName.contains(")")) {
+                       subHeatFileName = subHeatFileName.replace("(", "-");
+                       subHeatFileName = subHeatFileName.replace(")", "-");
+               }
+
+               String vnfName = namePrefix + subHeatFileName + nameSuffix;
+               return vnfName;
+       }
+       
+       public static String addVFCArtifacts(String filepath, String snmpPoll, String snmpTrap, String vspid, User user, String vspComponentId) throws Exception{
+               vspComponentId = (vspComponentId == null) ? getVSPComponentId(vspid, user) : vspComponentId;
+               if (vspComponentId != null){
+                       if (snmpPoll != null){
+                               ExtentTestActions.log(Status.INFO, "Adding VFC artifact of type SNMP POLL with the file " + snmpPoll);
+                               RestResponse uploadSnmpPollArtifact = uploadSnmpPollArtifact(filepath, snmpPoll, vspid, user, vspComponentId);
+                               assertEquals("Did not succeed to add SNMP POLL", 200, uploadSnmpPollArtifact.getErrorCode().intValue());
+                       }
+                       if (snmpTrap != null){
+                               ExtentTestActions.log(Status.INFO, "Adding VFC artifact of type SNMP TRAP with the file " + snmpTrap);
+                               RestResponse uploadSnmpTrapArtifact = uploadSnmpTrapArtifact(filepath, snmpTrap, vspid, user, vspComponentId);
+                               assertEquals("Did not succeed to add SNMP TRAP", 200, uploadSnmpTrapArtifact.getErrorCode().intValue());
+                       }
+               }
+               
+               return vspComponentId;
+       }
+       
+       public static String addVFCArtifacts(String filepath, String snmpPoll, String snmpTrap, String vspid, User user) throws Exception{
+               return addVFCArtifacts(filepath, snmpPoll, snmpTrap, vspid, user, null);
+       }
+
+       private static RestResponse uploadSnmpPollArtifact(String filepath, String zipArtifact, String vspid, User user,
+                       String vspComponentId) throws FileNotFoundException, IOException, ClientProtocolException {
+               Config config = Utils.getConfig();
+               String snmpPollUrl = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/components/%s/monitors/snmp/upload", 
+                               config.getCatalogBeHost(),config.getCatalogBePort(), vspid, vspComponentId);
+               return uploadFile(filepath, zipArtifact, snmpPollUrl, user);
+       }
+       
+       private static RestResponse uploadSnmpTrapArtifact(String filepath, String zipArtifact, String vspid, User user,
+                       String vspComponentId) throws FileNotFoundException, IOException, ClientProtocolException {
+               Config config = Utils.getConfig();
+               String snmpTrapUrl = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/components/%s/monitors/snmp-trap/upload", 
+                               config.getCatalogBeHost(),config.getCatalogBePort(), vspid, vspComponentId);
+               return uploadFile(filepath, zipArtifact, snmpTrapUrl, user);
+       }
+       
+       private static RestResponse deleteSnmpArtifact(String componentId, String vspId, User user, SnmpTypeEnum snmpType) throws Exception
+       {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/components/%s/monitors/%s", 
+                               config.getCatalogBeHost(),config.getCatalogBePort(), vspId, componentId, snmpType.getValue());
+               String userId = user.getUserId();
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendDelete(url, headersMap);
+               return response;
+       }
+       
+       
+
+       private static String getVSPComponentId(String vspid, User user) throws Exception, JSONException {
+               RestResponse components = getVSPComponents(vspid, user);
+               String response = components.getResponse();
+               Map<String, Object> responseMap = (Map<String, Object>) JSONValue.parse(response);
+               JSONArray results = (JSONArray)responseMap.get("results");
+               for (Object res : results){
+                       Map<String, Object> compMap= (Map<String, Object>) JSONValue.parse(res.toString());
+                       String componentId = compMap.get("id").toString();
+                       return componentId;
+               }
+               return null;
+       }
+       
+       private static RestResponse getVSPComponents(String vspid, User user) throws Exception{
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/components", config.getCatalogBeHost(),config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendGet(url, headersMap);
+               return response;
+       }
+
+       public static AmdocsLicenseMembers createVendorLicense(User user) throws Exception {
+               
+               AmdocsLicenseMembers amdocsLicenseMembers;
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Starting to create the vendor license");
+               String vendorLicenseName = "ciLicense" + getShortUUID();
+               RestResponse vendorLicenseResponse = createVendorLicenseModels_1(vendorLicenseName, user);
+               assertEquals("did not succeed to create vendor license model", 200, vendorLicenseResponse.getErrorCode().intValue());
+               String vendorId = ResponseParser.getValueFromJsonResponse(vendorLicenseResponse.getResponse(), "value");
+
+               RestResponse vendorKeyGroupsResponse = createVendorKeyGroups_2(vendorId, user);
+               assertEquals("did not succeed to create vendor key groups", 200, vendorKeyGroupsResponse.getErrorCode().intValue());
+               String keyGroupId = ResponseParser.getValueFromJsonResponse(vendorKeyGroupsResponse.getResponse(), "value");
+
+               RestResponse vendorEntitlementPool = createVendorEntitlementPool_3(vendorId, user);
+               assertEquals("did not succeed to create vendor entitlement pool", 200, vendorEntitlementPool.getErrorCode().intValue());
+               String entitlementPoolId = ResponseParser.getValueFromJsonResponse(vendorEntitlementPool.getResponse(), "value");
+
+               RestResponse vendorLicenseFeatureGroups = createVendorLicenseFeatureGroups_4(vendorId, keyGroupId, entitlementPoolId, user);
+               assertEquals("did not succeed to create vendor license feature groups", 200, vendorLicenseFeatureGroups.getErrorCode().intValue());
+               String featureGroupId = ResponseParser.getValueFromJsonResponse(vendorLicenseFeatureGroups.getResponse(), "value");
+
+               RestResponse vendorLicenseAgreement = createVendorLicenseAgreement_5(vendorId, featureGroupId, user);
+               assertEquals("did not succeed to create vendor license agreement", 200, vendorLicenseAgreement.getErrorCode().intValue());
+               String vendorLicenseAgreementId = ResponseParser.getValueFromJsonResponse(vendorLicenseAgreement.getResponse(), "value");
+
+               RestResponse checkinVendorLicense = checkinVendorLicense(vendorId, user);
+               assertEquals("did not succeed to checkin vendor license", 200, checkinVendorLicense.getErrorCode().intValue());
+
+               RestResponse submitVendorLicense = submitVendorLicense(vendorId, user);
+               assertEquals("did not succeed to submit vendor license", 200, submitVendorLicense.getErrorCode().intValue());
+
+               ComponentBaseTest.getExtendTest().log(Status.INFO, "Succeeded in creating the vendor license");
+
+               amdocsLicenseMembers = new AmdocsLicenseMembers(vendorId, vendorLicenseName, vendorLicenseAgreementId, featureGroupId);
+               
+               return amdocsLicenseMembers;
+       }
+
+       private static String getShortUUID() {
+               return UUID.randomUUID().toString().split("-")[0];
+       }
+
+       private static RestResponse actionOnComponent(String vspid, String action, String onboardComponent, User user)
+                       throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/" + onboardComponent + "/%s/versions/0.1/actions",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               JSONObject jObject = new JSONObject();
+               jObject.put("action", action);
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPut(url, jObject.toString(), headersMap);
+               return response;
+       }
+
+       public static RestResponse checkinVendorLicense(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Checkin", "vendor-license-models", user);
+       }
+
+       public static RestResponse submitVendorLicense(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Submit", "vendor-license-models", user);
+       }
+
+       public static RestResponse createVendorLicenseModels_1(String name, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-license-models", config.getCatalogBeHost(),
+                               config.getCatalogBePort());
+               String userId = user.getUserId();
+
+               JSONObject jObject = new JSONObject();
+               jObject.put("vendorName", name);
+               jObject.put("description", "new vendor license model");
+               jObject.put("iconRef", "icon");
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPost(url, jObject.toString(), headersMap);
+               return response;
+
+       }
+
+       public static RestResponse createVendorLicenseAgreement_5(String vspid, String featureGroupId, User user)
+                       throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-license-models/%s/versions/0.1/license-agreements",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               JSONObject licenseTermpObject = new JSONObject();
+               licenseTermpObject.put("choice", "Fixed_Term");
+               licenseTermpObject.put("other", "");
+
+               JSONObject jObjectBody = new JSONObject();
+               jObjectBody.put("name", "abc");
+               jObjectBody.put("description", "new vendor license agreement");
+               jObjectBody.put("requirementsAndConstrains", "abc");
+               jObjectBody.put("licenseTerm", licenseTermpObject);
+               jObjectBody.put("addedFeatureGroupsIds", Arrays.asList(featureGroupId).toArray());
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPost(url, jObjectBody.toString(), headersMap);
+               return response;
+       }
+
+       public static RestResponse createVendorLicenseFeatureGroups_4(String vspid, String licenseKeyGroupId,
+                       String entitlementPoolId, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-license-models/%s/versions/0.1/feature-groups",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               JSONObject jObject = new JSONObject();
+               jObject.put("name", "xyz");
+               jObject.put("description", "new vendor license feature groups");
+               jObject.put("partNumber", "123abc456");
+               jObject.put("manufacturerReferenceNumber", "5");
+               jObject.put("addedLicenseKeyGroupsIds", Arrays.asList(licenseKeyGroupId).toArray());
+               jObject.put("addedEntitlementPoolsIds", Arrays.asList(entitlementPoolId).toArray());
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPost(url, jObject.toString(), headersMap);
+               return response;
+
+       }
+
+       public static RestResponse createVendorEntitlementPool_3(String vspid, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-license-models/%s/versions/0.1/entitlement-pools",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               JSONObject jEntitlementMetricObject = new JSONObject();
+               jEntitlementMetricObject.put("choice", "CPU");
+               jEntitlementMetricObject.put("other", "");
+
+               JSONObject jAggregationFunctionObject = new JSONObject();
+               jAggregationFunctionObject.put("choice", "Peak");
+               jAggregationFunctionObject.put("other", "");
+
+               JSONObject jOperationalScope = new JSONObject();
+               jOperationalScope.put("choices", Arrays.asList("Availability_Zone").toArray());
+               jOperationalScope.put("other", "");
+
+               JSONObject jTimeObject = new JSONObject();
+               jTimeObject.put("choice", "Hour");
+               jTimeObject.put("other", "");
+
+               JSONObject jObjectBody = new JSONObject();
+               jObjectBody.put("name", "def"+ getShortUUID());
+               jObjectBody.put("description", "new vendor license entitlement pool");
+               jObjectBody.put("thresholdValue", "23");
+               jObjectBody.put("thresholdUnits", "Absolute");
+               jObjectBody.put("entitlementMetric", jEntitlementMetricObject);
+               jObjectBody.put("increments", "abcd");
+               jObjectBody.put("aggregationFunction", jAggregationFunctionObject);
+               jObjectBody.put("operationalScope", jOperationalScope);
+               jObjectBody.put("time", jTimeObject);
+               jObjectBody.put("manufacturerReferenceNumber", "123aaa");
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPost(url, jObjectBody.toString(), headersMap);
+               return response;
+       }
+
+       public static RestResponse createVendorKeyGroups_2(String vspid, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-license-models/%s/versions/0.1/license-key-groups",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               String userId = user.getUserId();
+
+               JSONObject jOperationalScope = new JSONObject();
+               jOperationalScope.put("choices", Arrays.asList("Tenant").toArray());
+               jOperationalScope.put("other", "");
+
+               JSONObject jObjectBody = new JSONObject();
+               jObjectBody.put("name", "keyGroup" + getShortUUID());
+               jObjectBody.put("description", "new vendor license key group");
+               jObjectBody.put("operationalScope", jOperationalScope);
+               jObjectBody.put("type", "Universal");
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+
+               HttpRequest http = new HttpRequest();
+               RestResponse response = http.httpSendPost(url, jObjectBody.toString(), headersMap);
+               return response;
+       }
+
+       public static Pair<RestResponse, Map<String, String>> createNewVendorSoftwareProduct(String name, AmdocsLicenseMembers amdocsLicenseMembers, User user) throws Exception {
+               Map<String, String> vspMetadta = new HashMap<String, String>();
+               
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products",
+                               config.getCatalogBeHost(), config.getCatalogBePort());
+
+               String userId = user.getUserId();
+
+               JSONObject jlicensingDataObj = new JSONObject();
+               jlicensingDataObj.put("licenseAgreement", amdocsLicenseMembers.getVendorLicenseAgreementId());
+               jlicensingDataObj.put("featureGroups", Arrays.asList(amdocsLicenseMembers.getFeatureGroupId()).toArray());
+               
+               JSONObject jlicensingVersionObj = new JSONObject();
+               jlicensingVersionObj.put("id", "1.0");
+               jlicensingVersionObj.put("label", "1.0");
+
+               JSONObject jObject = new JSONObject();
+               jObject.put("name", name);
+               jObject.put("description", "new VSP description");
+               jObject.put("category", "resourceNewCategory.generic");
+               jObject.put("subCategory", "resourceNewCategory.generic.database");
+               jObject.put("onboardingMethod", "HEAT");
+               jObject.put("licensingVersion", jlicensingVersionObj);
+               jObject.put("vendorName", amdocsLicenseMembers.getVendorLicenseName());
+               jObject.put("vendorId", amdocsLicenseMembers.getVendorId());
+               jObject.put("icon", "icon");
+               jObject.put("licensingData", jlicensingDataObj);
+               
+               vspMetadta.put("description", jObject.getString("description"));
+               vspMetadta.put("category", jObject.getString("category"));
+               vspMetadta.put("subCategory", jObject.getString("subCategory").split("\\.")[2]);
+               
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+               HttpRequest http = new HttpRequest();
+
+               RestResponse response = http.httpSendPost(url, jObject.toString(), headersMap);
+               return new Pair<RestResponse, Map<String, String>>(response, vspMetadta);
+       }
+       
+       public static RestResponse validateUpload(String vspid, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/orchestration-template-candidate/process",
+                               config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+
+               String userId = user.getUserId();
+
+               Map<String, String> headersMap = prepareHeadersMap(userId);
+               HttpRequest http = new HttpRequest();
+               
+               String body =null;
+
+               RestResponse response = http.httpSendPut(url, body, headersMap);
+
+               return response;
+       }
+
+       public static RestResponse uploadHeatPackage(String filepath, String filename, String vspid, User user) throws Exception {
+               Config config = Utils.getConfig();
+               String url = String.format("http://%s:%s/onboarding-api/v1.0/vendor-software-products/%s/versions/0.1/orchestration-template-candidate", config.getCatalogBeHost(), config.getCatalogBePort(), vspid);
+               return uploadFile(filepath, filename, url, user);
+       }
+
+       private static RestResponse uploadFile(String filepath, String filename, String url, User user)
+                       throws FileNotFoundException, IOException, ClientProtocolException {
+               CloseableHttpResponse response = null;
+
+               MultipartEntityBuilder mpBuilder = MultipartEntityBuilder.create();
+               mpBuilder.addPart("upload", new FileBody(getTestZipFile(filepath, filename)));
+
+               Map<String, String> headersMap = prepareHeadersMap(user.getUserId());
+               headersMap.put(HttpHeaderEnum.CONTENT_TYPE.getValue(), "multipart/form-data");
+
+               CloseableHttpClient client = HttpClients.createDefault();
+               try {
+                       HttpPost httpPost = new HttpPost(url);
+                       RestResponse restResponse = new RestResponse();
+
+                       Iterator<String> iterator = headersMap.keySet().iterator();
+                       while (iterator.hasNext()) {
+                               String key = iterator.next();
+                               String value = headersMap.get(key);
+                               httpPost.addHeader(key, value);
+                       }
+                       httpPost.setEntity(mpBuilder.build());
+                       response = client.execute(httpPost);
+                       HttpEntity entity = response.getEntity();
+                       String responseBody = null;
+                       if (entity != null) {
+                               InputStream instream = entity.getContent();
+                               StringWriter writer = new StringWriter();
+                               IOUtils.copy(instream, writer);
+                               responseBody = writer.toString();
+                               try {
+
+                               } finally {
+                                       instream.close();
+                               }
+                       }
+
+                       restResponse.setErrorCode(response.getStatusLine().getStatusCode());
+                       restResponse.setResponse(responseBody);
+
+                       return restResponse;
+
+               } finally {
+                       closeResponse(response);
+                       closeHttpClient(client);
+
+               }
+       }
+
+       private static void closeResponse(CloseableHttpResponse response) {
+               try {
+                       if (response != null) {
+                               response.close();
+                       }
+               } catch (IOException e) {
+                       System.out.println(String.format("failed to close client or response: %s", e.getMessage()));
+               }
+       }
+
+       private static void closeHttpClient(CloseableHttpClient client) {
+               try {
+                       if (client != null) {
+                               client.close();
+                       }
+               } catch (IOException e) {
+                       System.out.println(String.format("failed to close client or response: %s", e.getMessage()));
+               }
+       }
+
+       private static File getTestZipFile(String filepath, String filename) throws IOException {
+               Config config = Utils.getConfig();
+               String sourceDir = config.getImportResourceTestsConfigDir();
+               java.nio.file.Path filePath = FileSystems.getDefault().getPath(filepath + File.separator + filename);
+               return filePath.toFile();
+       }
+
+       public static RestResponse checkinVendorSoftwareProduct(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Checkin", "vendor-software-products", user);
+       }
+       
+       private static RestResponse checkoutVendorSoftwareProduct(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Checkout", "vendor-software-products", user);
+       }
+
+       public static RestResponse submitVendorSoftwareProduct(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Submit", "vendor-software-products", user);
+       }
+
+       public static RestResponse createPackageOfVendorSoftwareProduct(String vspid, User user) throws Exception {
+               return actionOnComponent(vspid, "Create_Package", "vendor-software-products", user);
+       }
+
+       protected static Map<String, String> prepareHeadersMap(String userId) {
+               Map<String, String> headersMap = new HashMap<String, String>();
+               headersMap.put(HttpHeaderEnum.CONTENT_TYPE.getValue(), "application/json");
+               headersMap.put(HttpHeaderEnum.ACCEPT.getValue(), "application/json");
+               headersMap.put(HttpHeaderEnum.USER_ID.getValue(), userId);
+               return headersMap;
+       }
+
+       
+//     private static void importUpdateVSP(Pair<String, Map<String, String>> vsp, boolean isUpdate) throws Exception{
+//             String vspName = vsp.left;
+//             Map<String, String> vspMetadata = vsp.right;
+//             boolean vspFound = HomePage.searchForVSP(vspName);
+//
+//             if (vspFound){
+//
+//                     List<WebElement> elemenetsFromTable = HomePage.getElemenetsFromTable();
+////                   WebDriverWait wait = new WebDriverWait(GeneralUIUtils.getDriver(), 30);
+////                   WebElement findElement = wait.until(ExpectedConditions.visibilityOf(elemenetsFromTable.get(1)));
+////                   findElement.click();
+//                     elemenetsFromTable.get(1).click();
+//                     GeneralUIUtils.waitForLoader();
+//
+//                     if (isUpdate){
+//                             GeneralUIUtils.clickOnElementByTestId(DataTestIdEnum.ImportVfRepository.UPDATE_VSP.getValue());
+//
+//                     }
+//                     else{
+//                             GeneralUIUtils.clickOnElementByTestId(DataTestIdEnum.ImportVfRepository.IMPORT_VSP.getValue());
+//                     }
+//
+//                     String lifeCycleState = ResourceGeneralPage.getLifeCycleState();
+//                     boolean needCheckout = lifeCycleState.equals(LifeCycleStateEnum.CHECKIN.getValue()) || lifeCycleState.equals(LifeCycleStateEnum.CERTIFIED.getValue());
+//                     if (needCheckout)
+//                     {
+//                             try {
+//                                     ResourceGeneralPage.clickCheckoutButton();
+//                                     Assert.assertTrue(ResourceGeneralPage.getLifeCycleState().equals(LifeCycleStateEnum.CHECKOUT.getValue()), "Did not succeed to checkout");
+//
+//                             } catch (Exception e) {
+//                                     ExtentTestActions.log(Status.ERROR, "Did not succeed to checkout");
+//                                     e.printStackTrace();
+//                             }
+//                             GeneralUIUtils.waitForLoader();
+//                     }
+//
+//                     //Metadata verification
+//                     VfVerificator.verifyOnboardedVnfMetadata(vspName, vspMetadata);
+//
+//                     ExtentTestActions.log(Status.INFO, "Clicking create/update VNF");
+//                     String duration = GeneralUIUtils.getActionDuration(() -> waitUntilVnfCreated());
+//                 ExtentTestActions.log(Status.INFO, "Succeeded in importing/updating " + vspName, duration);
+//             }
+//             else{
+//                     Assert.fail("Did not find VSP named " + vspName);
+//             }
+//     }
+
+//     private static void waitUntilVnfCreated() {
+//             GeneralUIUtils.clickOnElementByTestIdWithoutWait(DataTestIdEnum.GeneralElementsEnum.CREATE_BUTTON.getValue());
+//             GeneralUIUtils.waitForLoader(60*10);
+//             GeneralUIUtils.waitForAngular();
+//             GeneralUIUtils.getWebElementByTestID(DataTestIdEnum.GeneralElementsEnum.CHECKIN_BUTTON.getValue());
+//     }
+//
+//     public static void updateVSP(Pair<String, Map<String, String>> vsp) throws Exception{
+//             ExtentTestActions.log(Status.INFO, "Updating VSP " + vsp.left);
+//             importUpdateVSP(vsp, true);
+//     }
+//
+//     public static void importVSP(Pair<String, Map<String, String>> vsp) throws Exception{
+//             ExtentTestActions.log(Status.INFO, "Importing VSP " + vsp.left);
+//             importUpdateVSP(vsp, false);
+//     }
+//
+//     public static void updateVnfAndValidate(String filepath, Pair<String, Map<String, String>> vsp, String updatedVnfFile, User user) throws Exception, Throwable {
+//             ExtentTestActions.log(Status.INFO, String.format("Going to update the VNF with %s......", updatedVnfFile));
+//             System.out.println(String.format("Going to update the VNF with %s......", updatedVnfFile));
+//
+//             Map<String, String> vspMap = vsp.right;
+//             String vspId = vspMap.get("vspId");
+//
+//             updateVendorSoftwareProduct(vspId, updatedVnfFile, filepath, user);
+//             HomePage.showVspRepository();
+//             updateVSP(vsp);
+//             ResourceGeneralPage.getLeftMenu().moveToDeploymentArtifactScreen();
+//             DeploymentArtifactPage.verifyArtifactsExistInTable(filepath, updatedVnfFile);
+//     }
+//
+//     public static Pair<String, Map<String, String>> onboardAndValidate(String filepath, String vnfFile, User user) throws Exception {
+//             ExtentTestActions.log(Status.INFO, String.format("Going to onboard the VNF %s", vnfFile));
+//             System.out.println(String.format("Going to onboard the VNF %s", vnfFile));
+//
+//             AmdocsLicenseMembers amdocsLicenseMembers = createVendorLicense(user);
+//             Pair<String, Map<String, String>> createVendorSoftwareProduct = createVendorSoftwareProduct(vnfFile, filepath, user, amdocsLicenseMembers);
+//             String vspName = createVendorSoftwareProduct.left;
+//
+//             DownloadManager.downloadCsarByNameFromVSPRepository(vspName, createVendorSoftwareProduct.right.get("vspId"));
+//             File latestFilefromDir = FileHandling.getLastModifiedFileNameFromDir();
+//
+//             ExtentTestActions.log(Status.INFO, String.format("Searching for onboarded %s", vnfFile));
+//             HomePage.showVspRepository();
+//             ExtentTestActions.log(Status.INFO,String.format("Going to import %s", vnfFile.substring(0, vnfFile.indexOf("."))));
+//             importVSP(createVendorSoftwareProduct);
+//
+//             ResourceGeneralPage.getLeftMenu().moveToDeploymentArtifactScreen();
+//
+//             // Verify deployment artifacts
+//             Map<String, Object> combinedMap = ArtifactFromCsar.combineHeatArtifacstWithFolderArtifacsToMap(latestFilefromDir.getAbsolutePath());
+//
+//             LinkedList<HeatMetaFirstLevelDefinition> deploymentArtifacts = ((LinkedList<HeatMetaFirstLevelDefinition>) combinedMap.get("Deployment"));
+//             ArtifactsCorrelationManager.addVNFartifactDetails(vspName, deploymentArtifacts);
+//
+//             List<String> heatEnvFilesFromCSAR = deploymentArtifacts.stream().filter(e -> e.getType().equals("HEAT_ENV")).
+//                                                                                                                                              map(e -> e.getFileName()).
+//                                                                                                                                              collect(Collectors.toList());
+//
+//             validateDeploymentArtifactsVersion(deploymentArtifacts, heatEnvFilesFromCSAR);
+//
+//             DeploymentArtifactPage.verifyArtifactsExistInTable(filepath, vnfFile);
+//             return createVendorSoftwareProduct;
+//     }
+//
+//     public static void validateDeploymentArtifactsVersion(LinkedList<HeatMetaFirstLevelDefinition> deploymentArtifacts,
+//                     List<String> heatEnvFilesFromCSAR) {
+//             String artifactVersion;
+//             String artifactName;
+//
+//             for(HeatMetaFirstLevelDefinition deploymentArtifact: deploymentArtifacts) {
+//                     artifactVersion = "1";
+//
+//                     if(deploymentArtifact.getType().equals("HEAT_ENV")) {
+//                             continue;
+//                     } else if(deploymentArtifact.getFileName().contains(".")) {
+//                             artifactName = deploymentArtifact.getFileName().trim().substring(0, deploymentArtifact.getFileName().lastIndexOf("."));
+//                     } else {
+//                             artifactName = deploymentArtifact.getFileName().trim();
+//                     }
+//
+//                     if (heatEnvFilesFromCSAR.contains(artifactName + ".env")){
+//                             artifactVersion = "2";
+//                     }
+//                     ArtifactUIUtils.validateArtifactNameVersionType(artifactName, artifactVersion, deploymentArtifact.getType());
+//             }
+//     }
+       
+       
+       /**
+        * @return
+        * The method returns VNF names list from Files directory under sdc-vnfs repository
+        */
+       public static List<String> getVnfNamesFileList() {
+               String filepath = FileHandling.getVnfRepositoryPath();
+               List<String> fileNamesFromFolder = FileHandling.getZipFileNamesFromFolder(filepath);
+               fileNamesFromFolder.removeAll(exludeVnfList);
+               return fileNamesFromFolder;
+       }
+
+       /**
+        * @return
+        * The method returns VNF names list from Files directory under sdc-vnfs repository excluding zip files that known as failed in tosca parser
+        */
+       public static List<String> getVnfNamesFileListExcludeToscaParserFailure() {
+               List<String> fileNamesFromFolder = getVnfNamesFileList();
+               fileNamesFromFolder.removeAll(exludeVnfListForToscaParser);
+               return fileNamesFromFolder;
+       }
+       
+}
+
+       
\ No newline at end of file
diff --git a/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/SnmpTypeEnum.java b/test-apis-ci/src/main/java/org/openecomp/sdc/ci/tests/utils/general/SnmpTypeEnum.java
new file mode 100644 (file)
index 0000000..7103892
--- /dev/null
@@ -0,0 +1,88 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.ci.tests.utils.general;
+
+import static org.testng.AssertJUnit.assertEquals;
+
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.StringWriter;
+import java.nio.file.FileSystems;
+import java.util.Arrays;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+import java.util.stream.Collectors;
+
+import org.apache.commons.io.IOUtils;
+import org.apache.http.HttpEntity;
+import org.apache.http.client.ClientProtocolException;
+import org.apache.http.client.methods.CloseableHttpResponse;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.entity.mime.MultipartEntityBuilder;
+import org.apache.http.entity.mime.content.FileBody;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.apache.http.impl.client.HttpClients;
+import org.json.JSONException;
+import org.json.JSONObject;
+import org.json.simple.JSONArray;
+import org.json.simple.JSONValue;
+import org.openecomp.sdc.be.model.User;
+import org.openecomp.sdc.ci.tests.config.Config;
+import org.openecomp.sdc.ci.tests.datatypes.AmdocsLicenseMembers;
+
+import org.openecomp.sdc.ci.tests.datatypes.HeatMetaFirstLevelDefinition;
+
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpHeaderEnum;
+import org.openecomp.sdc.ci.tests.datatypes.http.HttpRequest;
+import org.openecomp.sdc.ci.tests.datatypes.http.RestResponse;
+import org.openecomp.sdc.ci.tests.execute.devCI.ArtifactFromCsar;
+
+
+import org.openecomp.sdc.ci.tests.utils.Utils;
+import org.openecomp.sdc.ci.tests.utils.rest.ResponseParser;
+
+import org.testng.Assert;
+
+import com.aventstack.extentreports.Status;
+import com.clearspring.analytics.util.Pair;
+
+enum SnmpTypeEnum{
+    SNMP_POLL ("snmp"),
+    SNMP_TRAP ("snmp-trap");
+
+    private String value;
+
+    public String getValue() {
+        return value;
+    }
+
+    private SnmpTypeEnum(String value) {
+        this.value = value;
+}
+
+}
+