salix/modules/travel/front/thermograph/create/index.spec.js

69 lines
2.9 KiB
JavaScript
Raw Normal View History

2020-01-17 07:43:10 +00:00
import './index';
describe('Ticket', () => {
2020-01-22 08:04:26 +00:00
describe('Component vnTravelThermographCreate', () => {
2020-01-17 07:43:10 +00:00
let controller;
let $scope;
let $httpBackend;
let $httpParamSerializer;
2020-01-22 08:04:26 +00:00
const travelId = 3;
const dmsTypeId = 5;
2020-01-17 07:43:10 +00:00
2020-01-22 08:04:26 +00:00
beforeEach(ngModule('travel'));
2020-01-17 07:43:10 +00:00
beforeEach(angular.mock.inject(($componentController, $rootScope, _$httpBackend_, _$httpParamSerializer_) => {
$scope = $rootScope.$new();
$httpBackend = _$httpBackend_;
$httpParamSerializer = _$httpParamSerializer_;
2020-01-22 08:04:26 +00:00
controller = $componentController('vnTravelThermographCreate', {$scope});
controller._travel = {
id: travelId
2020-01-17 07:43:10 +00:00
};
}));
2020-01-22 08:04:26 +00:00
describe('travel() setter', () => {
it('should set the travel data and then call setDefaultParams() and getAllowedContentTypes()', () => {
2020-01-17 07:43:10 +00:00
spyOn(controller, 'setDefaultParams');
spyOn(controller, 'getAllowedContentTypes');
2020-01-22 08:04:26 +00:00
controller.travel = {
id: travelId
2020-01-17 07:43:10 +00:00
};
2020-01-22 08:04:26 +00:00
expect(controller.travel).toBeDefined();
2020-01-17 07:43:10 +00:00
expect(controller.setDefaultParams).toHaveBeenCalledWith();
expect(controller.getAllowedContentTypes).toHaveBeenCalledWith();
});
});
describe('setDefaultParams()', () => {
it('should perform a GET query and define the dms property on controller', () => {
const params = {filter: {
2020-01-22 08:04:26 +00:00
where: {code: 'miscellaneous'}
2020-01-17 07:43:10 +00:00
}};
let serializedParams = $httpParamSerializer(params);
2020-01-22 08:04:26 +00:00
$httpBackend.when('GET', `DmsTypes/findOne?${serializedParams}`).respond({id: dmsTypeId, code: 'miscellaneous'});
2020-01-17 07:43:10 +00:00
$httpBackend.expect('GET', `DmsTypes/findOne?${serializedParams}`);
controller.setDefaultParams();
$httpBackend.flush();
expect(controller.dms).toBeDefined();
2020-01-22 08:04:26 +00:00
expect(controller.dms.reference).toEqual(travelId);
expect(controller.dms.dmsTypeId).toEqual(dmsTypeId);
2020-01-17 07:43:10 +00:00
});
});
describe('getAllowedContentTypes()', () => {
it('should make an HTTP GET request to get the allowed content types', () => {
2020-01-22 08:04:26 +00:00
const expectedResponse = ['application/pdf', 'image/png', 'image/jpg'];
$httpBackend.when('GET', `TravelThermographs/allowedContentTypes`).respond(expectedResponse);
$httpBackend.expect('GET', `TravelThermographs/allowedContentTypes`);
2020-01-17 07:43:10 +00:00
controller.getAllowedContentTypes();
$httpBackend.flush();
expect(controller.allowedContentTypes).toBeDefined();
2020-01-22 08:04:26 +00:00
expect(controller.allowedContentTypes).toEqual('application/pdf, image/png, image/jpg');
2020-01-17 07:43:10 +00:00
});
});
});
});