mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-09 19:13:08 +00:00

Conflicts: resources/i18n/en.json src/app/+item-page/edit-item-page/edit-item-page.component.ts src/app/+item-page/edit-item-page/edit-item-page.module.ts src/app/+item-page/edit-item-page/edit-item-page.routing.module.ts src/app/+item-page/edit-item-page/item-status/item-status.component.html src/app/+item-page/edit-item-page/item-status/item-status.component.spec.ts src/app/+item-page/edit-item-page/item-status/item-status.component.ts src/app/+item-page/item-page-routing.module.ts src/app/core/data/item-data.service.spec.ts src/app/core/data/item-data.service.ts src/app/core/shared/operators.spec.ts src/app/core/shared/operators.ts
106 lines
3.9 KiB
TypeScript
106 lines
3.9 KiB
TypeScript
import {async, ComponentFixture, TestBed} from '@angular/core/testing';
|
|
import {Item} from '../../../core/shared/item.model';
|
|
import {RouterStub} from '../../../shared/testing/router-stub';
|
|
import {of as observableOf} from 'rxjs';
|
|
import {RemoteData} from '../../../core/data/remote-data';
|
|
import {NotificationsServiceStub} from '../../../shared/testing/notifications-service-stub';
|
|
import {CommonModule} from '@angular/common';
|
|
import {FormsModule} from '@angular/forms';
|
|
import {RouterTestingModule} from '@angular/router/testing';
|
|
import {TranslateModule} from '@ngx-translate/core';
|
|
import {NgbModule} from '@ng-bootstrap/ng-bootstrap';
|
|
import {ActivatedRoute, Router} from '@angular/router';
|
|
import {ItemDataService} from '../../../core/data/item-data.service';
|
|
import {NotificationsService} from '../../../shared/notifications/notifications.service';
|
|
import {CUSTOM_ELEMENTS_SCHEMA} from '@angular/core';
|
|
import {By} from '@angular/platform-browser';
|
|
import {ItemPublicComponent} from './item-public.component';
|
|
import { RestResponse } from '../../../core/cache/response.models';
|
|
|
|
let comp: ItemPublicComponent;
|
|
let fixture: ComponentFixture<ItemPublicComponent>;
|
|
|
|
let mockItem;
|
|
let itemPageUrl;
|
|
let routerStub;
|
|
let mockItemDataService: ItemDataService;
|
|
let routeStub;
|
|
let notificationsServiceStub;
|
|
let successfulRestResponse;
|
|
let failRestResponse;
|
|
|
|
describe('ItemPublicComponent', () => {
|
|
beforeEach(async(() => {
|
|
|
|
mockItem = Object.assign(new Item(), {
|
|
id: 'fake-id',
|
|
handle: 'fake/handle',
|
|
lastModified: '2018',
|
|
isWithdrawn: true
|
|
});
|
|
|
|
itemPageUrl = `fake-url/${mockItem.id}`;
|
|
routerStub = Object.assign(new RouterStub(), {
|
|
url: `${itemPageUrl}/edit`
|
|
});
|
|
|
|
mockItemDataService = jasmine.createSpyObj('mockItemDataService',{
|
|
setDiscoverable: observableOf(new RestResponse(true, '200'))
|
|
});
|
|
|
|
routeStub = {
|
|
data: observableOf({
|
|
item: new RemoteData(false, false, true, null, {
|
|
id: 'fake-id'
|
|
})
|
|
})
|
|
};
|
|
|
|
notificationsServiceStub = new NotificationsServiceStub();
|
|
|
|
TestBed.configureTestingModule({
|
|
imports: [CommonModule, FormsModule, RouterTestingModule.withRoutes([]), TranslateModule.forRoot(), NgbModule.forRoot()],
|
|
declarations: [ItemPublicComponent],
|
|
providers: [
|
|
{provide: ActivatedRoute, useValue: routeStub},
|
|
{provide: Router, useValue: routerStub},
|
|
{provide: ItemDataService, useValue: mockItemDataService},
|
|
{provide: NotificationsService, useValue: notificationsServiceStub},
|
|
], schemas: [
|
|
CUSTOM_ELEMENTS_SCHEMA
|
|
]
|
|
}).compileComponents();
|
|
}));
|
|
|
|
beforeEach(() => {
|
|
successfulRestResponse = new RestResponse(true, '200');
|
|
failRestResponse = new RestResponse(false, '500');
|
|
|
|
fixture = TestBed.createComponent(ItemPublicComponent);
|
|
comp = fixture.componentInstance;
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
it('should render a page with messages based on the \'public\' messageKey', () => {
|
|
const header = fixture.debugElement.query(By.css('h2')).nativeElement;
|
|
expect(header.innerHTML).toContain('item.edit.public.header');
|
|
const description = fixture.debugElement.query(By.css('p')).nativeElement;
|
|
expect(description.innerHTML).toContain('item.edit.public.description');
|
|
const confirmButton = fixture.debugElement.query(By.css('button.perform-action')).nativeElement;
|
|
expect(confirmButton.innerHTML).toContain('item.edit.public.confirm');
|
|
const cancelButton = fixture.debugElement.query(By.css('button.cancel')).nativeElement;
|
|
expect(cancelButton.innerHTML).toContain('item.edit.public.cancel');
|
|
});
|
|
|
|
describe('performAction', () => {
|
|
it('should call setDiscoverable function from the ItemDataService', () => {
|
|
spyOn(comp, 'processRestResponse');
|
|
comp.performAction();
|
|
|
|
expect(mockItemDataService.setDiscoverable).toHaveBeenCalledWith(mockItem.id, true);
|
|
expect(comp.processRestResponse).toHaveBeenCalled();
|
|
});
|
|
});
|
|
})
|
|
;
|