mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
[ACS-5831] Added Generic Error to Library Dialog. (#9005)
* [ACS-5831] Added Generic Error to Library Dialogue. * format fix * format fix * [ci:force]
This commit is contained in:
parent
678df4298d
commit
d500bc67d7
@ -25,12 +25,14 @@ import { of, throwError } from 'rxjs';
|
|||||||
import { delay } from 'rxjs/operators';
|
import { delay } from 'rxjs/operators';
|
||||||
import { SiteEntry } from '@alfresco/js-api';
|
import { SiteEntry } from '@alfresco/js-api';
|
||||||
import { SitesService } from '../../common/services/sites.service';
|
import { SitesService } from '../../common/services/sites.service';
|
||||||
|
import { NotificationService } from '@alfresco/adf-core';
|
||||||
|
|
||||||
describe('LibraryDialogComponent', () => {
|
describe('LibraryDialogComponent', () => {
|
||||||
let fixture: ComponentFixture<LibraryDialogComponent>;
|
let fixture: ComponentFixture<LibraryDialogComponent>;
|
||||||
let component: LibraryDialogComponent;
|
let component: LibraryDialogComponent;
|
||||||
let sitesService: SitesService;
|
let sitesService: SitesService;
|
||||||
let findSitesSpy;
|
let findSitesSpy;
|
||||||
|
let notificationService: NotificationService;
|
||||||
const findSitesResponse = { list: { entries: [] } };
|
const findSitesResponse = { list: { entries: [] } };
|
||||||
const dialogRef = {
|
const dialogRef = {
|
||||||
close: jasmine.createSpy('close')
|
close: jasmine.createSpy('close')
|
||||||
@ -51,6 +53,7 @@ describe('LibraryDialogComponent', () => {
|
|||||||
component = fixture.componentInstance;
|
component = fixture.componentInstance;
|
||||||
sitesService = TestBed.inject(SitesService);
|
sitesService = TestBed.inject(SitesService);
|
||||||
findSitesSpy = spyOn(component['queriesApi'], 'findSites');
|
findSitesSpy = spyOn(component['queriesApi'], 'findSites');
|
||||||
|
notificationService = TestBed.inject(NotificationService);
|
||||||
});
|
});
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
@ -205,6 +208,26 @@ describe('LibraryDialogComponent', () => {
|
|||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
it('should handle default errors and show generic error in snackbar', fakeAsync(() => {
|
||||||
|
findSitesSpy.and.returnValue(Promise.resolve(findSitesResponse));
|
||||||
|
const error = {};
|
||||||
|
spyOn(sitesService, 'createSite').and.callFake(() => throwError(error));
|
||||||
|
spyOn(sitesService, 'getSite').and.callFake(() => throwError('error'));
|
||||||
|
spyOn(notificationService, 'showError').and.callThrough();
|
||||||
|
|
||||||
|
fixture.detectChanges();
|
||||||
|
component.form.controls.title.setValue('test');
|
||||||
|
tick(500);
|
||||||
|
flush();
|
||||||
|
fixture.detectChanges();
|
||||||
|
|
||||||
|
component.submit();
|
||||||
|
fixture.detectChanges();
|
||||||
|
flush();
|
||||||
|
|
||||||
|
expect(notificationService.showError).toHaveBeenCalledWith('CORE.MESSAGES.ERRORS.GENERIC');
|
||||||
|
}));
|
||||||
|
|
||||||
it('should not translate library title if value is not a valid id', fakeAsync(() => {
|
it('should not translate library title if value is not a valid id', fakeAsync(() => {
|
||||||
findSitesSpy.and.returnValue(Promise.resolve(findSitesResponse));
|
findSitesSpy.and.returnValue(Promise.resolve(findSitesResponse));
|
||||||
spyOn(sitesService, 'getSite').and.callFake(() => throwError('error'));
|
spyOn(sitesService, 'getSite').and.callFake(() => throwError('error'));
|
||||||
|
@ -33,7 +33,7 @@ import {
|
|||||||
} from '@angular/forms';
|
} from '@angular/forms';
|
||||||
import { MatDialogRef } from '@angular/material/dialog';
|
import { MatDialogRef } from '@angular/material/dialog';
|
||||||
import { QueriesApi, SiteBodyCreate, SiteEntry, SitePaging } from '@alfresco/js-api';
|
import { QueriesApi, SiteBodyCreate, SiteEntry, SitePaging } from '@alfresco/js-api';
|
||||||
import { AlfrescoApiService } from '@alfresco/adf-core';
|
import { AlfrescoApiService, NotificationService } from '@alfresco/adf-core';
|
||||||
import { debounceTime, finalize, mergeMap, takeUntil } from 'rxjs/operators';
|
import { debounceTime, finalize, mergeMap, takeUntil } from 'rxjs/operators';
|
||||||
import { SitesService } from '../../common/services/sites.service';
|
import { SitesService } from '../../common/services/sites.service';
|
||||||
|
|
||||||
@ -84,7 +84,8 @@ export class LibraryDialogComponent implements OnInit, OnDestroy {
|
|||||||
private alfrescoApiService: AlfrescoApiService,
|
private alfrescoApiService: AlfrescoApiService,
|
||||||
private sitesService: SitesService,
|
private sitesService: SitesService,
|
||||||
private formBuilder: UntypedFormBuilder,
|
private formBuilder: UntypedFormBuilder,
|
||||||
private dialog: MatDialogRef<LibraryDialogComponent>
|
private dialog: MatDialogRef<LibraryDialogComponent>,
|
||||||
|
private notificationService: NotificationService
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -198,6 +199,8 @@ export class LibraryDialogComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private handleError(error: any): any {
|
private handleError(error: any): any {
|
||||||
|
let errorMessage = 'CORE.MESSAGES.ERRORS.GENERIC';
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const {
|
const {
|
||||||
error: { statusCode }
|
error: { statusCode }
|
||||||
@ -209,6 +212,7 @@ export class LibraryDialogComponent implements OnInit, OnDestroy {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
|
this.notificationService.showError(errorMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
return error;
|
return error;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user