mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-19 17:14:57 +00:00
* custom tslint rules adf project name files * filename and class prefix rule * filename process service mock * fix spec filename * fix demo shell * rename mock * alias deprecated name class * core rename services * fix pacakge.json adf-rules * add exclude in whitelist
165 lines
6.6 KiB
TypeScript
165 lines
6.6 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2016 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.
|
|
*/
|
|
|
|
import { DebugElement } from '@angular/core';
|
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|
import { By } from '@angular/platform-browser';
|
|
import { AlfrescoTranslationService, CardViewUpdateService, CoreModule } from 'ng2-alfresco-core';
|
|
import { Observable } from 'rxjs/Rx';
|
|
|
|
import { TaskDetailsModel } from '../models/task-details.model';
|
|
import { taskDetailsMock } from './../assets/task-details.mock';
|
|
import { TaskListService } from './../services/tasklist.service';
|
|
import { TaskHeaderComponent } from './task-header.component';
|
|
|
|
describe('TaskHeaderComponent', () => {
|
|
|
|
let service: TaskListService;
|
|
let componentHandler: any;
|
|
let component: TaskHeaderComponent;
|
|
let fixture: ComponentFixture<TaskHeaderComponent>;
|
|
let debugElement: DebugElement;
|
|
|
|
beforeEach(async(() => {
|
|
TestBed.configureTestingModule({
|
|
imports: [
|
|
CoreModule.forRoot()
|
|
],
|
|
declarations: [
|
|
TaskHeaderComponent
|
|
],
|
|
providers: [
|
|
TaskListService,
|
|
CardViewUpdateService
|
|
]
|
|
}).compileComponents();
|
|
|
|
let translateService = TestBed.get(AlfrescoTranslationService);
|
|
spyOn(translateService, 'addTranslationFolder').and.stub();
|
|
spyOn(translateService.translate, 'get').and.callFake((key) => { return Observable.of(key); });
|
|
}));
|
|
|
|
beforeEach(() => {
|
|
fixture = TestBed.createComponent(TaskHeaderComponent);
|
|
component = fixture.componentInstance;
|
|
service = TestBed.get(TaskListService);
|
|
debugElement = fixture.debugElement;
|
|
|
|
component.taskDetails = new TaskDetailsModel(taskDetailsMock);
|
|
|
|
componentHandler = jasmine.createSpyObj('componentHandler', [
|
|
'upgradeAllRegistered',
|
|
'upgradeElement'
|
|
]);
|
|
window['componentHandler'] = componentHandler;
|
|
});
|
|
|
|
it('should render empty component if no task details provided', () => {
|
|
component.taskDetails = undefined;
|
|
fixture.detectChanges();
|
|
expect(fixture.debugElement.children.length).toBe(0);
|
|
});
|
|
|
|
it('should display assignee', () => {
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let formNameEl = fixture.debugElement.query(By.css('[data-automation-id="header-assignee"] .adf-property-value'));
|
|
expect(formNameEl.nativeElement.innerText).toBe('Wilbur Adams');
|
|
});
|
|
|
|
it('should display placeholder if no assignee', () => {
|
|
component.taskDetails.assignee = null;
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-assignee"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText).toBe('No assignee');
|
|
});
|
|
|
|
it('should display created-by', () => {
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let formNameEl = fixture.debugElement.query(By.css('[data-automation-id="header-created-by"] .adf-property-value'));
|
|
expect(formNameEl.nativeElement.innerText).toBe('Wilbur Adams');
|
|
});
|
|
|
|
it('should display placeholder if no created-by', () => {
|
|
component.taskDetails.assignee = null;
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-created-by"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText).toBe('No assignee');
|
|
});
|
|
|
|
it('should set editable to false if the task has already completed', () => {
|
|
component.taskDetails.endDate = '05/05/2002';
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
|
|
let datePicker = fixture.debugElement.query(By.css(`[data-automation-id="datepicker-dueDate"]`));
|
|
expect(datePicker).toBeNull('Datepicker should NOT be in DOM');
|
|
});
|
|
|
|
it('should set editable to true if the task has not completed yet', () => {
|
|
component.taskDetails.endDate = undefined;
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
|
|
let datePicker = fixture.debugElement.query(By.css(`[data-automation-id="datepicker-dueDate"]`));
|
|
expect(datePicker).not.toBeNull('Datepicker should be in DOM');
|
|
});
|
|
|
|
it('should display the claim button if no assignee', () => {
|
|
component.taskDetails.assignee = null;
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-claim-button"]'));
|
|
expect(valueEl.nativeElement.innerText).toBe('TASK_DETAILS.BUTTON.CLAIM');
|
|
});
|
|
|
|
it('should display due date', () => {
|
|
component.taskDetails.dueDate = '2016-11-03';
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-dueDate"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText.trim()).toBe('Nov 03 2016');
|
|
});
|
|
|
|
it('should display placeholder if no due date', () => {
|
|
component.taskDetails.dueDate = null;
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-dueDate"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText.trim()).toBe('No date');
|
|
});
|
|
|
|
it('should display form name', () => {
|
|
component.formName = 'test form';
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-formName"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText).toBe('test form');
|
|
});
|
|
|
|
it('should not display form name if no form name provided', () => {
|
|
component.ngOnChanges({});
|
|
fixture.detectChanges();
|
|
let valueEl = fixture.debugElement.query(By.css('[data-automation-id="header-formName"] .adf-property-value'));
|
|
expect(valueEl.nativeElement.innerText).toBe('No form');
|
|
});
|
|
|
|
});
|