mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
Improved 'upload' tests
This commit is contained in:
@@ -15,7 +15,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import { describe, expect, it, inject, beforeEachProviders } from '@angular/core/testing';
|
||||
import { describe, expect, it, inject, beforeEach, beforeEachProviders } from '@angular/core/testing';
|
||||
import { TestComponentBuilder } from '@angular/compiler/testing';
|
||||
import { UploadButtonComponent } from './upload-button.component';
|
||||
import { AlfrescoTranslationService, AlfrescoSettingsService } from 'ng2-alfresco-core';
|
||||
@@ -29,6 +29,8 @@ declare var AlfrescoApi: any;
|
||||
|
||||
describe('AlfrescoUploadButton', () => {
|
||||
|
||||
let uploadButtonFixture;
|
||||
|
||||
beforeEach( () => {
|
||||
window['AlfrescoApi'] = AlfrescoApiMock;
|
||||
window['componentHandler'] = null;
|
||||
@@ -42,114 +44,92 @@ describe('AlfrescoUploadButton', () => {
|
||||
];
|
||||
});
|
||||
|
||||
it('should render upload-single-file button as default',
|
||||
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
component.multipleFiles = false;
|
||||
let compiled = fixture.debugElement.nativeElement;
|
||||
fixture.detectChanges();
|
||||
expect(compiled.querySelector('#upload-single-file')).toBeDefined();
|
||||
});
|
||||
}));
|
||||
|
||||
it('should render upload-multiple-file button if multipleFiles is true',
|
||||
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
component.multipleFiles = true;
|
||||
let compiled = fixture.debugElement.nativeElement;
|
||||
fixture.detectChanges();
|
||||
expect(compiled.querySelector('#upload-multiple-files')).toBeDefined();
|
||||
});
|
||||
}));
|
||||
|
||||
it('should render an uploadFolder button if uploadFolder is true',
|
||||
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
component.uploadFolder = true;
|
||||
let compiled = fixture.debugElement.nativeElement;
|
||||
fixture.detectChanges();
|
||||
expect(compiled.querySelector('#uploadFolder')).toBeDefined();
|
||||
});
|
||||
}));
|
||||
|
||||
it('should call uploadFile with the default folder', inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
beforeEach( inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
component.currentFolderPath = '/root-fake-/sites-fake/folder-fake';
|
||||
component.onSuccess = null;
|
||||
component._uploaderService.uploadFilesInTheQueue = jasmine.createSpy('uploadFilesInTheQueue');
|
||||
|
||||
fixture.detectChanges();
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'fake-folder1/fake-name-1.json'};
|
||||
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
|
||||
component.onFilesAdded(fakeEvent);
|
||||
expect(component._uploaderService.uploadFilesInTheQueue).toHaveBeenCalledWith('/root-fake-/sites-fake/folder-fake', null);
|
||||
});
|
||||
.then(fixture => uploadButtonFixture = fixture);
|
||||
}));
|
||||
|
||||
it('should create a folder and call upload file', inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
it('should render upload-single-file button as default', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
component.multipleFiles = false;
|
||||
let compiled = uploadButtonFixture.debugElement.nativeElement;
|
||||
uploadButtonFixture.detectChanges();
|
||||
expect(compiled.querySelector('#upload-single-file')).toBeDefined();
|
||||
});
|
||||
|
||||
component.uploadFiles = jasmine.createSpy('uploadFiles');
|
||||
let doneFn = jasmine.createSpy('success');
|
||||
it('should render upload-multiple-file button if multipleFiles is true', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
component.multipleFiles = true;
|
||||
let compiled = uploadButtonFixture.debugElement.nativeElement;
|
||||
uploadButtonFixture.detectChanges();
|
||||
expect(compiled.querySelector('#upload-multiple-files')).toBeDefined();
|
||||
});
|
||||
|
||||
fixture.detectChanges();
|
||||
it('should render an uploadFolder button if uploadFolder is true', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
component.uploadFolder = true;
|
||||
let compiled = uploadButtonFixture.debugElement.nativeElement;
|
||||
uploadButtonFixture.detectChanges();
|
||||
expect(compiled.querySelector('#uploadFolder')).toBeDefined();
|
||||
});
|
||||
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'fake-folder1/fake-name-1.json'};
|
||||
it('should call uploadFile with the default folder', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
component.currentFolderPath = '/root-fake-/sites-fake/folder-fake';
|
||||
component.onSuccess = null;
|
||||
component._uploaderService.uploadFilesInTheQueue = jasmine.createSpy('uploadFilesInTheQueue');
|
||||
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
component.onDirectoryAdded(fakeEvent);
|
||||
expect(doneFn).not.toHaveBeenCalledWith(fakeEvent);
|
||||
});
|
||||
}));
|
||||
uploadButtonFixture.detectChanges();
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'fake-folder1/fake-name-1.json'};
|
||||
|
||||
it('should throws an exception when the folder already exist', inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
|
||||
return tcb
|
||||
.createAsync(UploadButtonComponent)
|
||||
.then((fixture) => {
|
||||
let component = fixture.componentInstance;
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
|
||||
component.uploadFiles = jasmine.createSpy('uploadFiles');
|
||||
component.onFilesAdded(fakeEvent);
|
||||
expect(component._uploaderService.uploadFilesInTheQueue).toHaveBeenCalledWith('/root-fake-/sites-fake/folder-fake', null);
|
||||
});
|
||||
|
||||
fixture.detectChanges();
|
||||
it('should create a folder and call upload file', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'folder-duplicate-fake/fake-name-1.json'};
|
||||
component.uploadFiles = jasmine.createSpy('uploadFiles');
|
||||
let doneFn = jasmine.createSpy('success');
|
||||
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
component.onDirectoryAdded(fakeEvent);
|
||||
expect(component.uploadFiles).not.toHaveBeenCalledWith(fakeEvent);
|
||||
});
|
||||
}));
|
||||
uploadButtonFixture.detectChanges();
|
||||
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'fake-folder1/fake-name-1.json'};
|
||||
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
component.onDirectoryAdded(fakeEvent);
|
||||
expect(doneFn).not.toHaveBeenCalledWith(fakeEvent);
|
||||
});
|
||||
|
||||
it('should throws an exception when the folder already exist', () => {
|
||||
let component = uploadButtonFixture.componentInstance;
|
||||
|
||||
component.uploadFiles = jasmine.createSpy('uploadFiles');
|
||||
|
||||
uploadButtonFixture.detectChanges();
|
||||
|
||||
let file = {name: 'fake-name-1', size: 10, webkitRelativePath: 'folder-duplicate-fake/fake-name-1.json'};
|
||||
|
||||
let fakeEvent = {
|
||||
currentTarget: {
|
||||
files: [file]
|
||||
},
|
||||
target: {value: 'fake-value'}
|
||||
};
|
||||
component.onDirectoryAdded(fakeEvent);
|
||||
expect(component.uploadFiles).not.toHaveBeenCalledWith(fakeEvent);
|
||||
});
|
||||
});
|
||||
|
Reference in New Issue
Block a user