mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-14 13:33:03 +00:00
65 lines
2.5 KiB
TypeScript
65 lines
2.5 KiB
TypeScript
import { TranslateLoader, TranslateModule } from '@ngx-translate/core';
|
|
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|
import { Item } from '../../../../core/shared/item.model';
|
|
import { PaginatedList } from '../../../../core/data/paginated-list';
|
|
import { MockTranslateLoader } from '../../../../shared/mocks/mock-translate-loader';
|
|
import { Observable } from 'rxjs';
|
|
import { PageInfo } from '../../../../core/shared/page-info.model';
|
|
import { RemoteData } from '../../../../core/data/remote-data';
|
|
import { ItemPageFieldComponent } from './item-page-field.component';
|
|
import { MetadataValuesComponent } from '../../../field-components/metadata-values/metadata-values.component';
|
|
import { of as observableOf } from 'rxjs';
|
|
import { MetadataMap, MetadataValue } from '../../../../core/shared/metadata.models';
|
|
import { createSuccessfulRemoteDataObject$ } from '../../../../shared/testing/utils';
|
|
|
|
let comp: ItemPageFieldComponent;
|
|
let fixture: ComponentFixture<ItemPageFieldComponent>;
|
|
|
|
const mockValue = 'test value';
|
|
const mockField = 'dc.test';
|
|
const mockLabel = 'test label';
|
|
const mockFields = [mockField];
|
|
|
|
describe('ItemPageFieldComponent', () => {
|
|
beforeEach(async(() => {
|
|
TestBed.configureTestingModule({
|
|
imports: [TranslateModule.forRoot({
|
|
loader: {
|
|
provide: TranslateLoader,
|
|
useClass: MockTranslateLoader
|
|
}
|
|
})],
|
|
declarations: [ItemPageFieldComponent, MetadataValuesComponent],
|
|
schemas: [NO_ERRORS_SCHEMA]
|
|
}).overrideComponent(ItemPageFieldComponent, {
|
|
set: {changeDetection: ChangeDetectionStrategy.Default}
|
|
}).compileComponents();
|
|
}));
|
|
|
|
beforeEach(async(() => {
|
|
fixture = TestBed.createComponent(ItemPageFieldComponent);
|
|
comp = fixture.componentInstance;
|
|
comp.item = mockItemWithMetadataFieldAndValue(mockField, mockValue);
|
|
comp.fields = mockFields;
|
|
comp.label = mockLabel;
|
|
fixture.detectChanges();
|
|
}));
|
|
|
|
it('should display display the correct metadata value', () => {
|
|
expect(fixture.nativeElement.innerHTML).toContain(mockValue);
|
|
});
|
|
});
|
|
|
|
export function mockItemWithMetadataFieldAndValue(field: string, value: string): Item {
|
|
const item = Object.assign(new Item(), {
|
|
bitstreams: createSuccessfulRemoteDataObject$(new PaginatedList(new PageInfo(), [])),
|
|
metadata: new MetadataMap()
|
|
});
|
|
item.metadata[field] = [{
|
|
language: 'en_US',
|
|
value: value
|
|
}] as MetadataValue[];
|
|
return item;
|
|
}
|