/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying * information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Portions Copyright 2007 Sun Microsystems, Inc. */ import java.io.*; import java.lang.*; import java.util.ArrayList; public class GenerateOpenDSTestSpecs { private static String strParentDirName; private static String strOutputDirName; private static String strFileFormat; private static String strTestType; private static File fileList; private ArrayList arrayParsedData; public GenerateOpenDSTestSpecs() { } public static void main(String[] args) { // retrieve input if(args.length == 3) { strParentDirName = new String(args[0]); strOutputDirName = new String(args[1]); strFileFormat = new String(args[2]); } else { usage(); System.exit(0); } // validate input File fileDirName = new File(strParentDirName); if(!fileDirName.isDirectory()) { fatalMsg(fileDirName + " is not a directory."); System.exit(0); } else { System.out.println("Using file directory, " + strParentDirName); } File outputDirName = new File(strOutputDirName); if(!outputDirName.isDirectory()) { fatalMsg(outputDirName + " is not a directory."); System.exit(0); } else { System.out.println("Using output directory, " + strOutputDirName); } // java files are assumed to be from the unit-integration tests. // xml files are assumed to be from the functional tests. if((strFileFormat.startsWith("java")) || (strFileFormat.startsWith("xml"))) { System.out.println("Using file format " + strFileFormat.toString()); if (strFileFormat.startsWith("java")) strTestType = "Int"; else if (strFileFormat.startsWith("xml")) strTestType = "Func"; } else { fatalMsg(strFileFormat + " is not supported in this version"); System.exit(0); } System.out.println("Now running......"); // create list of files to parse TestFileList listFiles = new TestFileList(strParentDirName); listFiles.createFileArray(); // clean out the list of files listFiles.purgeFilesWithSubstring("svn"); if(strFileFormat.startsWith("java")) { listFiles.keepFilesWithSubstring("java"); } else if(strFileFormat.startsWith("xml")) { listFiles.keepFilesWithSubstring("xml"); } // The ArrayList object, arrayFiles, contains the list of files that must be parsed. ArrayList arrayFiles = listFiles.getFileArray(); // print out list of files //for(int i=0; iarrayTests = new ArrayList(); // For each directory, parse out the data from each file within that directory. for(int i=0; i 0) { if(strFileFormat.startsWith("java")) { WriteXMLFile_int xmlFile = new WriteXMLFile_int(arrayData.getTestSuite(0)); try { xmlFile.MakeXMLFile(arrayData, strOutputDirName); } catch(Exception e) { e.printStackTrace(); } } else if(strFileFormat.startsWith("xml")) { WriteXMLFile_xml xmlFile = new WriteXMLFile_xml(arrayData.getTestSuite(0)); try { xmlFile.MakeXMLFile(arrayData, strOutputDirName); } catch(Exception e) { e.printStackTrace(); } } } } System.out.println("Files successfully written to the output directory."); } private static void usage() { System.out.println("Version 01202007"); System.out.println("This program will parse files that are used for testing and create an xml file that is used for generating test specification html pages."); System.out.println("The program will recursively search for files from the directory that is passed in from the parameter."); System.out.println("This version will only recursively search one or two levels below the \"directory to files\" which is passed in as a parameter."); System.out.println("The file formats that are currently supported are \"java\" and \"xml\"."); System.out.println("Usage:"); System.out.println(" java GenerateOpenDSTestSpecs [directory to files] [directory for output files] [file format]"); } private static void fatalMsg(String str) { System.out.println(str); System.out.println("exiting....."); } private static String parseSuite(File inDir, String strParentDir) { String tmpStr = new String(inDir.toString()); int index = tmpStr.indexOf(strParentDir) + strParentDir.length() + 1; String subStr = tmpStr.substring(index); return subStr; } }