mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-09 11:03:05 +00:00
92900: Update docs & specs for AuthRequestService
This commit is contained in:
@@ -7,17 +7,24 @@ import { TestScheduler } from 'rxjs/testing';
|
||||
import { createSuccessfulRemoteDataObject } from '../../shared/remote-data.utils';
|
||||
import { ShortLivedToken } from './models/short-lived-token.model';
|
||||
import { RemoteData } from '../data/remote-data';
|
||||
import { HttpOptions } from '../dspace-rest/dspace-rest.service';
|
||||
import objectContaining = jasmine.objectContaining;
|
||||
import { AuthStatus } from './models/auth-status.model';
|
||||
import { RestRequestMethod } from '../data/rest-request-method';
|
||||
|
||||
describe(`AuthRequestService`, () => {
|
||||
let halService: HALEndpointService;
|
||||
let endpointURL: string;
|
||||
let requestID: string;
|
||||
let shortLivedToken: ShortLivedToken;
|
||||
let shortLivedTokenRD: RemoteData<ShortLivedToken>;
|
||||
let requestService: RequestService;
|
||||
let rdbService: RemoteDataBuildService;
|
||||
let service: AuthRequestService;
|
||||
let service;
|
||||
let testScheduler;
|
||||
|
||||
const status = new AuthStatus();
|
||||
|
||||
class TestAuthRequestService extends AuthRequestService {
|
||||
constructor(
|
||||
hes: HALEndpointService,
|
||||
@@ -34,6 +41,7 @@ describe(`AuthRequestService`, () => {
|
||||
|
||||
const init = (cold: typeof TestScheduler.prototype.createColdObservable) => {
|
||||
endpointURL = 'https://rest.api/auth';
|
||||
requestID = 'requestID';
|
||||
shortLivedToken = Object.assign(new ShortLivedToken(), {
|
||||
value: 'some-token'
|
||||
});
|
||||
@@ -43,13 +51,16 @@ describe(`AuthRequestService`, () => {
|
||||
'getEndpoint': cold('a', { a: endpointURL })
|
||||
});
|
||||
requestService = jasmine.createSpyObj('requestService', {
|
||||
'send': null
|
||||
'generateRequestId': requestID,
|
||||
'send': null,
|
||||
});
|
||||
rdbService = jasmine.createSpyObj('rdbService', {
|
||||
'buildFromRequestUUID': cold('a', { a: shortLivedTokenRD })
|
||||
});
|
||||
|
||||
service = new TestAuthRequestService(halService, requestService, rdbService);
|
||||
|
||||
spyOn(service as any, 'fetchRequest').and.returnValue(cold('a', { a: createSuccessfulRemoteDataObject(status) }));
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
@@ -58,6 +69,94 @@ describe(`AuthRequestService`, () => {
|
||||
});
|
||||
});
|
||||
|
||||
describe('REST request methods', () => {
|
||||
let options: HttpOptions;
|
||||
|
||||
beforeEach(() => {
|
||||
options = Object.create({});
|
||||
});
|
||||
|
||||
describe('GET', () => {
|
||||
it('should send a GET request to the right endpoint and return the auth status', () => {
|
||||
testScheduler.run(({ cold, expectObservable, flush }) => {
|
||||
init(cold);
|
||||
|
||||
expectObservable(service.getRequest('method', options)).toBe('a', {
|
||||
a: objectContaining({ payload: status }),
|
||||
});
|
||||
flush();
|
||||
|
||||
expect(requestService.send).toHaveBeenCalledWith(objectContaining({
|
||||
uuid: requestID,
|
||||
href: endpointURL + '/method',
|
||||
method: RestRequestMethod.GET,
|
||||
body: undefined,
|
||||
options,
|
||||
}));
|
||||
expect((service as any).fetchRequest).toHaveBeenCalledWith(requestID);
|
||||
});
|
||||
});
|
||||
|
||||
it('should send the request even if caller doesn\'t subscribe to the response', () => {
|
||||
testScheduler.run(({ cold, flush }) => {
|
||||
init(cold);
|
||||
|
||||
service.getRequest('method', options);
|
||||
flush();
|
||||
|
||||
expect(requestService.send).toHaveBeenCalledWith(objectContaining({
|
||||
uuid: requestID,
|
||||
href: endpointURL + '/method',
|
||||
method: RestRequestMethod.GET,
|
||||
body: undefined,
|
||||
options,
|
||||
}));
|
||||
expect((service as any).fetchRequest).toHaveBeenCalledWith(requestID);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('POST', () => {
|
||||
it('should send a POST request to the right endpoint and return the auth status', () => {
|
||||
testScheduler.run(({ cold, expectObservable, flush }) => {
|
||||
init(cold);
|
||||
|
||||
expectObservable(service.postToEndpoint('method', { content: 'something' }, options)).toBe('a', {
|
||||
a: objectContaining({ payload: status }),
|
||||
});
|
||||
flush();
|
||||
|
||||
expect(requestService.send).toHaveBeenCalledWith(objectContaining({
|
||||
uuid: requestID,
|
||||
href: endpointURL + '/method',
|
||||
method: RestRequestMethod.POST,
|
||||
body: { content: 'something' },
|
||||
options,
|
||||
}));
|
||||
expect((service as any).fetchRequest).toHaveBeenCalledWith(requestID);
|
||||
});
|
||||
});
|
||||
|
||||
it('should send the request even if caller doesn\'t subscribe to the response', () => {
|
||||
testScheduler.run(({ cold, flush }) => {
|
||||
init(cold);
|
||||
|
||||
service.postToEndpoint('method', { content: 'something' }, options);
|
||||
flush();
|
||||
|
||||
expect(requestService.send).toHaveBeenCalledWith(objectContaining({
|
||||
uuid: requestID,
|
||||
href: endpointURL + '/method',
|
||||
method: RestRequestMethod.POST,
|
||||
body: { content: 'something' },
|
||||
options,
|
||||
}));
|
||||
expect((service as any).fetchRequest).toHaveBeenCalledWith(requestID);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe(`getShortlivedToken`, () => {
|
||||
it(`should call createShortLivedTokenRequest with the url for the endpoint`, () => {
|
||||
testScheduler.run(({ cold, expectObservable, flush }) => {
|
||||
|
@@ -26,6 +26,11 @@ export abstract class AuthRequestService {
|
||||
) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Fetch the response to a request from the cache, once it's completed.
|
||||
* @param requestId the UUID of the request for which to retrieve the response
|
||||
* @protected
|
||||
*/
|
||||
protected fetchRequest(requestId: string): Observable<RemoteData<AuthStatus>> {
|
||||
return this.rdbService.buildFromRequestUUID<AuthStatus>(requestId).pipe(
|
||||
getFirstCompletedRemoteData(),
|
||||
@@ -36,6 +41,12 @@ export abstract class AuthRequestService {
|
||||
return isNotEmpty(method) ? `${endpoint}/${method}` : `${endpoint}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* Send a POST request to an authentication endpoint
|
||||
* @param method the method to send to (e.g. 'status')
|
||||
* @param body the data to send (optional)
|
||||
* @param options the HTTP options for the request
|
||||
*/
|
||||
public postToEndpoint(method: string, body?: any, options?: HttpOptions): Observable<RemoteData<AuthStatus>> {
|
||||
const requestId = this.requestService.generateRequestId();
|
||||
|
||||
@@ -52,6 +63,11 @@ export abstract class AuthRequestService {
|
||||
return this.fetchRequest(requestId);
|
||||
}
|
||||
|
||||
/**
|
||||
* Send a GET request to an authentication endpoint
|
||||
* @param method the method to send to (e.g. 'status')
|
||||
* @param options the HTTP options for the request
|
||||
*/
|
||||
public getRequest(method: string, options?: HttpOptions): Observable<RemoteData<AuthStatus>> {
|
||||
const requestId = this.requestService.generateRequestId();
|
||||
|
||||
|
Reference in New Issue
Block a user