kanbanworkflowstimelinescrumrubyroadmapproject-planningproject-managementopenprojectangularissue-trackerifcgantt-chartganttbug-trackerboardsbcf
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
241 lines
7.2 KiB
241 lines
7.2 KiB
//-- copyright
|
|
// OpenProject is a project management system.
|
|
// Copyright (C) 2012-2015 the OpenProject Foundation (OPF)
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License version 3.
|
|
//
|
|
// OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
|
|
// Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
// Copyright (C) 2010-2013 the ChiliProject Team
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License
|
|
// as published by the Free Software Foundation; either version 2
|
|
// of the License, or (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program; if not, write to the Free Software
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
//
|
|
// See doc/COPYRIGHT.rdoc for more details.
|
|
//++
|
|
|
|
import {opApiModule} from '../../../../angular-modules';
|
|
import {HalRequestService} from './hal-request.service';
|
|
import {HalResource} from '../hal-resources/hal-resource.service';
|
|
import IPromise = angular.IPromise;
|
|
import IRootScopeService = angular.IRootScopeService;
|
|
import IHttpBackendService = angular.IHttpBackendService;
|
|
|
|
describe('halRequest service', () => {
|
|
var $httpBackend:IHttpBackendService;
|
|
var $rootScope:IRootScopeService;
|
|
var halRequest:HalRequestService;
|
|
|
|
beforeEach(angular.mock.module(opApiModule.name));
|
|
beforeEach(angular.mock.inject(function (_$httpBackend_:any, _$rootScope_:any, _halRequest_:any) {
|
|
[$httpBackend, $rootScope, halRequest] = _.toArray(arguments);
|
|
}));
|
|
|
|
it('should exist', () => {
|
|
expect(halRequest).to.exist;
|
|
});
|
|
|
|
afterEach(() => {
|
|
$rootScope.$apply();
|
|
});
|
|
|
|
describe('when requesting a null href', () => {
|
|
var promise:any;
|
|
|
|
beforeEach(() => {
|
|
promise = halRequest.request('get', '');
|
|
});
|
|
|
|
it('should return a rejected promise', () => {
|
|
expect(promise).to.eventually.be.rejected;
|
|
});
|
|
});
|
|
|
|
describe('when requesting the same GET resource multiple times', () => {
|
|
var headers:any;
|
|
|
|
const testRequest = (prepare:any) => {
|
|
beforeEach(prepare);
|
|
|
|
it('should perform requests according to the cache options', () => {
|
|
$httpBackend.expectGET('something').respond(200, '', (headers:any) => {
|
|
return headers.caching.enabled === true;
|
|
});
|
|
|
|
if (headers.caching && headers.caching.enabled === false) {
|
|
$httpBackend.expectGET('something').respond(200, '');
|
|
}
|
|
});
|
|
};
|
|
const testMethods = () => {
|
|
describe('when using request()', () => {
|
|
testRequest(() => {
|
|
halRequest.request('get', 'something', {}, headers);
|
|
halRequest.request('get', 'something', {}, headers);
|
|
});
|
|
});
|
|
|
|
describe('when using get()', () => {
|
|
testRequest(() => {
|
|
halRequest.get('something', {}, headers);
|
|
halRequest.get('something', {}, headers);
|
|
});
|
|
});
|
|
};
|
|
|
|
beforeEach(() => {
|
|
halRequest.defaultHeaders.caching = {enabled: true};
|
|
headers = {};
|
|
});
|
|
|
|
testMethods();
|
|
|
|
describe('when sending a no cache header', () => {
|
|
beforeEach(() => {
|
|
headers = {caching: {enabled: false}};
|
|
});
|
|
|
|
testMethods();
|
|
});
|
|
});
|
|
|
|
describe('when requesting data', () => {
|
|
var promise:IPromise<HalResource>;
|
|
var method:string;
|
|
var data:any;
|
|
var expectedData:any;
|
|
var headers = {Accept: 'foo', caching: {enabled: false}};
|
|
|
|
const methods = ['get', 'put', 'post', 'patch', 'delete'];
|
|
const respond = (status:any, response:any) => {
|
|
$httpBackend
|
|
.expect(method.toUpperCase(), 'href', expectedData, (headers:any) => {
|
|
return headers.Accept === 'foo';
|
|
})
|
|
.respond(status, response);
|
|
|
|
$httpBackend.flush();
|
|
};
|
|
const runTests = () => {
|
|
describe('when no error occurs', () => {
|
|
beforeEach(() => respond(200, {}));
|
|
it('should return a HalResource', () => {
|
|
expect(promise).to.eventually.be.an.instanceOf(HalResource);
|
|
});
|
|
});
|
|
|
|
describe('when an error occurs', () => {
|
|
beforeEach(() => respond(400, {}));
|
|
|
|
it('should be rejected with an instance of HalResource', () => {
|
|
expect(promise).to.eventually.be.rejectedWith(HalResource);
|
|
});
|
|
});
|
|
|
|
describe('when the server does not respond with a result', () => {
|
|
beforeEach(() => respond(200, null));
|
|
|
|
it('should return nothing as well', () => {
|
|
expect(promise).to.eventually.be.null;
|
|
});
|
|
});
|
|
};
|
|
const runRequests = (cb:any) => {
|
|
const callback = () => {
|
|
if (method === 'get') {
|
|
data = null;
|
|
expectedData = null;
|
|
}
|
|
cb();
|
|
};
|
|
methods.forEach(requestMethod => {
|
|
describe(`when performing a ${requestMethod} request`, () => {
|
|
beforeEach(() => {
|
|
method = requestMethod;
|
|
});
|
|
|
|
describe('when sending no data with the request', () => {
|
|
beforeEach(() => {
|
|
data = void 0;
|
|
expectedData = void 0;
|
|
|
|
if (method === 'post') {
|
|
expectedData = {};
|
|
}
|
|
|
|
callback();
|
|
});
|
|
|
|
runTests();
|
|
});
|
|
|
|
describe('when sending data with the request', () => {
|
|
beforeEach(() => {
|
|
data = {foo: 'bar'};
|
|
expectedData = data;
|
|
callback();
|
|
});
|
|
|
|
runTests();
|
|
});
|
|
});
|
|
});
|
|
};
|
|
|
|
describe('when calling the http methods of the service', () => {
|
|
runRequests(() => {
|
|
promise = (halRequest as any)[method]('href', data, headers);
|
|
});
|
|
});
|
|
|
|
describe('when calling request()', () => {
|
|
runRequests(() => {
|
|
promise = halRequest.request(method, 'href', data, headers);
|
|
});
|
|
});
|
|
|
|
describe('when requesting a GET resource with parameters', () => {
|
|
const params = {foo: 'bar'};
|
|
|
|
beforeEach(() => {
|
|
promise = halRequest.get('href', params);
|
|
});
|
|
|
|
it('should append the parameters at the end of the requested url', () => {
|
|
$httpBackend.expectGET('href?foo=bar').respond(200, {});
|
|
$httpBackend.flush();
|
|
});
|
|
});
|
|
|
|
describe('#getAllPaginated', () => {
|
|
const params = {};
|
|
let promise:any;
|
|
|
|
beforeEach(() => {
|
|
promise = halRequest.getAllPaginated('href', 25, params);
|
|
|
|
$httpBackend.expectGET('href?offset=1').respond(200, { count: 12, total: 25 });
|
|
$httpBackend.expectGET('href?offset=2').respond(200, { count: 12, total: 25 });
|
|
$httpBackend.expectGET('href?offset=3').respond(200, { count: 1, total: 25 });
|
|
});
|
|
|
|
it('should resolve with three results', () => {
|
|
expect(promise).to.eventually.be.fulfilled.then(allResults => {
|
|
expect(allResults.length).to.eq(3);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|