alfresco-content-app/src/app/app.component.spec.ts
Denys Vuika 9db1c2989f
shared library (#1080)
* shared project scaffold

* rules package

* move evaluators to shared lib

* add rxjs peer dependency

* use dedicated material namespaces

* create store package, move actions

* move selectors to shared library

* move generic effects to shared lib

* move routing extensions

* minor code reorg

* fix unit tests

* move content-api service

* move permission service

* update tests

* update plint config

* move page layout

* css variables

* use dedicated css property

* move generic error component to shared lib

* fix test
2019-04-25 14:56:54 +01:00

120 lines
3.6 KiB
TypeScript

/*!
* @license
* Alfresco Example Content Application
*
* Copyright (C) 2005 - 2019 Alfresco Software Limited
*
* This file is part of the Alfresco Example Content Application.
* If the software was purchased under a paid Alfresco license, the terms of
* the paid license agreement will prevail. Otherwise, the software is
* provided under the following open source license terms:
*
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
*/
import { AppComponent } from './app.component';
import { SetInitialStateAction } from '@alfresco/aca-shared/store';
describe('AppComponent', () => {
let component: AppComponent;
const storeMock: any = {
dispatch: jasmine.createSpy('dispatch')
};
const configMock: any = {
get: (key: string) => {
if (key === 'baseShareUrl') {
return 'http://localhost:4200/#/preview/s';
}
return null;
}
};
beforeAll(() => {
component = new AppComponent(
null,
null,
null,
storeMock,
configMock,
null,
null,
null,
null,
null,
null
);
});
beforeEach(() => {
storeMock.dispatch = jasmine.createSpy('dispatch');
});
it('should setup baseShareUrl as per config', done => {
storeMock.dispatch.and.callFake((action: SetInitialStateAction) => {
expect(action.payload.sharedUrl).toBe(
'http://localhost:4200/#/preview/s/'
);
done();
});
component.loadAppSettings();
});
describe('onFileUploadedError', () => {
it('should dispatch 403 error message', () => {
component.onFileUploadedError(<any>{ error: { status: 403 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.403'
);
});
it('should dispatch 404 error message', () => {
component.onFileUploadedError(<any>{ error: { status: 404 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.404'
);
});
it('should dispatch 409 error message', () => {
component.onFileUploadedError(<any>{ error: { status: 409 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.CONFLICT'
);
});
it('should dispatch 500 error message', () => {
component.onFileUploadedError(<any>{ error: { status: 500 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.500'
);
});
it('should dispatch 504 error message', () => {
component.onFileUploadedError(<any>{ error: { status: 504 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.504'
);
});
it('should dispatch generic error message', () => {
component.onFileUploadedError(<any>{ error: { status: 999 } });
expect(storeMock.dispatch['calls'].argsFor(0)[0].payload).toBe(
'APP.MESSAGES.UPLOAD.ERROR.GENERIC'
);
});
});
});