mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
* Fixed failing unit tests on process-services. (#5080)
This commit is contained in:
parent
b2966bc6f5
commit
30089f485f
22
lib/process-services/mock/process/process-comments.mock.ts
Normal file
22
lib/process-services/mock/process/process-comments.mock.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2019 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
export let mockProcessInstanceComments = [
|
||||||
|
{ message: 'Test1', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} },
|
||||||
|
{ message: 'Test2', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} },
|
||||||
|
{ message: 'Test3', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} }
|
||||||
|
];
|
@ -65,6 +65,19 @@ export let processEnded = new ProcessInstance({
|
|||||||
ended: '2016-11-11T03:37:30.010+0000'
|
ended: '2016-11-11T03:37:30.010+0000'
|
||||||
});
|
});
|
||||||
|
|
||||||
|
export let mockRunningProcess = new ProcessInstance({
|
||||||
|
id: '123',
|
||||||
|
name: 'Process 123',
|
||||||
|
started: '2016-11-10T03:37:30.010+0000',
|
||||||
|
startedBy: {
|
||||||
|
id: 1001,
|
||||||
|
firstName: 'Bob',
|
||||||
|
lastName: 'Jones',
|
||||||
|
email: 'bob@app.activiti.com'
|
||||||
|
},
|
||||||
|
ended: null
|
||||||
|
});
|
||||||
|
|
||||||
export let exampleProcessNoName = new ProcessInstance({
|
export let exampleProcessNoName = new ProcessInstance({
|
||||||
id: '123',
|
id: '123',
|
||||||
name: null,
|
name: null,
|
||||||
|
@ -19,6 +19,7 @@ export * from './process/process-instances-list.mock';
|
|||||||
export * from './process/process.service.mock';
|
export * from './process/process.service.mock';
|
||||||
export * from './process/start-process.component.mock';
|
export * from './process/start-process.component.mock';
|
||||||
export * from './process/process.model.mock';
|
export * from './process/process.model.mock';
|
||||||
|
export * from './process/process-comments.mock';
|
||||||
|
|
||||||
export * from './task/start-task.mock';
|
export * from './task/start-task.mock';
|
||||||
export * from './task/task-details.mock';
|
export * from './task/task-details.mock';
|
||||||
|
@ -23,6 +23,7 @@ import { CommentProcessService, setupTestBed } from '@alfresco/adf-core';
|
|||||||
|
|
||||||
import { ProcessCommentsComponent } from './process-comments.component';
|
import { ProcessCommentsComponent } from './process-comments.component';
|
||||||
import { ProcessTestingModule } from '../testing/process.testing.module';
|
import { ProcessTestingModule } from '../testing/process.testing.module';
|
||||||
|
import { mockProcessInstanceComments } from '../mock/process/process-comments.mock';
|
||||||
|
|
||||||
describe('ProcessCommentsComponent', () => {
|
describe('ProcessCommentsComponent', () => {
|
||||||
|
|
||||||
@ -41,11 +42,7 @@ describe('ProcessCommentsComponent', () => {
|
|||||||
component = fixture.componentInstance;
|
component = fixture.componentInstance;
|
||||||
commentProcessService = TestBed.get(CommentProcessService);
|
commentProcessService = TestBed.get(CommentProcessService);
|
||||||
|
|
||||||
getCommentsSpy = spyOn(commentProcessService, 'getProcessInstanceComments').and.returnValue(of([
|
getCommentsSpy = spyOn(commentProcessService, 'getProcessInstanceComments').and.returnValue(of(mockProcessInstanceComments));
|
||||||
{ message: 'Test1', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} },
|
|
||||||
{ message: 'Test2', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} },
|
|
||||||
{ message: 'Test3', created: Date.now(), createdBy: {firstName: 'Admin', lastName: 'User'} }
|
|
||||||
]));
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should load comments when processInstanceId specified', () => {
|
it('should load comments when processInstanceId specified', () => {
|
||||||
|
@ -20,11 +20,11 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|||||||
import { By } from '@angular/platform-browser';
|
import { By } from '@angular/platform-browser';
|
||||||
import { of } from 'rxjs';
|
import { of } from 'rxjs';
|
||||||
|
|
||||||
import { setupTestBed } from '@alfresco/adf-core';
|
import { setupTestBed, CommentProcessService } from '@alfresco/adf-core';
|
||||||
import { TaskListModule } from '../../task-list/task-list.module';
|
import { TaskListModule } from '../../task-list/task-list.module';
|
||||||
|
|
||||||
import { ProcessInstance } from '../models/process-instance.model';
|
import { exampleProcess, exampleProcessNoName, mockRunningProcess, processEnded } from './../../mock';
|
||||||
import { exampleProcess, exampleProcessNoName } from './../../mock';
|
import { mockProcessInstanceComments } from './../../mock/process/process-comments.mock';
|
||||||
import { ProcessService } from './../services/process.service';
|
import { ProcessService } from './../services/process.service';
|
||||||
import { ProcessInstanceDetailsComponent } from './process-instance-details.component';
|
import { ProcessInstanceDetailsComponent } from './process-instance-details.component';
|
||||||
import { ProcessTestingModule } from '../../testing/process.testing.module';
|
import { ProcessTestingModule } from '../../testing/process.testing.module';
|
||||||
@ -54,8 +54,15 @@ describe('ProcessInstanceDetailsComponent', () => {
|
|||||||
fixture = TestBed.createComponent(ProcessInstanceDetailsComponent);
|
fixture = TestBed.createComponent(ProcessInstanceDetailsComponent);
|
||||||
component = fixture.componentInstance;
|
component = fixture.componentInstance;
|
||||||
service = fixture.debugElement.injector.get(ProcessService);
|
service = fixture.debugElement.injector.get(ProcessService);
|
||||||
|
const commentService = fixture.debugElement.injector.get(CommentProcessService);
|
||||||
|
|
||||||
getProcessSpy = spyOn(service, 'getProcess').and.returnValue(of(exampleProcess));
|
getProcessSpy = spyOn(service, 'getProcess').and.returnValue(of(exampleProcess));
|
||||||
|
spyOn(commentService, 'getProcessInstanceComments').and.returnValue(of(mockProcessInstanceComments));
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
getProcessSpy.calls.reset();
|
||||||
|
fixture.destroy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not load task details when no processInstanceId is specified', () => {
|
it('should not load task details when no processInstanceId is specified', () => {
|
||||||
@ -80,7 +87,8 @@ describe('ProcessInstanceDetailsComponent', () => {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
it('should display default details when the process instance has no name', async(() => {
|
it('should display default details when the process instance has no name', async(() => {
|
||||||
getProcessSpy = getProcessSpy.and.returnValue(of(exampleProcessNoName));
|
fixture.detectChanges();
|
||||||
|
getProcessSpy.and.returnValue(of(exampleProcessNoName));
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
component.ngOnChanges({ 'processInstanceId': new SimpleChange(null, '123', true) });
|
component.ngOnChanges({ 'processInstanceId': new SimpleChange(null, '123', true) });
|
||||||
fixture.whenStable().then(() => {
|
fixture.whenStable().then(() => {
|
||||||
@ -91,83 +99,83 @@ describe('ProcessInstanceDetailsComponent', () => {
|
|||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
it('should enable diagram button if the process is running', async(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
getProcessSpy.and.returnValue(of(mockRunningProcess));
|
||||||
|
fixture.detectChanges();
|
||||||
|
component.ngOnChanges({ 'processInstanceId': new SimpleChange(null, '123', true) });
|
||||||
|
fixture.whenStable().then(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
const diagramButton = fixture.debugElement.query(By.css('#show-diagram-button'));
|
||||||
|
expect(diagramButton).not.toBeNull();
|
||||||
|
expect(diagramButton.nativeElement.disabled).toBe(false);
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
|
it('should disable diagram button if the process is running', async(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
getProcessSpy.and.returnValue(of(processEnded));
|
||||||
|
fixture.detectChanges();
|
||||||
|
component.ngOnChanges({ 'processInstanceId': new SimpleChange(null, '123', true) });
|
||||||
|
fixture.whenStable().then(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
const diagramButton = fixture.debugElement.query(By.css('#show-diagram-button'));
|
||||||
|
expect(diagramButton).not.toBeNull();
|
||||||
|
expect(diagramButton.nativeElement.disabled).toBe(true);
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
describe('change detection', () => {
|
describe('change detection', () => {
|
||||||
|
|
||||||
const change = new SimpleChange('123', '456', true);
|
const change = new SimpleChange('123', '456', true);
|
||||||
const nullChange = new SimpleChange('123', null, true);
|
const nullChange = new SimpleChange('123', null, true);
|
||||||
|
|
||||||
beforeEach(async(() => {
|
beforeEach(() => {
|
||||||
component.processInstanceId = '123';
|
component.processInstanceId = '123';
|
||||||
fixture.detectChanges();
|
|
||||||
component.tasksList = jasmine.createSpyObj('tasksList', ['load']);
|
component.tasksList = jasmine.createSpyObj('tasksList', ['load']);
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should fetch new process details when processInstanceId changed', async(() => {
|
||||||
|
fixture.detectChanges();
|
||||||
|
component.ngOnChanges({ 'processInstanceId': change });
|
||||||
fixture.whenStable().then(() => {
|
fixture.whenStable().then(() => {
|
||||||
getProcessSpy.calls.reset();
|
fixture.detectChanges();
|
||||||
|
expect(getProcessSpy).toHaveBeenCalledWith('456');
|
||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
// tslint:disable-next-line: ban
|
it('should NOT fetch new process details when empty changeset made', async(() => {
|
||||||
xit('should fetch new process details when processInstanceId changed', () => {
|
fixture.detectChanges();
|
||||||
component.ngOnChanges({ 'processInstanceId': change });
|
|
||||||
expect(getProcessSpy).toHaveBeenCalledWith('456');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should NOT fetch new process details when empty changeset made', () => {
|
|
||||||
component.ngOnChanges({});
|
component.ngOnChanges({});
|
||||||
expect(getProcessSpy).not.toHaveBeenCalled();
|
fixture.whenStable().then(() => {
|
||||||
});
|
expect(getProcessSpy).not.toHaveBeenCalled();
|
||||||
|
|
||||||
// tslint:disable-next-line: ban
|
|
||||||
xit('should NOT fetch new process details when processInstanceId changed to null', () => {
|
|
||||||
component.ngOnChanges({ 'processInstanceId': nullChange });
|
|
||||||
expect(getProcessSpy).not.toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
|
|
||||||
// tslint:disable-next-line: ban
|
|
||||||
xit('should set a placeholder message when processInstanceId changed to null', () => {
|
|
||||||
component.ngOnChanges({ 'processInstanceId': nullChange });
|
|
||||||
fixture.detectChanges();
|
|
||||||
expect(fixture.nativeElement.innerText).toBe('ADF_PROCESS_LIST.DETAILS.MESSAGES.NONE');
|
|
||||||
});
|
|
||||||
|
|
||||||
// tslint:disable-next-line: ban
|
|
||||||
xit('should display cancel button if process is running', () => {
|
|
||||||
component.processInstanceDetails = new ProcessInstance({
|
|
||||||
ended: null
|
|
||||||
});
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
|
it('should NOT fetch new process details when processInstanceId changed to null', async(() => {
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
const buttonEl = fixture.debugElement.query(By.css('[data-automation-id="header-status"] button'));
|
component.ngOnChanges({ 'processInstanceId': nullChange });
|
||||||
expect(buttonEl).not.toBeNull();
|
fixture.whenStable().then(() => {
|
||||||
});
|
expect(getProcessSpy).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
describe('Diagram', () => {
|
it('should set a placeholder message when processInstanceId changed to null', async(() => {
|
||||||
|
component.ngOnChanges({ 'processInstanceId': nullChange });
|
||||||
// tslint:disable-next-line: ban
|
fixture.whenStable().then(() => {
|
||||||
xit('should enable diagram button if the process is running', async(() => {
|
|
||||||
component.processInstanceDetails = new ProcessInstance({
|
|
||||||
ended: null
|
|
||||||
});
|
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
|
expect(fixture.nativeElement.innerText).toBe('ADF_PROCESS_LIST.DETAILS.MESSAGES.NONE');
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
fixture.whenStable().then(() => {
|
it('should display cancel button if process is running', async(() => {
|
||||||
const diagramButton = fixture.debugElement.query(By.css('#show-diagram-button'));
|
component.ngOnChanges({ 'processInstanceId': change });
|
||||||
expect(diagramButton).not.toBeNull();
|
fixture.whenStable().then(() => {
|
||||||
expect(diagramButton.nativeElement.disabled).toBe(false);
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
|
|
||||||
it('should disable diagram button if the process is running', async(() => {
|
|
||||||
component.processInstanceDetails = new ProcessInstance({
|
|
||||||
ended: new Date()
|
|
||||||
});
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
|
const buttonEl = fixture.debugElement.query(By.css('[data-automation-id="header-status"] button'));
|
||||||
fixture.whenStable().then(() => {
|
expect(buttonEl).not.toBeNull();
|
||||||
const diagramButton = fixture.debugElement.query(By.css('#show-diagram-button'));
|
});
|
||||||
expect(diagramButton).not.toBeNull();
|
}));
|
||||||
expect(diagramButton.nativeElement.disabled).toBe(true);
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user