mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
123 lines
3.6 KiB
TypeScript
123 lines
3.6 KiB
TypeScript
import {
|
|
DebugElement,
|
|
NO_ERRORS_SCHEMA,
|
|
} from '@angular/core';
|
|
import {
|
|
ComponentFixture,
|
|
TestBed,
|
|
} from '@angular/core/testing';
|
|
import { By } from '@angular/platform-browser';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
import { of as observableOf } from 'rxjs';
|
|
|
|
import { APP_CONFIG } from '../../../../config/app-config.interface';
|
|
import { environment } from '../../../../environments/environment';
|
|
import { ObjectUpdatesService } from '../../../core/data/object-updates/object-updates.service';
|
|
import { Item } from '../../../core/shared/item.model';
|
|
import { getMockThemeService } from '../../../shared/mocks/theme-service.mock';
|
|
import { ListableObjectComponentLoaderComponent } from '../../../shared/object-collection/shared/listable-object/listable-object-component-loader.component';
|
|
import { ThemeService } from '../../../shared/theme-support/theme.service';
|
|
import { VarDirective } from '../../../shared/utils/var.directive';
|
|
import { VirtualMetadataComponent } from './virtual-metadata.component';
|
|
|
|
describe('VirtualMetadataComponent', () => {
|
|
|
|
let comp: VirtualMetadataComponent;
|
|
let fixture: ComponentFixture<VirtualMetadataComponent>;
|
|
let de: DebugElement;
|
|
|
|
let objectUpdatesService;
|
|
|
|
const url = 'http://test-url.com/test-url';
|
|
|
|
let item;
|
|
let relatedItem;
|
|
let relationshipId;
|
|
|
|
beforeEach(() => {
|
|
|
|
relationshipId = 'relationship id';
|
|
|
|
item = Object.assign(new Item(), {
|
|
uuid: 'publication',
|
|
metadata: [],
|
|
});
|
|
|
|
relatedItem = Object.assign(new Item(), {
|
|
uuid: 'relatedItem',
|
|
metadata: [],
|
|
});
|
|
|
|
objectUpdatesService = jasmine.createSpyObj('objectUpdatesService', {
|
|
isSelectedVirtualMetadata: observableOf(false),
|
|
setSelectedVirtualMetadata: null,
|
|
});
|
|
|
|
TestBed.configureTestingModule({
|
|
imports: [TranslateModule.forRoot(), VirtualMetadataComponent, VarDirective],
|
|
providers: [
|
|
{ provide: ObjectUpdatesService, useValue: objectUpdatesService },
|
|
{ provide: APP_CONFIG, useValue: environment },
|
|
{ provide: ThemeService, useValue: getMockThemeService() },
|
|
], schemas: [
|
|
NO_ERRORS_SCHEMA,
|
|
],
|
|
})
|
|
.overrideComponent(VirtualMetadataComponent, {
|
|
remove: {
|
|
imports: [ListableObjectComponentLoaderComponent],
|
|
},
|
|
})
|
|
.compileComponents();
|
|
|
|
fixture = TestBed.createComponent(VirtualMetadataComponent);
|
|
comp = fixture.componentInstance;
|
|
de = fixture.debugElement;
|
|
|
|
comp.url = url;
|
|
comp.leftItem = item;
|
|
comp.rightItem = relatedItem;
|
|
comp.ngOnChanges();
|
|
comp.relationshipId = relationshipId;
|
|
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
describe('when clicking the save button', () => {
|
|
it('should emit a save event', () => {
|
|
|
|
spyOn(comp.save, 'emit');
|
|
fixture.debugElement
|
|
.query(By.css('button.save'))
|
|
.triggerEventHandler('click', null);
|
|
expect(comp.save.emit).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe('when clicking the close button', () => {
|
|
it('should emit a close event', () => {
|
|
|
|
spyOn(comp.close, 'emit');
|
|
fixture.debugElement
|
|
.query(By.css('button.close'))
|
|
.triggerEventHandler('click', null);
|
|
expect(comp.close.emit).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe('when selecting an item', () => {
|
|
it('should call the updates service setSelectedVirtualMetadata method', () => {
|
|
|
|
fixture.debugElement
|
|
.query(By.css('div.item'))
|
|
.triggerEventHandler('click', null);
|
|
expect(objectUpdatesService.setSelectedVirtualMetadata).toHaveBeenCalledWith(
|
|
url,
|
|
relationshipId,
|
|
item.uuid,
|
|
true,
|
|
);
|
|
});
|
|
});
|
|
});
|