use of org.uberfire.java.nio.file.NoSuchFileException in project kie-wb-common by kiegroup.
the class LibraryServiceImpl method getProjectAssets.
@Override
public AssetQueryResult getProjectAssets(final ProjectAssetsQuery query) {
checkNotNull("query", query);
final boolean projectStillExists = ioService.exists(Paths.convert(query.getProject().getBranch().getPath()));
if (!projectStillExists) {
return AssetQueryResult.nonexistent();
} else if (!indexOracle.isIndexed(query.getProject())) {
return AssetQueryResult.unindexed();
}
final HashSet<ValueIndexTerm> queryTerms = buildProjectAssetsQuery(query);
final PageResponse<RefactoringPageRow> findRulesByProjectQuery = refactoringQueryService.query(new RefactoringPageRequest(FindAllLibraryAssetsQuery.NAME, queryTerms, query.getStartIndex(), query.getAmount(), Boolean.TRUE));
final List<FolderItem> assets = findRulesByProjectQuery.getPageRowList().stream().map(row -> {
final Path path = (Path) row.getValue();
return new FolderItem(path, path.getFileName(), FolderItemType.FILE, false, Paths.readLockedBy(path), Collections.<String>emptyList(), explorerServiceHelper.getRestrictedOperations(path));
}).collect(Collectors.toList());
return AssetQueryResult.normal(assets.stream().map(asset -> {
AssetInfo info = null;
try {
final Map<String, Object> attributes = ioService.readAttributes(Paths.convert((Path) asset.getItem()));
final FileTime lastModifiedFileTime = (FileTime) getAttribute(LibraryService.LAST_MODIFIED_TIME, attributes).get();
final FileTime createdFileTime = (FileTime) getAttribute(LibraryService.CREATED_TIME, attributes).get();
final Date lastModifiedTime = new Date(lastModifiedFileTime.toMillis());
final Date createdTime = new Date(createdFileTime.toMillis());
info = new AssetInfo(asset, lastModifiedTime, createdTime);
} catch (NoSuchFileException nfe) {
log.debug("File '" + asset.getFileName() + "' in LibraryIndex but not VFS. Suspected deletion. Skipping.");
}
return Optional.ofNullable(info);
}).filter(Optional::isPresent).map(Optional::get).collect(Collectors.toList()));
}
use of org.uberfire.java.nio.file.NoSuchFileException in project kie-wb-common by kiegroup.
the class LibraryServiceImplTest method queryAnItemThatIsInLuceneIndexButAlreadyDeletedFromGitRepository.
@Test
public void queryAnItemThatIsInLuceneIndexButAlreadyDeletedFromGitRepository() throws Exception {
final Path path = mockPath("file://the_project");
final WorkspaceProject project = spy(WorkspaceProject.class);
final Branch branch = mock(Branch.class);
when(project.getBranch()).thenReturn(branch);
when(branch.getPath()).thenReturn(path);
doReturn(true).when(ioService).exists(any());
final ProjectAssetsQuery query = new ProjectAssetsQuery(project, "", 10, 20, Collections.emptyList());
final PageResponse<RefactoringPageRow> pageRowPageResponse = new PageResponse<>();
final ArrayList<RefactoringPageRow> assetPageRowList = new ArrayList<>();
final RefactoringPageRow pageRow = mock(RefactoringPageRow.class);
final Path filePath = mockPath("file://the_project/delete.me");
when(filePath.getFileName()).thenReturn("delete.me");
when(pageRow.getValue()).thenReturn(filePath);
assetPageRowList.add(pageRow);
pageRowPageResponse.setPageRowList(assetPageRowList);
when(refactoringQueryService.query(any(RefactoringPageRequest.class))).thenReturn(pageRowPageResponse);
when(ioService.readAttributes(any())).thenThrow(new NoSuchFileException());
final AssetQueryResult result = libraryService.getProjectAssets(query);
assertEquals(ResultType.Normal, result.getResultType());
assertTrue(result.getAssetInfos().isPresent());
List<AssetInfo> projectAssets = result.getAssetInfos().get();
assertTrue(projectAssets.isEmpty());
}
Aggregations