mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
177 lines
5.2 KiB
177 lines
5.2 KiB
/*
|
|
* Squidex Headless CMS
|
|
*
|
|
* @license
|
|
* Copyright (c) Squidex UG (haftungsbeschränkt). All rights reserved.
|
|
*/
|
|
|
|
import { never, of, throwError } from 'rxjs';
|
|
import { onErrorResumeNext } from 'rxjs/operators';
|
|
import { IMock, Mock } from 'typemoq';
|
|
|
|
import {
|
|
AssetDto,
|
|
AssetsService,
|
|
AssetUploaderState,
|
|
DialogService,
|
|
ofForever,
|
|
Types
|
|
} from '@app/shared/internal';
|
|
|
|
import { createAsset } from './../services/assets.service.spec';
|
|
|
|
import { TestValues } from './_test-helpers';
|
|
|
|
describe('AssetsState', () => {
|
|
const {
|
|
app,
|
|
appsState
|
|
} = TestValues;
|
|
|
|
let assetsService: IMock<AssetsService>;
|
|
let dialogs: IMock<DialogService>;
|
|
let assetUploader: AssetUploaderState;
|
|
|
|
const asset = createAsset(1);
|
|
|
|
beforeEach(() => {
|
|
dialogs = Mock.ofType<DialogService>();
|
|
|
|
assetsService = Mock.ofType<AssetsService>();
|
|
assetUploader = new AssetUploaderState(appsState.object, assetsService.object, dialogs.object);
|
|
});
|
|
|
|
afterEach(() => {
|
|
assetsService.verifyAll();
|
|
});
|
|
|
|
it('should create initial state when uploading file', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.uploadFile(app, file))
|
|
.returns(() => never()).verifiable();
|
|
|
|
assetUploader.uploadFile(file).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Running');
|
|
expect(upload.progress).toBe(1);
|
|
});
|
|
|
|
it('should update progress when uploading file makes progress', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.uploadFile(app, file))
|
|
.returns(() => ofForever(10, 20)).verifiable();
|
|
|
|
assetUploader.uploadFile(file).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Running');
|
|
expect(upload.progress).toBe(20);
|
|
});
|
|
|
|
it('should update status when uploading file failed', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.uploadFile(app, file))
|
|
.returns(() => throwError('Error')).verifiable();
|
|
|
|
assetUploader.uploadFile(file).pipe(onErrorResumeNext()).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Failed');
|
|
expect(upload.progress).toBe(1);
|
|
});
|
|
|
|
it('should update status when uploading file completes', (cb) => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.uploadFile(app, file))
|
|
.returns(() => of(10, 20, asset)).verifiable();
|
|
|
|
let uploadedAsset: AssetDto;
|
|
|
|
assetUploader.uploadFile(file).subscribe(dto => {
|
|
if (Types.is(dto, AssetDto)) {
|
|
uploadedAsset = dto;
|
|
}
|
|
|
|
cb();
|
|
});
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Completed');
|
|
expect(upload.progress).toBe(100);
|
|
expect(uploadedAsset!).toEqual(asset);
|
|
});
|
|
|
|
it('should create initial state when uploading asset', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.replaceFile(app, asset, file, asset.version))
|
|
.returns(() => never()).verifiable();
|
|
|
|
assetUploader.uploadAsset(asset, file).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Running');
|
|
expect(upload.progress).toBe(1);
|
|
});
|
|
|
|
it('should update progress when uploading asset makes progress', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.replaceFile(app, asset, file, asset.version))
|
|
.returns(() => ofForever(10, 20)).verifiable();
|
|
|
|
assetUploader.uploadAsset(asset, file).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Running');
|
|
expect(upload.progress).toBe(20);
|
|
});
|
|
|
|
it('should update status when uploading asset failed', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
assetsService.setup(x => x.replaceFile(app, asset, file, asset.version))
|
|
.returns(() => throwError('Error')).verifiable();
|
|
|
|
assetUploader.uploadAsset(asset, file).pipe(onErrorResumeNext()).subscribe();
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Failed');
|
|
expect(upload.progress).toBe(1);
|
|
});
|
|
|
|
it('should update status when uploading asset completes', () => {
|
|
const file: File = <any>{ name: 'my-file' };
|
|
|
|
let updated = createAsset(1, undefined, '-new');
|
|
|
|
assetsService.setup(x => x.replaceFile(app, asset, file, asset.version))
|
|
.returns(() => of(10, 20, updated)).verifiable();
|
|
|
|
let uploadedAsset: AssetDto;
|
|
|
|
assetUploader.uploadAsset(asset, file).subscribe(dto => {
|
|
if (Types.is(dto, AssetDto)) {
|
|
uploadedAsset = dto;
|
|
}
|
|
});
|
|
|
|
const upload = assetUploader.snapshot.uploads.at(0);
|
|
|
|
expect(upload.status).toBe('Completed');
|
|
expect(upload.progress).toBe(100);
|
|
expect(uploadedAsset!).toEqual(updated);
|
|
});
|
|
});
|