mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-13 21:13:07 +00:00
70 lines
2.6 KiB
TypeScript
70 lines
2.6 KiB
TypeScript
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
|
|
|
|
import { of as observableOf } from 'rxjs';
|
|
import { TranslateLoader, TranslateModule } from '@ngx-translate/core';
|
|
import { cold } from 'jasmine-marbles';
|
|
import { ItemSubmitterComponent } from './item-submitter.component';
|
|
import { WorkflowItem } from '../../../../core/submission/models/workflowitem.model';
|
|
import { PoolTask } from '../../../../core/tasks/models/pool-task-object.model';
|
|
import { EPersonMock } from '../../../testing/eperson.mock';
|
|
import { TranslateLoaderMock } from '../../../mocks/translate-loader.mock';
|
|
import { By } from '@angular/platform-browser';
|
|
import { createSuccessfulRemoteDataObject } from '../../../remote-data.utils';
|
|
import { LinkService } from '../../../../core/cache/builders/link.service';
|
|
import { getMockLinkService } from '../../../mocks/link-service.mock';
|
|
|
|
let component: ItemSubmitterComponent;
|
|
let fixture: ComponentFixture<ItemSubmitterComponent>;
|
|
let mockResultObject: PoolTask;
|
|
|
|
const rdSumbitter = createSuccessfulRemoteDataObject(EPersonMock);
|
|
const workflowitem = Object.assign(new WorkflowItem(), { submitter: observableOf(rdSumbitter) });
|
|
const rdWorkflowitem = createSuccessfulRemoteDataObject(workflowitem);
|
|
mockResultObject = Object.assign(new PoolTask(), { workflowitem: observableOf(rdWorkflowitem) });
|
|
|
|
describe('ItemSubmitterComponent', () => {
|
|
beforeEach(waitForAsync(() => {
|
|
TestBed.configureTestingModule({
|
|
imports: [
|
|
TranslateModule.forRoot({
|
|
loader: {
|
|
provide: TranslateLoader,
|
|
useClass: TranslateLoaderMock
|
|
}
|
|
})
|
|
],
|
|
declarations: [ItemSubmitterComponent],
|
|
providers: [
|
|
{ provide: LinkService, useValue: getMockLinkService() },
|
|
],
|
|
schemas: [NO_ERRORS_SCHEMA]
|
|
}).overrideComponent(ItemSubmitterComponent, {
|
|
set: { changeDetection: ChangeDetectionStrategy.Default }
|
|
}).compileComponents();
|
|
}));
|
|
|
|
beforeEach(waitForAsync(() => {
|
|
fixture = TestBed.createComponent(ItemSubmitterComponent);
|
|
component = fixture.componentInstance;
|
|
}));
|
|
|
|
beforeEach(() => {
|
|
component.object = mockResultObject;
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
it('should init submitter properly', () => {
|
|
expect(component.submitter$).toBeObservable(cold('(b|)', {
|
|
b: EPersonMock
|
|
}));
|
|
});
|
|
|
|
it('should show a badge with submitter name', () => {
|
|
const badge = fixture.debugElement.query(By.css('.badge'));
|
|
|
|
expect(badge).toBeDefined();
|
|
expect(badge.nativeElement.innerHTML).toBe(EPersonMock.name);
|
|
});
|
|
});
|