fix test and coverage Angular2 Final release uploader component #749

This commit is contained in:
Eugenio Romano
2016-10-06 16:18:03 +01:00
parent 94b89fa43d
commit 362e2e32ea
13 changed files with 351 additions and 399 deletions

View File

@@ -15,153 +15,107 @@
* limitations under the License.
*/
/*
import { PLATFORM_PIPES } from '@angular/core';
import { describe, expect, it, inject, beforeEach, beforeEachProviders } from '@angular/core/testing';
import { TestComponentBuilder } from '@angular/compiler/testing';
import { Observable } from 'rxjs/Observable';
import { HTTP_PROVIDERS } from '@angular/http';
import {
AlfrescoTranslationService,
AlfrescoSettingsService,
AlfrescoAuthenticationService,
AlfrescoApiService,
AlfrescoPipeTranslate
} from 'ng2-alfresco-core';
import { ComponentFixture, TestBed, async } from '@angular/core/testing';
import { FileUploadingDialogComponent } from './file-uploading-dialog.component';
import { FileModel } from '../models/file.model';
import { TranslationMock } from '../assets/translation.service.mock';
import { FileUploadingListComponent } from './file-uploading-list.component';
import { DebugElement, ReflectiveInjector } from '@angular/core';
import {
AlfrescoAuthenticationService,
AlfrescoSettingsService,
AlfrescoApiService,
CoreModule
} from 'ng2-alfresco-core';
import { UploadService } from '../services/upload.service';
import { FileModel } from '../models/file.model';
describe('FileUploadDialog', () => {
describe('Test ng2-alfresco-upload FileUploadDialog', () => {
let componentFixture;
let uploadService;
let injector;
let component: any;
let fixture: ComponentFixture<FileUploadingDialogComponent>;
let debug: DebugElement;
let element: any;
let file: FileModel;
beforeEachProviders(() => {
return [
HTTP_PROVIDERS,
AlfrescoApiService,
AlfrescoSettingsService,
AlfrescoAuthenticationService,
{ provide: PLATFORM_PIPES, useValue: AlfrescoPipeTranslate, multi: true },
{ provide: AlfrescoTranslationService, useClass: TranslationMock },
beforeEach(async(() => {
injector = ReflectiveInjector.resolveAndCreate([
UploadService
];
});
]);
beforeEach(
inject(
[TestComponentBuilder, UploadService],
(tcb: TestComponentBuilder, service: UploadService) => {
return tcb
.createAsync(FileUploadingDialogComponent)
.then(fixture => {
componentFixture = fixture;
uploadService = service;
});
}
)
);
TestBed.configureTestingModule({
imports: [
CoreModule
],
declarations: [FileUploadingDialogComponent, FileUploadingListComponent],
providers: [
AlfrescoSettingsService,
AlfrescoAuthenticationService,
AlfrescoApiService,
UploadService
]
}).compileComponents();
}));
beforeEach(() => {
window['componentHandler'] = null;
it('should render completed upload 1 when an element is added to Observer', () => {
let fileFake = {
id: 'fake-id',
name: 'fake-name'
};
let file = new FileModel(fileFake);
file.progress = {'percent': 50};
file = new FileModel(fileFake);
uploadService.totalCompleted$ = new Observable(observer => {
observer.next(1);
});
fixture = TestBed.createComponent(FileUploadingDialogComponent);
debug = fixture.debugElement;
element = fixture.nativeElement;
component = fixture.componentInstance;
let component = componentFixture.componentInstance;
componentFixture.detectChanges();
component.filesUploadingList = [file];
fixture.detectChanges();
});
let compiled = componentFixture.debugElement.nativeElement;
componentFixture.detectChanges();
it('should render completed upload 1 when an element is added to Observer', () => {
component._uploaderService.updateFileCounterStream(1);
fixture.detectChanges();
expect(compiled.querySelector('#total-upload-completed').innerText).toEqual('1');
expect(element.querySelector('#total-upload-completed').innerText).toEqual('1');
});
it('should render dialog box with css class show when an element is added to Observer', () => {
let fileFake = {
id: 'fake-id',
name: 'fake-name'
};
let file = new FileModel(fileFake);
file.progress = {'percent': 50};
let component = componentFixture.componentInstance;
componentFixture.detectChanges();
uploadService.addToQueue([file]);
component._uploaderService.addToQueue([file]);
component.filesUploadingList = [file];
let compiled = componentFixture.debugElement.nativeElement;
fixture.detectChanges();
componentFixture.detectChanges();
expect(compiled.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog show');
expect(element.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog show');
});
it('should render dialog box with css class show when the toggleShowDialog is called', () => {
let fileFake = {
id: 'fake-id',
name: 'fake-name'
};
let file = new FileModel(fileFake);
let component = componentFixture.componentInstance;
componentFixture.detectChanges();
component.filesUploadingList = [file];
let compiled = componentFixture.debugElement.nativeElement;
component.toggleShowDialog();
componentFixture.detectChanges();
fixture.detectChanges();
expect(compiled.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog show');
expect(element.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog show');
});
it('should render dialog box with css class hide', () => {
let fileFake = {
id: 'fake-id',
name: 'fake-name'
};
let file = new FileModel(fileFake);
let component = componentFixture.componentInstance;
component.filesUploadingList = [file];
component.isDialogActive = true;
let compiled = componentFixture.debugElement.nativeElement;
component.toggleShowDialog();
componentFixture.detectChanges();
fixture.detectChanges();
expect(compiled.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog');
expect(element.querySelector('.file-dialog').getAttribute('class')).toEqual('file-dialog');
});
it('should render minimize dialog as default', () => {
let fileFake = {
id: 'fake-id',
name: 'fake-name'
};
let file = new FileModel(fileFake);
let component = componentFixture.componentInstance;
component.filesUploadingList = [file];
component.isDialogActive = true;
let compiled = componentFixture.debugElement.nativeElement;
component.toggleDialogMinimize();
componentFixture.detectChanges();
fixture.detectChanges();
expect(compiled.querySelector('.minimize-button').getAttribute('class')).toEqual('minimize-button active');
expect(element.querySelector('.minimize-button').getAttribute('class')).toEqual('minimize-button active');
});
});
*/