#1852 worker.time-control
This commit is contained in:
parent
eeead2cc86
commit
f998a04808
|
@ -1,6 +1,6 @@
|
|||
import './index.js';
|
||||
|
||||
describe('Worker', () => {
|
||||
|
||||
describe('Component vnWorkerTimeControl', () => {
|
||||
let $httpBackend;
|
||||
let $scope;
|
||||
|
@ -9,22 +9,33 @@ describe('Worker', () => {
|
|||
|
||||
beforeEach(ngModule('worker'));
|
||||
|
||||
beforeEach(angular.mock.inject(($compile, $rootScope, $stateParams, _$httpBackend_) => {
|
||||
beforeEach(angular.mock.inject(($componentController, $compile, $rootScope, $stateParams, _$httpBackend_) => {
|
||||
$stateParams.id = 1;
|
||||
$httpBackend = _$httpBackend_;
|
||||
$scope = $rootScope.$new();
|
||||
$element = $compile('<vn-worker-time-control></vn-worker-time-control>')($scope);
|
||||
controller = $element.controller('vnWorkerTimeControl');
|
||||
$element = angular.element('<vn-worker-time-control></vn-worker-time-control>');
|
||||
controller = $componentController('vnWorkerTimeControl', {$element, $scope});
|
||||
}));
|
||||
|
||||
afterEach(() => {
|
||||
$scope.$destroy();
|
||||
$element.remove();
|
||||
describe('date() setter', () => {
|
||||
it(`should set the weekDays, the date in the controller and call fetchHours`, () => {
|
||||
let today = new Date();
|
||||
spyOn(controller, 'fetchHours');
|
||||
|
||||
controller.date = today;
|
||||
|
||||
expect(controller._date).toEqual(today);
|
||||
expect(controller.started).toBeDefined();
|
||||
expect(controller.ended).toBeDefined();
|
||||
expect(controller.weekDays.length).toEqual(7);
|
||||
expect(controller.fetchHours).toHaveBeenCalledWith();
|
||||
});
|
||||
});
|
||||
|
||||
describe('hours() setter', () => {
|
||||
it(`should set hours data at it's corresponding week day`, () => {
|
||||
let today = new Date();
|
||||
spyOn(controller, 'fetchHours');
|
||||
|
||||
controller.date = today;
|
||||
|
||||
|
@ -35,35 +46,42 @@ describe('Worker', () => {
|
|||
userFk: 1
|
||||
}, {
|
||||
id: 2,
|
||||
timed: today.toJSON(),
|
||||
timed: controller.ended.toJSON(),
|
||||
userFk: 1
|
||||
}, {
|
||||
id: 3,
|
||||
timed: today.toJSON(),
|
||||
timed: controller.ended.toJSON(),
|
||||
userFk: 1
|
||||
}
|
||||
];
|
||||
|
||||
controller.hours = hours;
|
||||
|
||||
let todayInWeek = today.getDay() - 1;
|
||||
|
||||
expect(controller.weekDays.length).toEqual(7);
|
||||
expect(controller.weekDays[0].hours.length).toEqual(1);
|
||||
expect(controller.weekDays[todayInWeek].hours.length).toEqual(2);
|
||||
expect(controller.weekDays[6].hours.length).toEqual(2);
|
||||
});
|
||||
});
|
||||
|
||||
describe('getWorkedHours() ', () => {
|
||||
fit(`should set the week days and the worked hours in today`, () => {
|
||||
it(`should `, () => {
|
||||
let today = new Date();
|
||||
spyOn(controller, 'fetchHours');
|
||||
|
||||
$httpBackend.whenRoute('GET', 'WorkerTimeControls/filter').respond({});
|
||||
$httpBackend.whenRoute('GET', 'WorkerCalendars/absences').respond({});
|
||||
controller.date = today;
|
||||
|
||||
let sixHoursInSeconds = 6 * 60 * 60;
|
||||
let tenHoursInSeconds = 10 * 60 * 60;
|
||||
let response = [
|
||||
{
|
||||
dated: today,
|
||||
expectedHours: sixHoursInSeconds,
|
||||
workedHours: tenHoursInSeconds,
|
||||
|
||||
},
|
||||
];
|
||||
$httpBackend.whenRoute('GET', 'Workers/:id/getWorkedHours')
|
||||
.respond([
|
||||
{dated: today},
|
||||
]);
|
||||
.respond(response);
|
||||
|
||||
today.setHours(0, 0, 0, 0);
|
||||
|
||||
|
@ -83,40 +101,15 @@ describe('Worker', () => {
|
|||
|
||||
$httpBackend.flush();
|
||||
|
||||
expect(controller.started).toEqual(started);
|
||||
});
|
||||
});
|
||||
|
||||
describe('weekTotalHours() ', () => {
|
||||
it(`should return a total worked hours from a week`, () => {
|
||||
const hourOne = new Date();
|
||||
hourOne.setHours(7, 0, 0, 0);
|
||||
const hourTwo = new Date();
|
||||
hourTwo.setHours(10, 0, 0, 0);
|
||||
const hourThree = new Date();
|
||||
hourThree.setHours(10, 20, 0, 0);
|
||||
const hourFour = new Date();
|
||||
hourFour.setHours(15, 0, 0, 0);
|
||||
|
||||
const weekday = {hours: [
|
||||
{id: 1, timed: hourOne},
|
||||
{id: 2, timed: hourTwo},
|
||||
{id: 3, timed: hourThree},
|
||||
{id: 4, timed: hourFour}
|
||||
]};
|
||||
controller.weekDays = [weekday];
|
||||
|
||||
const weekdayHours = controller.getWeekdayTotalHours(weekday);
|
||||
const weekHours = controller.weekTotalHours;
|
||||
|
||||
expect(weekdayHours).toEqual('08:00');
|
||||
expect(weekHours).toEqual('08:00');
|
||||
});
|
||||
expect(controller.weekDays.length).toEqual(7);
|
||||
expect(controller.weekDays[weekOffset].expectedHours).toEqual(response[0].expectedHours);
|
||||
expect(controller.weekDays[weekOffset].workedHours).toEqual(response[0].workedHours);
|
||||
expect(controller.weekTotalHours).toEqual('10:00');
|
||||
});
|
||||
|
||||
describe('formatHours() ', () => {
|
||||
it(`should format a passed timestamp to hours and minutes`, () => {
|
||||
const result = controller.formatHours(3600000);
|
||||
const result = controller.formatHours(3600);
|
||||
|
||||
expect(result).toEqual('01:00');
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue