mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-31 17:38:48 +00:00
Unit tests for document list component
This commit is contained in:
@@ -41,4 +41,11 @@ export class AlfrescoServiceMock extends AlfrescoService {
|
|||||||
observer.complete();
|
observer.complete();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
deleteNode(nodeId: string) {
|
||||||
|
return Observable.create(observer => {
|
||||||
|
observer.next();
|
||||||
|
observer.complete();
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -33,6 +33,7 @@ export class FileNode extends MinimalNodeEntity {
|
|||||||
constructor(name?: string) {
|
constructor(name?: string) {
|
||||||
super();
|
super();
|
||||||
this.entry = new MinimalNodeEntryEntity();
|
this.entry = new MinimalNodeEntryEntity();
|
||||||
|
this.entry.id = 'file-id';
|
||||||
this.entry.isFile = true;
|
this.entry.isFile = true;
|
||||||
this.entry.isFolder = false;
|
this.entry.isFolder = false;
|
||||||
this.entry.name = name;
|
this.entry.name = name;
|
||||||
@@ -45,6 +46,7 @@ export class FolderNode extends MinimalNodeEntity {
|
|||||||
constructor(name?: string) {
|
constructor(name?: string) {
|
||||||
super();
|
super();
|
||||||
this.entry = new MinimalNodeEntryEntity();
|
this.entry = new MinimalNodeEntryEntity();
|
||||||
|
this.entry.id = 'folder-id';
|
||||||
this.entry.isFile = false;
|
this.entry.isFile = false;
|
||||||
this.entry.isFolder = true;
|
this.entry.isFolder = true;
|
||||||
this.entry.name = name;
|
this.entry.name = name;
|
||||||
|
@@ -21,17 +21,26 @@ import {
|
|||||||
expect,
|
expect,
|
||||||
beforeEach
|
beforeEach
|
||||||
} from '@angular/core/testing';
|
} from '@angular/core/testing';
|
||||||
|
import { AlfrescoContentService } from 'ng2-alfresco-core';
|
||||||
import { ContentActionHandler } from '../models/content-action.model';
|
import { ContentActionHandler } from '../models/content-action.model';
|
||||||
import { DocumentActionsService } from './document-actions.service';
|
import { DocumentActionsService } from './document-actions.service';
|
||||||
import { AlfrescoServiceMock } from '../assets/alfresco.service.mock';
|
import { AlfrescoServiceMock } from '../assets/alfresco.service.mock';
|
||||||
|
import { AlfrescoService } from './alfresco.service';
|
||||||
|
import {
|
||||||
|
FileNode,
|
||||||
|
FolderNode
|
||||||
|
} from '../assets/document-library.model.mock';
|
||||||
|
|
||||||
describe('DocumentActionsService', () => {
|
describe('DocumentActionsService', () => {
|
||||||
|
|
||||||
let service: DocumentActionsService;
|
let service: DocumentActionsService;
|
||||||
|
let alfrescoService: AlfrescoService;
|
||||||
|
let contentService: AlfrescoContentService;
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
let alfrescoServiceMock = new AlfrescoServiceMock();
|
alfrescoService = new AlfrescoServiceMock();
|
||||||
service = new DocumentActionsService(alfrescoServiceMock);
|
contentService = new AlfrescoContentService(null, null);
|
||||||
|
service = new DocumentActionsService(alfrescoService, contentService);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should register default download action', () => {
|
it('should register default download action', () => {
|
||||||
@@ -52,6 +61,142 @@ describe('DocumentActionsService', () => {
|
|||||||
let handler: ContentActionHandler = function (obj: any) {};
|
let handler: ContentActionHandler = function (obj: any) {};
|
||||||
service.setHandler('<key>', handler);
|
service.setHandler('<key>', handler);
|
||||||
expect(service.getHandler('<KEY>')).toBe(handler);
|
expect(service.getHandler('<KEY>')).toBe(handler);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not find handler with invalid key', () => {
|
||||||
|
expect(service.getHandler(null)).toBeNull();
|
||||||
|
expect(service.getHandler('')).toBeNull();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should allow action execution only when service available', () => {
|
||||||
|
let file = new FileNode();
|
||||||
|
expect(service.canExecuteAction(file)).toBeTruthy();
|
||||||
|
|
||||||
|
service = new DocumentActionsService(null);
|
||||||
|
expect(service.canExecuteAction(file)).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should allow action execution only for file nodes', () => {
|
||||||
|
expect(service.canExecuteAction(null)).toBeFalsy();
|
||||||
|
expect(service.canExecuteAction(new FileNode())).toBeTruthy();
|
||||||
|
expect(service.canExecuteAction(new FolderNode())).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should set new handler only by key', () => {
|
||||||
|
let handler: ContentActionHandler = function (obj: any) {};
|
||||||
|
expect(service.setHandler(null, handler)).toBeFalsy();
|
||||||
|
expect(service.setHandler('', handler)).toBeFalsy();
|
||||||
|
expect(service.setHandler('my-handler', handler)).toBeTruthy();
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: to be removed once demo handlers are removed
|
||||||
|
it('should execute demo actions', () => {
|
||||||
|
spyOn(window, 'alert').and.stub();
|
||||||
|
|
||||||
|
service.getHandler('system1')(null);
|
||||||
|
expect(window.alert).toHaveBeenCalledWith('standard document action 1');
|
||||||
|
|
||||||
|
service.getHandler('system2')(null);
|
||||||
|
expect(window.alert).toHaveBeenCalledWith('standard document action 2');
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: to be removed once demo handlers are removed
|
||||||
|
it('should register demo handlers', () => {
|
||||||
|
expect(service.getHandler('system1')).toBeDefined();
|
||||||
|
expect(service.getHandler('system2')).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should register delete action', () => {
|
||||||
|
expect(service.getHandler('delete')).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should register download action', () => {
|
||||||
|
expect(service.getHandler('download')).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should execute download action and cleanup', () => {
|
||||||
|
let file = new FileNode();
|
||||||
|
let url = 'http://<address>';
|
||||||
|
|
||||||
|
spyOn(contentService, 'getContentUrl').and.returnValue(url);
|
||||||
|
|
||||||
|
let link = jasmine.createSpyObj('a', [
|
||||||
|
'setAttribute',
|
||||||
|
'click'
|
||||||
|
]);
|
||||||
|
|
||||||
|
spyOn(document, 'createElement').and.returnValue(link);
|
||||||
|
spyOn(document.body, 'appendChild').and.stub();
|
||||||
|
spyOn(document.body, 'removeChild').and.stub();
|
||||||
|
|
||||||
|
service.getHandler('download')(file);
|
||||||
|
|
||||||
|
expect(contentService.getContentUrl).toHaveBeenCalledWith(file);
|
||||||
|
expect(document.createElement).toHaveBeenCalledWith('a');
|
||||||
|
expect(link.setAttribute).toHaveBeenCalledWith('download', 'download');
|
||||||
|
expect(document.body.appendChild).toHaveBeenCalledWith(link);
|
||||||
|
expect(link.click).toHaveBeenCalled();
|
||||||
|
expect(document.body.removeChild).toHaveBeenCalledWith(link);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should require internal service for download action', () => {
|
||||||
|
let actionService = new DocumentActionsService(null, contentService);
|
||||||
|
let file = new FileNode();
|
||||||
|
let result = actionService.getHandler('download')(file);
|
||||||
|
expect(result).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should require content service for download action', () => {
|
||||||
|
let actionService = new DocumentActionsService(alfrescoService, null);
|
||||||
|
let file = new FileNode();
|
||||||
|
let result = actionService.getHandler('download')(file);
|
||||||
|
expect(result).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should require file node for download action', () => {
|
||||||
|
let folder = new FolderNode();
|
||||||
|
expect(service.getHandler('download')(folder)).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should delete file node', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let file = new FileNode();
|
||||||
|
service.getHandler('delete')(file);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalledWith(file.entry.id);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should support deletion only file node', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let folder = new FolderNode();
|
||||||
|
service.getHandler('delete')(folder);
|
||||||
|
expect(alfrescoService.deleteNode).not.toHaveBeenCalled();
|
||||||
|
|
||||||
|
let file = new FileNode();
|
||||||
|
service.getHandler('delete')(file);
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should require node id to delete', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let file = new FileNode();
|
||||||
|
file.entry.id = null;
|
||||||
|
service.getHandler('delete')(file);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should reload target upon node deletion', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let target = jasmine.createSpyObj('obj', ['reload']);
|
||||||
|
let file = new FileNode();
|
||||||
|
service.getHandler('delete')(file, target);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalled();
|
||||||
|
expect(target.reload).toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@@ -18,17 +18,15 @@
|
|||||||
import {Injectable} from '@angular/core';
|
import {Injectable} from '@angular/core';
|
||||||
import {ContentActionHandler} from '../models/content-action.model';
|
import {ContentActionHandler} from '../models/content-action.model';
|
||||||
import {AlfrescoService} from './alfresco.service';
|
import {AlfrescoService} from './alfresco.service';
|
||||||
import {
|
import { AlfrescoContentService } from 'ng2-alfresco-core';
|
||||||
AlfrescoContentService
|
|
||||||
} from 'ng2-alfresco-core';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class DocumentActionsService {
|
export class DocumentActionsService {
|
||||||
private handlers: { [id: string]: ContentActionHandler; } = {};
|
private handlers: { [id: string]: ContentActionHandler; } = {};
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private _alfrescoService?: AlfrescoService,
|
private alfrescoService?: AlfrescoService,
|
||||||
private _contentService?: AlfrescoContentService
|
private contentService?: AlfrescoContentService
|
||||||
) {
|
) {
|
||||||
this.setupActionHandlers();
|
this.setupActionHandlers();
|
||||||
}
|
}
|
||||||
@@ -41,15 +39,17 @@ export class DocumentActionsService {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
setHandler(key: string, handler: ContentActionHandler): void {
|
setHandler(key: string, handler: ContentActionHandler): boolean {
|
||||||
if (key) {
|
if (key) {
|
||||||
let lkey = key.toLowerCase();
|
let lkey = key.toLowerCase();
|
||||||
this.handlers[lkey] = handler;
|
this.handlers[lkey] = handler;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
canExecuteAction(obj: any): boolean {
|
canExecuteAction(obj: any): boolean {
|
||||||
return this._alfrescoService && obj && obj.entry.isFile === true;
|
return this.alfrescoService && obj && obj.entry.isFile === true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private setupActionHandlers() {
|
private setupActionHandlers() {
|
||||||
@@ -71,20 +71,22 @@ export class DocumentActionsService {
|
|||||||
window.alert('standard document action 2');
|
window.alert('standard document action 2');
|
||||||
}
|
}
|
||||||
|
|
||||||
private download(obj: any) {
|
private download(obj: any): boolean {
|
||||||
if (this.canExecuteAction(obj)) {
|
if (this.canExecuteAction(obj) && this.contentService) {
|
||||||
let link = document.createElement('a');
|
let link = document.createElement('a');
|
||||||
document.body.appendChild(link);
|
document.body.appendChild(link);
|
||||||
link.setAttribute('download', 'download');
|
link.setAttribute('download', 'download');
|
||||||
link.href = this._contentService.getContentUrl(obj);
|
link.href = this.contentService.getContentUrl(obj);
|
||||||
link.click();
|
link.click();
|
||||||
document.body.removeChild(link);
|
document.body.removeChild(link);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private deleteNode(obj: any, target?: any) {
|
private deleteNode(obj: any, target?: any) {
|
||||||
if (this.canExecuteAction(obj) && obj.entry && obj.entry.id) {
|
if (this.canExecuteAction(obj) && obj.entry && obj.entry.id) {
|
||||||
this._alfrescoService.deleteNode(obj.entry.id).subscribe(() => {
|
this.alfrescoService.deleteNode(obj.entry.id).subscribe(() => {
|
||||||
if (target && typeof target.reload === 'function') {
|
if (target && typeof target.reload === 'function') {
|
||||||
target.reload();
|
target.reload();
|
||||||
}
|
}
|
||||||
|
@@ -23,13 +23,21 @@ import {
|
|||||||
} from '@angular/core/testing';
|
} from '@angular/core/testing';
|
||||||
import {FolderActionsService} from './folder-actions.service';
|
import {FolderActionsService} from './folder-actions.service';
|
||||||
import {ContentActionHandler} from '../models/content-action.model';
|
import {ContentActionHandler} from '../models/content-action.model';
|
||||||
|
import {
|
||||||
|
FileNode,
|
||||||
|
FolderNode
|
||||||
|
} from '../assets/document-library.model.mock';
|
||||||
|
import { AlfrescoService } from './alfresco.service';
|
||||||
|
import { AlfrescoServiceMock } from '../assets/alfresco.service.mock';
|
||||||
|
|
||||||
describe('FolderActionsService', () => {
|
describe('FolderActionsService', () => {
|
||||||
|
|
||||||
let service: FolderActionsService;
|
let service: FolderActionsService;
|
||||||
|
let alfrescoService: AlfrescoService;
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
service = new FolderActionsService();
|
alfrescoService = new AlfrescoServiceMock();
|
||||||
|
service = new FolderActionsService(alfrescoService);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should register custom action handler', () => {
|
it('should register custom action handler', () => {
|
||||||
@@ -46,7 +54,96 @@ describe('FolderActionsService', () => {
|
|||||||
let handler: ContentActionHandler = function (obj: any) {};
|
let handler: ContentActionHandler = function (obj: any) {};
|
||||||
service.setHandler('<key>', handler);
|
service.setHandler('<key>', handler);
|
||||||
expect(service.getHandler('<KEY>')).toBe(handler);
|
expect(service.getHandler('<KEY>')).toBe(handler);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not find handler with invalid key', () => {
|
||||||
|
expect(service.getHandler(null)).toBeNull();
|
||||||
|
expect(service.getHandler('')).toBeNull();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should allow action execution only when service available', () => {
|
||||||
|
let folder = new FolderNode();
|
||||||
|
expect(service.canExecuteAction(folder)).toBeTruthy();
|
||||||
|
|
||||||
|
service = new FolderActionsService(null);
|
||||||
|
expect(service.canExecuteAction(folder)).toBeFalsy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should allow action execution only for folder nodes', () => {
|
||||||
|
expect(service.canExecuteAction(null)).toBeFalsy();
|
||||||
|
expect(service.canExecuteAction(new FileNode())).toBeFalsy();
|
||||||
|
expect(service.canExecuteAction(new FolderNode())).toBeTruthy();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should set new handler only by key', () => {
|
||||||
|
let handler: ContentActionHandler = function (obj: any) {};
|
||||||
|
expect(service.setHandler(null, handler)).toBeFalsy();
|
||||||
|
expect(service.setHandler('', handler)).toBeFalsy();
|
||||||
|
expect(service.setHandler('my-handler', handler)).toBeTruthy();
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: to be removed once demo handlers are removed
|
||||||
|
it('should execute demo actions', () => {
|
||||||
|
spyOn(window, 'alert').and.stub();
|
||||||
|
|
||||||
|
service.getHandler('system1')(null);
|
||||||
|
expect(window.alert).toHaveBeenCalledWith('standard folder action 1');
|
||||||
|
|
||||||
|
service.getHandler('system2')(null);
|
||||||
|
expect(window.alert).toHaveBeenCalledWith('standard folder action 2');
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// TODO: to be removed once demo handlers are removed
|
||||||
|
it('should register demo handlers', () => {
|
||||||
|
expect(service.getHandler('system1')).toBeDefined();
|
||||||
|
expect(service.getHandler('system2')).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should register delete action', () => {
|
||||||
|
expect(service.getHandler('delete')).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should delete folder node', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let folder = new FolderNode();
|
||||||
|
service.getHandler('delete')(folder);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalledWith(folder.entry.id);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should support deletion only folder node', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let file = new FileNode();
|
||||||
|
service.getHandler('delete')(file);
|
||||||
|
expect(alfrescoService.deleteNode).not.toHaveBeenCalled();
|
||||||
|
|
||||||
|
let folder = new FolderNode();
|
||||||
|
service.getHandler('delete')(folder);
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should require node id to delete', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let folder = new FolderNode();
|
||||||
|
folder.entry.id = null;
|
||||||
|
service.getHandler('delete')(folder);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should reload target upon node deletion', () => {
|
||||||
|
spyOn(alfrescoService, 'deleteNode').and.callThrough();
|
||||||
|
|
||||||
|
let target = jasmine.createSpyObj('obj', ['reload']);
|
||||||
|
let folder = new FolderNode();
|
||||||
|
service.getHandler('delete')(folder, target);
|
||||||
|
|
||||||
|
expect(alfrescoService.deleteNode).toHaveBeenCalled();
|
||||||
|
expect(target.reload).toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@@ -35,11 +35,13 @@ export class FolderActionsService {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
setHandler(key: string, handler: ContentActionHandler): void {
|
setHandler(key: string, handler: ContentActionHandler): boolean {
|
||||||
if (key) {
|
if (key) {
|
||||||
let lkey = key.toLowerCase();
|
let lkey = key.toLowerCase();
|
||||||
this.handlers[lkey] = handler;
|
this.handlers[lkey] = handler;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
canExecuteAction(obj: any): boolean {
|
canExecuteAction(obj: any): boolean {
|
||||||
|
Reference in New Issue
Block a user