mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 10:04:11 +00:00
150 lines
5.3 KiB
TypeScript
150 lines
5.3 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 { CommonModule } from '@angular/common';
|
|
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 { NotificationsServiceStub } from '../../../shared/testing/notifications-service-stub';
|
|
import { NotificationsService } from '../../../shared/notifications/notifications.service';
|
|
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
import { FormsModule } from '@angular/forms';
|
|
import { ItemDataService } from '../../../core/data/item-data.service';
|
|
import { RemoteData } from '../../../core/data/remote-data';
|
|
import { AbstractSimpleItemActionComponent } from './abstract-simple-item-action.component';
|
|
import { By } from '@angular/platform-browser';
|
|
import { of as observableOf } from 'rxjs';
|
|
import { getItemEditPath } from '../../item-page-routing.module';
|
|
import { RestResponse } from '../../../core/cache/response.models';
|
|
import {
|
|
createSuccessfulRemoteDataObject,
|
|
createSuccessfulRemoteDataObject$
|
|
} from '../../../shared/testing/utils';
|
|
|
|
/**
|
|
* Test component that implements the AbstractSimpleItemActionComponent used to test the
|
|
* AbstractSimpleItemActionComponent component
|
|
*/
|
|
@Component({
|
|
selector: 'ds-simple-action',
|
|
templateUrl: './abstract-simple-item-action.component.html'
|
|
})
|
|
export class MySimpleItemActionComponent extends AbstractSimpleItemActionComponent {
|
|
|
|
protected messageKey = 'myEditAction';
|
|
protected predicate = (rd: RemoteData<Item>) => rd.payload.isWithdrawn;
|
|
|
|
performAction() {
|
|
// do nothing
|
|
}
|
|
|
|
}
|
|
|
|
let comp: MySimpleItemActionComponent;
|
|
let fixture: ComponentFixture<MySimpleItemActionComponent>;
|
|
|
|
let mockItem;
|
|
let itemPageUrl;
|
|
let routerStub;
|
|
let mockItemDataService;
|
|
let routeStub;
|
|
let notificationsServiceStub;
|
|
let successfulRestResponse;
|
|
let failRestResponse;
|
|
|
|
describe('AbstractSimpleItemActionComponent', () => {
|
|
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({
|
|
findById: createSuccessfulRemoteDataObject$(mockItem)
|
|
});
|
|
|
|
routeStub = {
|
|
data: observableOf({
|
|
item: createSuccessfulRemoteDataObject({
|
|
id: 'fake-id'
|
|
})
|
|
})
|
|
};
|
|
|
|
notificationsServiceStub = new NotificationsServiceStub();
|
|
|
|
TestBed.configureTestingModule({
|
|
imports: [CommonModule, FormsModule, RouterTestingModule.withRoutes([]), TranslateModule.forRoot(), NgbModule.forRoot()],
|
|
declarations: [MySimpleItemActionComponent],
|
|
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, 'OK');
|
|
failRestResponse = new RestResponse(false, 500, 'Internal Server Error');
|
|
|
|
fixture = TestBed.createComponent(MySimpleItemActionComponent);
|
|
comp = fixture.componentInstance;
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
afterEach(() => {
|
|
fixture.destroy();
|
|
comp = null;
|
|
});
|
|
|
|
it('should render a page with messages based on the provided messageKey', () => {
|
|
const header = fixture.debugElement.query(By.css('h2')).nativeElement;
|
|
expect(header.innerHTML).toContain('item.edit.myEditAction.header');
|
|
|
|
const description = fixture.debugElement.query(By.css('p')).nativeElement;
|
|
expect(description.innerHTML).toContain('item.edit.myEditAction.description');
|
|
|
|
const confirmButton = fixture.debugElement.query(By.css('button.perform-action')).nativeElement;
|
|
expect(confirmButton.innerHTML).toContain('item.edit.myEditAction.confirm');
|
|
|
|
const cancelButton = fixture.debugElement.query(By.css('button.cancel')).nativeElement;
|
|
expect(cancelButton.innerHTML).toContain('item.edit.myEditAction.cancel');
|
|
});
|
|
|
|
it('should perform action when the button is clicked', () => {
|
|
spyOn(comp, 'performAction');
|
|
const performButton = fixture.debugElement.query(By.css('.perform-action'));
|
|
performButton.triggerEventHandler('click', null);
|
|
|
|
expect(comp.performAction).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should process a RestResponse to navigate and display success notification', () => {
|
|
comp.processRestResponse(successfulRestResponse);
|
|
|
|
expect(notificationsServiceStub.success).toHaveBeenCalled();
|
|
expect(routerStub.navigate).toHaveBeenCalledWith([getItemEditPath(mockItem.id)]);
|
|
});
|
|
|
|
it('should process a RestResponse to navigate and display success notification', () => {
|
|
comp.processRestResponse(failRestResponse);
|
|
|
|
expect(notificationsServiceStub.error).toHaveBeenCalled();
|
|
expect(routerStub.navigate).toHaveBeenCalledWith([getItemEditPath(mockItem.id)]);
|
|
});
|
|
|
|
});
|