use of com.blackducksoftware.integration.hub.detect.detector.nuget.inspector.NugetInspector in project hub-detect by blackducksoftware.
the class NugetSolutionExtractionDebugger method debug.
public void debug(LoggedDetectExtraction extraction, DetectRunInfo detectRunInfo, DetectConfiguration detectConfiguration) {
String id = extraction.extractionIdentifier;
try {
NugetInspectorPackager packager = new NugetInspectorPackager(new Gson(), new ExternalIdFactory());
DetectFileFinder detectFileFinder = new DetectFileFinder();
File extractionFolder = new File(detectRunInfo.getExtractionsFolder(), extraction.extractionIdentifier);
List<File> extractionFiles = Arrays.asList(extractionFolder.listFiles());
DetectFileFinder mock = Mockito.mock(DetectFileFinder.class);
Mockito.when(mock.findFiles(Mockito.any(), Mockito.any())).thenReturn(extractionFiles);
NugetInspectorExtractor nugetInspectorExtractor = new NugetInspectorExtractor(packager, mock, detectConfiguration);
NugetInspector inspector = Mockito.mock(NugetInspector.class);
Mockito.when(inspector.execute(Mockito.any(), Mockito.any())).thenReturn(new ExecutableOutput("", ""));
File mockTarget = Mockito.mock(File.class);
Mockito.when(mockTarget.toString()).thenReturn("mock/target");
File mockOutput = Mockito.mock(File.class);
Mockito.when(mockOutput.getCanonicalPath()).thenReturn("mock/output");
Mockito.when(mockOutput.toString()).thenReturn("mock/output");
Extraction newExtraction = nugetInspectorExtractor.extract(mockTarget, mockOutput, inspector, new ExtractionId(DetectorType.NUGET, id));
logger.info("We did it: " + newExtraction.result.toString());
} catch (Exception e) {
logger.info("We did not do it: " + e.toString());
throw new RuntimeException(e);
}
}
use of com.blackducksoftware.integration.hub.detect.detector.nuget.inspector.NugetInspector in project hub-detect by blackducksoftware.
the class NugetInspectorExtractor method extract.
public Extraction extract(final File targetDirectory, File outputDirectory, NugetInspector inspector, final ExtractionId extractionId) {
try {
final List<String> options = new ArrayList<>(Arrays.asList("--target_path=" + targetDirectory.toString(), "--output_directory=" + outputDirectory.getCanonicalPath(), "--ignore_failure=" + detectConfiguration.getBooleanProperty(DetectProperty.DETECT_NUGET_IGNORE_FAILURE, PropertyAuthority.None)));
final String nugetExcludedModules = detectConfiguration.getProperty(DetectProperty.DETECT_NUGET_EXCLUDED_MODULES, PropertyAuthority.None);
if (StringUtils.isNotBlank(nugetExcludedModules)) {
options.add("--excluded_modules=" + nugetExcludedModules);
}
final String nugetIncludedModules = detectConfiguration.getProperty(DetectProperty.DETECT_NUGET_INCLUDED_MODULES, PropertyAuthority.None);
if (StringUtils.isNotBlank(nugetIncludedModules)) {
options.add("--included_modules=" + nugetIncludedModules);
}
final String[] nugetPackagesRepo = detectConfiguration.getStringArrayProperty(DetectProperty.DETECT_NUGET_PACKAGES_REPO_URL, PropertyAuthority.None);
if (nugetPackagesRepo.length > 0) {
final String packagesRepos = Arrays.asList(nugetPackagesRepo).stream().collect(Collectors.joining(","));
options.add("--packages_repo_url=" + packagesRepos);
}
final String nugetConfigPath = detectConfiguration.getProperty(DetectProperty.DETECT_NUGET_CONFIG_PATH, PropertyAuthority.None);
if (StringUtils.isNotBlank(nugetConfigPath)) {
options.add("--nuget_config_path=" + nugetConfigPath);
}
if (logger.isTraceEnabled()) {
options.add("-v");
}
final ExecutableOutput executableOutput = inspector.execute(targetDirectory, options);
if (executableOutput.getReturnCode() != 0) {
return new Extraction.Builder().failure(String.format("Executing command '%s' returned a non-zero exit code %s", String.join(" ", options), executableOutput.getReturnCode())).build();
}
final List<File> dependencyNodeFiles = detectFileFinder.findFiles(outputDirectory, INSPECTOR_OUTPUT_PATTERN);
final List<NugetParseResult> parseResults = new ArrayList<>();
for (final File dependencyNodeFile : dependencyNodeFiles) {
final NugetParseResult result = nugetInspectorPackager.createDetectCodeLocation(dependencyNodeFile);
parseResults.add(result);
}
final List<DetectCodeLocation> codeLocations = parseResults.stream().flatMap(it -> it.codeLocations.stream()).collect(Collectors.toList());
if (codeLocations.size() <= 0) {
logger.warn("Unable to extract any dependencies from nuget");
}
final Map<String, DetectCodeLocation> codeLocationsBySource = new HashMap<>();
final DependencyGraphCombiner combiner = new DependencyGraphCombiner();
codeLocations.stream().forEach(codeLocation -> {
final String sourcePathKey = codeLocation.getSourcePath().toLowerCase();
if (codeLocationsBySource.containsKey(sourcePathKey)) {
logger.info("Multiple project code locations were generated for: " + targetDirectory.toString());
logger.info("This most likely means the same project exists in multiple solutions.");
logger.info("The code location's dependencies will be combined, in the future they will exist seperately for each solution.");
final DetectCodeLocation destination = codeLocationsBySource.get(sourcePathKey);
combiner.addGraphAsChildrenToRoot((MutableDependencyGraph) destination.getDependencyGraph(), codeLocation.getDependencyGraph());
} else {
codeLocationsBySource.put(sourcePathKey, codeLocation);
}
});
final List<DetectCodeLocation> uniqueCodeLocations = codeLocationsBySource.values().stream().collect(Collectors.toList());
final Extraction.Builder builder = new Extraction.Builder().success(uniqueCodeLocations);
final Optional<NugetParseResult> project = parseResults.stream().filter(it -> StringUtils.isNotBlank(it.projectName)).findFirst();
if (project.isPresent()) {
builder.projectName(project.get().projectName);
builder.projectVersion(project.get().projectVersion);
}
return builder.build();
} catch (final Exception e) {
return new Extraction.Builder().exception(e).build();
}
}
Aggregations