mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
99 lines
3.5 KiB
TypeScript
99 lines
3.5 KiB
TypeScript
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
|
|
|
|
import { of as observableOf } from 'rxjs';
|
|
|
|
import { Item } from '../../../../core/shared/item.model';
|
|
import { PoolTask } from '../../../../core/tasks/models/pool-task-object.model';
|
|
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
|
|
import { WorkflowItem } from '../../../../core/submission/models/workflowitem.model';
|
|
import { createSuccessfulRemoteDataObject } from '../../../testing/utils';
|
|
import { PoolSearchResultDetailElementComponent } from './pool-search-result-detail-element.component';
|
|
import { PoolTaskSearchResult } from '../../../object-collection/shared/pool-task-search-result.model';
|
|
import { VarDirective } from '../../../utils/var.directive';
|
|
import { LinkService } from '../../../../core/cache/builders/link.service';
|
|
import { getMockLinkService } from '../../../mocks/mock-link-service';
|
|
|
|
let component: PoolSearchResultDetailElementComponent;
|
|
let fixture: ComponentFixture<PoolSearchResultDetailElementComponent>;
|
|
|
|
const compIndex = 1;
|
|
|
|
const mockResultObject: PoolTaskSearchResult = new PoolTaskSearchResult();
|
|
mockResultObject.hitHighlights = {};
|
|
|
|
const item = Object.assign(new Item(), {
|
|
bundles: observableOf({}),
|
|
metadata: {
|
|
'dc.title': [
|
|
{
|
|
language: 'en_US',
|
|
value: 'This is just another title'
|
|
}
|
|
],
|
|
'dc.type': [
|
|
{
|
|
language: null,
|
|
value: 'Article'
|
|
}
|
|
],
|
|
'dc.contributor.author': [
|
|
{
|
|
language: 'en_US',
|
|
value: 'Smith, Donald'
|
|
}
|
|
],
|
|
'dc.date.issued': [
|
|
{
|
|
language: null,
|
|
value: '2015-06-26'
|
|
}
|
|
]
|
|
}
|
|
});
|
|
const rdItem = createSuccessfulRemoteDataObject(item);
|
|
const workflowitem = Object.assign(new WorkflowItem(), { item: observableOf(rdItem) });
|
|
const rdWorkflowitem = createSuccessfulRemoteDataObject(workflowitem);
|
|
mockResultObject.indexableObject = Object.assign(new PoolTask(), { workflowitem: observableOf(rdWorkflowitem) });
|
|
const linkService = getMockLinkService();
|
|
|
|
describe('PoolSearchResultDetailElementComponent', () => {
|
|
beforeEach(async(() => {
|
|
TestBed.configureTestingModule({
|
|
imports: [NoopAnimationsModule],
|
|
declarations: [PoolSearchResultDetailElementComponent, VarDirective],
|
|
providers: [
|
|
{ provide: 'objectElementProvider', useValue: (mockResultObject) },
|
|
{ provide: 'indexElementProvider', useValue: (compIndex) },
|
|
{ provide: LinkService, useValue: linkService }
|
|
],
|
|
schemas: [NO_ERRORS_SCHEMA]
|
|
}).overrideComponent(PoolSearchResultDetailElementComponent, {
|
|
set: { changeDetection: ChangeDetectionStrategy.Default }
|
|
}).compileComponents();
|
|
}));
|
|
|
|
beforeEach(async(() => {
|
|
fixture = TestBed.createComponent(PoolSearchResultDetailElementComponent);
|
|
component = fixture.componentInstance;
|
|
}));
|
|
|
|
beforeEach(() => {
|
|
component.dso = mockResultObject.indexableObject;
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
it('should init workflowitem properly', (done) => {
|
|
component.workflowitemRD$.subscribe((workflowitemRD) => {
|
|
expect(linkService.resolveLink).toHaveBeenCalled();
|
|
expect(workflowitemRD.payload).toEqual(workflowitem);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should have properly status', () => {
|
|
expect(component.status).toEqual(MyDspaceItemStatusType.WAITING_CONTROLLER);
|
|
});
|
|
});
|