Files
dspace-angular/src/app/profile-page/profile-page-metadata-form/profile-page-metadata-form.component.spec.ts
Kristof De Langhe 20f8f913cf 69432: Tests
2020-03-12 10:18:49 +01:00

143 lines
4.4 KiB
TypeScript

import { ProfilePageMetadataFormComponent } from './profile-page-metadata-form.component';
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { VarDirective } from '../../shared/utils/var.directive';
import { TranslateModule, TranslateService } from '@ngx-translate/core';
import { RouterTestingModule } from '@angular/router/testing';
import { EventEmitter, NO_ERRORS_SCHEMA } from '@angular/core';
import { EPerson } from '../../core/eperson/models/eperson.model';
import { GLOBAL_CONFIG } from '../../../config';
import { FormBuilderService } from '../../shared/form/builder/form-builder.service';
import { NotificationsService } from '../../shared/notifications/notifications.service';
import { EPersonDataService } from '../../core/eperson/eperson-data.service';
import { cloneDeep } from 'lodash';
import { createSuccessfulRemoteDataObject$ } from '../../shared/testing/utils';
describe('ProfilePageMetadataFormComponent', () => {
let component: ProfilePageMetadataFormComponent;
let fixture: ComponentFixture<ProfilePageMetadataFormComponent>;
const config = {
languages: [{
code: 'en',
label: 'English',
active: true,
}, {
code: 'de',
label: 'Deutsch',
active: true,
}]
} as any;
const user = Object.assign(new EPerson(), {
email: 'example@gmail.com',
metadata: {
'eperson.firstname': [
{
value: 'John',
language: null
}
],
'eperson.lastname': [
{
value: 'Doe',
language: null
}
],
'eperson.language': [
{
value: 'de',
language: null
}
]
}
});
const epersonService = jasmine.createSpyObj('epersonService', {
update: createSuccessfulRemoteDataObject$(user)
});
const notificationsService = jasmine.createSpyObj('notificationsService', {
success: {},
error: {},
warning: {}
});
const translate = {
instant: () => 'translated',
onLangChange: new EventEmitter()
};
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ProfilePageMetadataFormComponent, VarDirective],
imports: [TranslateModule.forRoot(), RouterTestingModule.withRoutes([])],
providers: [
{ provide: GLOBAL_CONFIG, useValue: config },
{ provide: EPersonDataService, useValue: epersonService },
{ provide: TranslateService, useValue: translate },
{ provide: NotificationsService, useValue: notificationsService },
FormBuilderService
],
schemas: [NO_ERRORS_SCHEMA]
}).compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(ProfilePageMetadataFormComponent);
component = fixture.componentInstance;
component.user = user;
fixture.detectChanges();
});
it('should automatically fill in the user\'s email in the correct field', () => {
expect(component.formGroup.get('email').value).toEqual(user.email);
});
it('should automatically fill the present metadata values and leave missing ones empty', () => {
expect(component.formGroup.get('firstname').value).toEqual('John');
expect(component.formGroup.get('lastname').value).toEqual('Doe');
expect(component.formGroup.get('phone').value).toBeUndefined();
expect(component.formGroup.get('language').value).toEqual('de');
});
describe('updateProfile', () => {
describe('when no values changed', () => {
let result;
beforeEach(() => {
result = component.updateProfile();
});
it('should return false', () => {
expect(result).toEqual(false);
});
it('should not call epersonService.update', () => {
expect(epersonService.update).not.toHaveBeenCalled();
});
});
describe('when a form value changed', () => {
let result;
let newUser;
beforeEach(() => {
newUser = cloneDeep(user);
newUser.metadata['eperson.firstname'][0].value = 'Johnny';
setModelValue('firstname', 'Johnny');
result = component.updateProfile();
});
it('should return true', () => {
expect(result).toEqual(true);
});
it('should call epersonService.update', () => {
expect(epersonService.update).toHaveBeenCalledWith(newUser);
});
});
});
function setModelValue(id: string, value: string) {
component.formModel.filter((model) => model.id === id).forEach((model) => (model as any).value = value);
}
});