mirror of
https://github.com/ysoftdevs/DependencyCheck.git
synced 2026-03-24 18:11:47 +01:00
general updates
Former-commit-id: 9ad33356df25672ff4e9c91e8c1d456450069402
This commit is contained in:
12
pom.xml
12
pom.xml
@@ -232,6 +232,18 @@ along with DependencyCheck. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-failsafe-plugin</artifactId>
|
<artifactId>maven-failsafe-plugin</artifactId>
|
||||||
<version>2.12.4</version>
|
<version>2.12.4</version>
|
||||||
|
<configuration>
|
||||||
|
<systemProperties>
|
||||||
|
<property>
|
||||||
|
<name>cve</name>
|
||||||
|
<value>../data/cve</value>
|
||||||
|
</property>
|
||||||
|
<property>
|
||||||
|
<name>cpe</name>
|
||||||
|
<value>../data/cpe</value>
|
||||||
|
</property>
|
||||||
|
</systemProperties>
|
||||||
|
</configuration>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
<goals>
|
<goals>
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ import java.io.File;
|
|||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.net.URLDecoder;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.LogManager;
|
import java.util.logging.LogManager;
|
||||||
@@ -69,11 +70,32 @@ public class App {
|
|||||||
app.run(args);
|
app.run(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static File getLoggingDirectory() throws IOException {
|
||||||
|
String fileName = "logs";
|
||||||
|
String filePath = App.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||||
|
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
||||||
|
File exePath = new File(decodedPath);
|
||||||
|
if (!exePath.isDirectory()) {
|
||||||
|
exePath = exePath.getParentFile();
|
||||||
|
}
|
||||||
|
File path = new File(exePath.getCanonicalFile() + File.separator + fileName);
|
||||||
|
path = new File(path.getCanonicalPath());
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
private static void prepareLogger() {
|
private static void prepareLogger() {
|
||||||
//while java doc for JUL says to use preferences api - it throws an exception...
|
//while java doc for JUL says to use preferences api - it throws an exception...
|
||||||
//Preferences.systemRoot().put("java.util.logging.config.file", "log.properties");
|
//Preferences.systemRoot().put("java.util.logging.config.file", "log.properties");
|
||||||
//System.getProperties().put("java.util.logging.config.file", "configuration/log.properties");
|
//System.getProperties().put("java.util.logging.config.file", "configuration/log.properties");
|
||||||
File dir = new File("logs");
|
File dir;
|
||||||
|
try {
|
||||||
|
dir = getLoggingDirectory();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(App.class.getName()).log(Level.SEVERE, "Unable to get default logging location, "
|
||||||
|
+ "using the working directory instead.", ex);
|
||||||
|
dir = new File("logs");
|
||||||
|
}
|
||||||
|
|
||||||
if (!dir.exists()) {
|
if (!dir.exists()) {
|
||||||
dir.mkdir();
|
dir.mkdir();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -75,17 +75,32 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
* @throws IOException is thrown if an IOException occurs.
|
* @throws IOException is thrown if an IOException occurs.
|
||||||
*/
|
*/
|
||||||
public Directory getDirectory() throws IOException {
|
public Directory getDirectory() throws IOException {
|
||||||
String fileName = Settings.getString(Settings.KEYS.CPE_INDEX);
|
File path = getDataDirectory();
|
||||||
String filePath = Index.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
|
||||||
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
|
||||||
|
|
||||||
File path = new File(decodedPath + File.separator + fileName);
|
|
||||||
path = new File(path.getCanonicalPath());
|
|
||||||
Directory dir = FSDirectory.open(path);
|
Directory dir = FSDirectory.open(path);
|
||||||
|
|
||||||
return dir;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the directory that the JAR file exists in so that
|
||||||
|
* we can ensure we always use a common data directory.
|
||||||
|
*
|
||||||
|
* @return the data directory for this index.
|
||||||
|
* @throws IOException is thrown if an IOException occurs of course...
|
||||||
|
*/
|
||||||
|
protected File getDataDirectory() throws IOException {
|
||||||
|
String fileName = Settings.getString(Settings.KEYS.CPE_INDEX);
|
||||||
|
String filePath = Index.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||||
|
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
||||||
|
File exePath = new File(decodedPath);
|
||||||
|
if (!exePath.isDirectory()) {
|
||||||
|
exePath = exePath.getParentFile();
|
||||||
|
}
|
||||||
|
File path = new File(exePath.getCanonicalFile() + File.separator + fileName);
|
||||||
|
path = new File(path.getCanonicalPath());
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an Analyzer for the CPE Index.
|
* Creates an Analyzer for the CPE Index.
|
||||||
*
|
*
|
||||||
@@ -158,8 +173,14 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
*
|
*
|
||||||
* @param timeStamp the timestamp to write.
|
* @param timeStamp the timestamp to write.
|
||||||
*/
|
*/
|
||||||
private void writeLastUpdatedPropertyFile(long timeStamp) {
|
private void writeLastUpdatedPropertyFile(long timeStamp) throws UpdateException {
|
||||||
String dir = Settings.getString(Settings.KEYS.CPE_INDEX);
|
String dir;
|
||||||
|
try {
|
||||||
|
dir = getDataDirectory().getCanonicalPath();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to locate the last updated properties file.", ex);
|
||||||
|
}
|
||||||
File cpeProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
File cpeProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
||||||
Properties prop = new Properties();
|
Properties prop = new Properties();
|
||||||
prop.put(Index.LAST_UPDATED, String.valueOf(timeStamp));
|
prop.put(Index.LAST_UPDATED, String.valueOf(timeStamp));
|
||||||
@@ -198,8 +219,10 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
* is incorrect.
|
* is incorrect.
|
||||||
* @throws DownloadFailedException is thrown if there is an error
|
* @throws DownloadFailedException is thrown if there is an error
|
||||||
* downloading the cpe.meta data file.
|
* downloading the cpe.meta data file.
|
||||||
|
* @throws UpdateException is thrown if there is an error locating the last updated
|
||||||
|
* properties file.
|
||||||
*/
|
*/
|
||||||
public long updateNeeded() throws MalformedURLException, DownloadFailedException {
|
public long updateNeeded() throws MalformedURLException, DownloadFailedException, UpdateException {
|
||||||
long retVal = 0;
|
long retVal = 0;
|
||||||
long lastUpdated = 0;
|
long lastUpdated = 0;
|
||||||
long currentlyPublishedDate = retrieveCurrentCPETimestampFromWeb();
|
long currentlyPublishedDate = retrieveCurrentCPETimestampFromWeb();
|
||||||
@@ -207,12 +230,24 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
throw new DownloadFailedException("Unable to retrieve valid timestamp from cpe.meta file");
|
throw new DownloadFailedException("Unable to retrieve valid timestamp from cpe.meta file");
|
||||||
}
|
}
|
||||||
|
|
||||||
String dir = Settings.getString(Settings.KEYS.CPE_INDEX);
|
//String dir = Settings.getString(Settings.KEYS.CPE_INDEX);
|
||||||
File f = new File(dir);
|
File f;
|
||||||
|
try {
|
||||||
|
f = getDataDirectory(); //new File(dir);
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to locate last updated properties file.", ex);
|
||||||
|
}
|
||||||
if (!f.exists()) {
|
if (!f.exists()) {
|
||||||
retVal = currentlyPublishedDate;
|
retVal = currentlyPublishedDate;
|
||||||
} else {
|
} else {
|
||||||
File cpeProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
File cpeProp;
|
||||||
|
try {
|
||||||
|
cpeProp = new File(f.getCanonicalPath() + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to find last updated properties file.", ex);
|
||||||
|
}
|
||||||
if (!cpeProp.exists()) {
|
if (!cpeProp.exists()) {
|
||||||
retVal = currentlyPublishedDate;
|
retVal = currentlyPublishedDate;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -67,21 +67,36 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
private static final String LAST_UPDATED_BASE = "lastupdated.";
|
private static final String LAST_UPDATED_BASE = "lastupdated.";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the directory that holds the NVD CVE Index.
|
* Returns the directory that holds the NVD CVE Index. Note, this
|
||||||
|
* returns the path where the class or jar file exists.
|
||||||
*
|
*
|
||||||
* @return the Directory containing the NVD CVE Index.
|
* @return the Directory containing the NVD CVE Index.
|
||||||
* @throws IOException is thrown if an IOException occurs.
|
* @throws IOException is thrown if an IOException occurs.
|
||||||
*/
|
*/
|
||||||
public Directory getDirectory() throws IOException {
|
public Directory getDirectory() throws IOException {
|
||||||
|
File path = getDataDirectory();
|
||||||
|
Directory dir = FSDirectory.open(path);
|
||||||
|
return dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the directory that the JAR file exists in so that
|
||||||
|
* we can ensure we always use a common data directory.
|
||||||
|
*
|
||||||
|
* @return the data directory for this index.
|
||||||
|
* @throws IOException is thrown if an IOException occurs of course...
|
||||||
|
*/
|
||||||
|
protected File getDataDirectory() throws IOException {
|
||||||
String fileName = Settings.getString(Settings.KEYS.CVE_INDEX);
|
String fileName = Settings.getString(Settings.KEYS.CVE_INDEX);
|
||||||
String filePath = Index.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
String filePath = Index.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||||
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
||||||
|
File exePath = new File(decodedPath);
|
||||||
File path = new File(decodedPath + File.separator + fileName);
|
if (!exePath.isDirectory()) {
|
||||||
|
exePath = exePath.getParentFile();
|
||||||
|
}
|
||||||
|
File path = new File(exePath.getCanonicalFile() + File.separator + fileName);
|
||||||
path = new File(path.getCanonicalPath());
|
path = new File(path.getCanonicalPath());
|
||||||
Directory dir = FSDirectory.open(path);
|
return path;
|
||||||
|
|
||||||
return dir;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -171,8 +186,14 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
*
|
*
|
||||||
* @param timeStamp the timestamp to write.
|
* @param timeStamp the timestamp to write.
|
||||||
*/
|
*/
|
||||||
private void writeLastUpdatedPropertyFile(Map<String, NvdCveUrl> updated) {
|
private void writeLastUpdatedPropertyFile(Map<String, NvdCveUrl> updated) throws UpdateException {
|
||||||
String dir = Settings.getString(Settings.KEYS.CVE_INDEX);
|
String dir;
|
||||||
|
try {
|
||||||
|
dir = getDataDirectory().getCanonicalPath();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to locate last updated properties file.", ex);
|
||||||
|
}
|
||||||
File cveProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
File cveProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
||||||
Properties prop = new Properties();
|
Properties prop = new Properties();
|
||||||
|
|
||||||
@@ -187,8 +208,10 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
prop.store(out, dir);
|
prop.store(out, dir);
|
||||||
} catch (FileNotFoundException ex) {
|
} catch (FileNotFoundException ex) {
|
||||||
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to find last updated properties file.", ex);
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to update last updated properties file.", ex);
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
os.flush();
|
os.flush();
|
||||||
@@ -212,10 +235,11 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
* @return the NvdCveUrl of the files that need to be updated.
|
* @return the NvdCveUrl of the files that need to be updated.
|
||||||
* @throws MalformedURLException is thrown if the URL for the NVD CVE Meta
|
* @throws MalformedURLException is thrown if the URL for the NVD CVE Meta
|
||||||
* data is incorrect.
|
* data is incorrect.
|
||||||
* @throws DownloadFailedException is thrown if there is an error
|
* @throws DownloadFailedException is thrown if there is an error.
|
||||||
* downloading the nvd cve download data file.
|
* downloading the nvd cve download data file.
|
||||||
|
* @throws UpdateException Is thrown if there is an issue with the last updated properties file.
|
||||||
*/
|
*/
|
||||||
public Map<String, NvdCveUrl> updateNeeded() throws MalformedURLException, DownloadFailedException {
|
public Map<String, NvdCveUrl> updateNeeded() throws MalformedURLException, DownloadFailedException, UpdateException {
|
||||||
|
|
||||||
Map<String, NvdCveUrl> currentlyPublished;
|
Map<String, NvdCveUrl> currentlyPublished;
|
||||||
try {
|
try {
|
||||||
@@ -227,7 +251,14 @@ public class Index extends AbstractIndex implements CachedWebDataSource {
|
|||||||
if (currentlyPublished == null) {
|
if (currentlyPublished == null) {
|
||||||
throw new DownloadFailedException("Unable to retrieve valid timestamp from nvd cve downloads page");
|
throw new DownloadFailedException("Unable to retrieve valid timestamp from nvd cve downloads page");
|
||||||
}
|
}
|
||||||
String dir = Settings.getString(Settings.KEYS.CVE_INDEX);
|
String dir;
|
||||||
|
try {
|
||||||
|
dir = getDataDirectory().getCanonicalPath();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
Logger.getLogger(Index.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
throw new UpdateException("Unable to locate last updated properties file.", ex);
|
||||||
|
}
|
||||||
|
|
||||||
File f = new File(dir);
|
File f = new File(dir);
|
||||||
if (f.exists()) {
|
if (f.exists()) {
|
||||||
File cveProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
File cveProp = new File(dir + File.separatorChar + UPDATE_PROPERTIES_FILE);
|
||||||
|
|||||||
@@ -93,17 +93,20 @@ public final class CliParser {
|
|||||||
validatePathExists(getScanFiles());
|
validatePathExists(getScanFiles());
|
||||||
if (!line.hasOption(ArgumentName.OUT)) {
|
if (!line.hasOption(ArgumentName.OUT)) {
|
||||||
//TODO - need a new exception type here, this isn't really a parseexception.
|
//TODO - need a new exception type here, this isn't really a parseexception.
|
||||||
throw new ParseException("Scan cannot be run without specifying a directory to write the reports to via the 'out' argument.");
|
throw new ParseException("Scan cannot be run without specifying a directory "
|
||||||
|
+ "to write the reports to via the 'out' argument.");
|
||||||
} else {
|
} else {
|
||||||
String p = line.getOptionValue(ArgumentName.OUT, "");
|
String p = line.getOptionValue(ArgumentName.OUT, "");
|
||||||
File f = new File(p);
|
File f = new File(p);
|
||||||
if ("".equals(p) || !(f.exists() && f.isDirectory())) {
|
if ("".equals(p) || !(f.exists() && f.isDirectory())) {
|
||||||
//TODO - need a new exception type here, this isn't really a parseexception.
|
//TODO - need a new exception type here, this isn't really a parseexception.
|
||||||
throw new ParseException("A valid directory name must be specified for the 'out' argument.");
|
throw new ParseException("A valid directory name must be specified for "
|
||||||
|
+ "the 'out' argument.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!line.hasOption(ArgumentName.APPNAME)) {
|
if (!line.hasOption(ArgumentName.APPNAME)) {
|
||||||
throw new ParseException("Scan cannot be run without specifying an application name via the 'app' argument.");
|
throw new ParseException("Scan cannot be run without specifying an application "
|
||||||
|
+ "name via the 'app' argument.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -160,15 +163,25 @@ public final class CliParser {
|
|||||||
Option noupdate = new Option(ArgumentName.DISABLE_AUTO_UPDATE_SHORT, ArgumentName.DISABLE_AUTO_UPDATE,
|
Option noupdate = new Option(ArgumentName.DISABLE_AUTO_UPDATE_SHORT, ArgumentName.DISABLE_AUTO_UPDATE,
|
||||||
false, "disables the automatic updating of the CPE data.");
|
false, "disables the automatic updating of the CPE data.");
|
||||||
|
|
||||||
Option appname = OptionBuilder.withArgName("name").hasArg().withLongOpt(ArgumentName.APPNAME).withDescription("the name of the application being scanned.").create(ArgumentName.APPNAME_SHORT);
|
Option appname = OptionBuilder.withArgName("name").hasArg().withLongOpt(ArgumentName.APPNAME)
|
||||||
|
.withDescription("the name of the application being scanned.")
|
||||||
|
.create(ArgumentName.APPNAME_SHORT);
|
||||||
|
|
||||||
Option path = OptionBuilder.withArgName("path").hasArg().withLongOpt(ArgumentName.SCAN).withDescription("the path to scan - this option can be specified multiple times.").create(ArgumentName.SCAN_SHORT);
|
Option path = OptionBuilder.withArgName("path").hasArg().withLongOpt(ArgumentName.SCAN)
|
||||||
|
.withDescription("the path to scan - this option can be specified multiple times.")
|
||||||
|
.create(ArgumentName.SCAN_SHORT);
|
||||||
|
|
||||||
Option load = OptionBuilder.withArgName("file").hasArg().withLongOpt(ArgumentName.CPE).withDescription("load the CPE xml file.").create(ArgumentName.CPE_SHORT);
|
Option load = OptionBuilder.withArgName("file").hasArg().withLongOpt(ArgumentName.CPE)
|
||||||
|
.withDescription("load the CPE xml file.")
|
||||||
|
.create(ArgumentName.CPE_SHORT);
|
||||||
|
|
||||||
Option props = OptionBuilder.withArgName("file").hasArg().withLongOpt(ArgumentName.PROP).withDescription("a property file to load.").create(ArgumentName.PROP_SHORT);
|
Option props = OptionBuilder.withArgName("file").hasArg().withLongOpt(ArgumentName.PROP)
|
||||||
|
.withDescription("a property file to load.")
|
||||||
|
.create(ArgumentName.PROP_SHORT);
|
||||||
|
|
||||||
Option out = OptionBuilder.withArgName("folder").hasArg().withLongOpt(ArgumentName.OUT).withDescription("the folder to write reports to.").create(ArgumentName.OUT_SHORT);
|
Option out = OptionBuilder.withArgName("folder").hasArg().withLongOpt(ArgumentName.OUT)
|
||||||
|
.withDescription("the folder to write reports to.")
|
||||||
|
.create(ArgumentName.OUT_SHORT);
|
||||||
|
|
||||||
//TODO add the ability to load a properties file to override the defaults...
|
//TODO add the ability to load a properties file to override the defaults...
|
||||||
|
|
||||||
@@ -237,7 +250,8 @@ public final class CliParser {
|
|||||||
+ "using the -p <file> argument or by passing them in as system properties." + nl
|
+ "using the -p <file> argument or by passing them in as system properties." + nl
|
||||||
+ nl + " " + Settings.KEYS.PROXY_URL + "\t\t the proxy URL to use when downloading resources."
|
+ nl + " " + Settings.KEYS.PROXY_URL + "\t\t the proxy URL to use when downloading resources."
|
||||||
+ nl + " " + Settings.KEYS.PROXY_PORT + "\t\t the proxy port to use when downloading resources."
|
+ nl + " " + Settings.KEYS.PROXY_PORT + "\t\t the proxy port to use when downloading resources."
|
||||||
+ nl + " " + Settings.KEYS.CONNECTION_TIMEOUT + "\t the cconnection timeout (in milliseconds) to use" + nl + "\t\t\t when downloading resources.";
|
+ nl + " " + Settings.KEYS.CONNECTION_TIMEOUT + "\t the cconnection timeout (in milliseconds) to use"
|
||||||
|
+ nl + "\t\t\t when downloading resources.";
|
||||||
}
|
}
|
||||||
|
|
||||||
formatter.printHelp(Settings.getString("application.name", "DependencyCheck"),
|
formatter.printHelp(Settings.getString("application.name", "DependencyCheck"),
|
||||||
|
|||||||
@@ -9,6 +9,8 @@ import java.io.BufferedOutputStream;
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.URLDecoder;
|
||||||
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipInputStream;
|
import java.util.zip.ZipInputStream;
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
@@ -30,8 +32,22 @@ public abstract class BaseIndexTestCase extends TestCase {
|
|||||||
ensureIndexExists();
|
ensureIndexExists();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static File getDataDirectory() throws IOException {
|
||||||
|
String fileName = Settings.getString(Settings.KEYS.CPE_INDEX);
|
||||||
|
String filePath = BaseIndexTestCase.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||||
|
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
||||||
|
File exePath = new File(decodedPath);
|
||||||
|
if (!exePath.isDirectory()) {
|
||||||
|
exePath = exePath.getParentFile();
|
||||||
|
}
|
||||||
|
File path = new File(exePath.getCanonicalFile() + File.separator + fileName);
|
||||||
|
path = new File(path.getCanonicalPath());
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
public static void ensureIndexExists() throws Exception {
|
public static void ensureIndexExists() throws Exception {
|
||||||
String indexPath = Settings.getString(Settings.KEYS.CPE_INDEX);
|
//String indexPath = Settings.getString(Settings.KEYS.CPE_INDEX);
|
||||||
|
String indexPath = getDataDirectory().getCanonicalPath();
|
||||||
java.io.File f = new File(indexPath);
|
java.io.File f = new File(indexPath);
|
||||||
if (!f.exists()) {
|
if (!f.exists()) {
|
||||||
f.mkdirs();
|
f.mkdirs();
|
||||||
|
|||||||
@@ -10,6 +10,8 @@ import java.io.BufferedOutputStream;
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.URLDecoder;
|
||||||
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipInputStream;
|
import java.util.zip.ZipInputStream;
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
@@ -31,8 +33,23 @@ public abstract class BaseIndexTestCase extends TestCase {
|
|||||||
ensureIndexExists();
|
ensureIndexExists();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected static File getDataDirectory() throws IOException {
|
||||||
|
String fileName = Settings.getString(Settings.KEYS.CVE_INDEX);
|
||||||
|
String filePath = BaseIndexTestCase.class.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||||
|
String decodedPath = URLDecoder.decode(filePath, "UTF-8");
|
||||||
|
File exePath = new File(decodedPath);
|
||||||
|
if (!exePath.isDirectory()) {
|
||||||
|
exePath = exePath.getParentFile();
|
||||||
|
}
|
||||||
|
File path = new File(exePath.getCanonicalFile() + File.separator + fileName);
|
||||||
|
path = new File(path.getCanonicalPath());
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
public static void ensureIndexExists() throws Exception {
|
public static void ensureIndexExists() throws Exception {
|
||||||
String indexPath = Settings.getString(Settings.KEYS.CVE_INDEX);
|
//String indexPath = Settings.getString(Settings.KEYS.CVE_INDEX);
|
||||||
|
String indexPath = getDataDirectory().getCanonicalPath();
|
||||||
java.io.File f = new File(indexPath);
|
java.io.File f = new File(indexPath);
|
||||||
if (!f.exists()) {
|
if (!f.exists()) {
|
||||||
f.mkdirs();
|
f.mkdirs();
|
||||||
|
|||||||
@@ -45,6 +45,8 @@ public class IndexTest extends BaseIndexTestCase {
|
|||||||
Index instance = new Index();
|
Index instance = new Index();
|
||||||
String exp = File.separatorChar + "target" + File.separatorChar + "data" + File.separatorChar + "cve";
|
String exp = File.separatorChar + "target" + File.separatorChar + "data" + File.separatorChar + "cve";
|
||||||
Directory result = instance.getDirectory();
|
Directory result = instance.getDirectory();
|
||||||
assertTrue(result.toString().contains(exp));
|
|
||||||
|
assertTrue("Recieved '" + result.toString() + "' and excpected '" + exp + "'.",
|
||||||
|
result.toString().contains(exp));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ public class SettingsTest extends TestCase {
|
|||||||
public void testGetString() {
|
public void testGetString() {
|
||||||
System.out.println("getString");
|
System.out.println("getString");
|
||||||
String key = Settings.KEYS.CPE_INDEX;
|
String key = Settings.KEYS.CPE_INDEX;
|
||||||
String expResult = "target/data/cpe";
|
String expResult = "../data/cpe";
|
||||||
String result = Settings.getString(key);
|
String result = Settings.getString(key);
|
||||||
assertTrue(result.endsWith(expResult));
|
assertTrue(result.endsWith(expResult));
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user