Merge pull request '3736-worker-timeControl_calculate' (#926) from 3736-worker-timeControl_calculate into dev
gitea/salix/pipeline/head This commit looks good
Details
gitea/salix/pipeline/head This commit looks good
Details
Reviewed-on: #926 Reviewed-by: Joan Sanchez <joan@verdnatura.es>
This commit is contained in:
commit
8414f94cf6
|
@ -0,0 +1,73 @@
|
||||||
|
DROP PROCEDURE IF EXISTS vn.timeControl_getError;
|
||||||
|
|
||||||
|
DELIMITER $$
|
||||||
|
$$
|
||||||
|
CREATE DEFINER=`root`@`localhost` PROCEDURE `vn`.`timeControl_getError`(vDatedFrom DATETIME, vDatedTo DATETIME)
|
||||||
|
BEGIN
|
||||||
|
/*
|
||||||
|
* @param vDatedFrom
|
||||||
|
* @param vDatedTo
|
||||||
|
* @table tmp.`user`(userFk)
|
||||||
|
* Fichadas incorrectas de las cuales no se puede calcular horas trabajadas
|
||||||
|
* @return tmp.timeControlError (id)
|
||||||
|
*/
|
||||||
|
DECLARE vDayMaxTime INTEGER;
|
||||||
|
|
||||||
|
SET @journeyCounter := 0;
|
||||||
|
SET @lastUserFk := NULL;
|
||||||
|
|
||||||
|
SELECT dayMaxTime INTO vDayMaxTime
|
||||||
|
FROM workerTimeControlConfig LIMIT 1;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.timeControl;
|
||||||
|
CREATE TEMPORARY TABLE tmp.timeControl
|
||||||
|
(INDEX(id), INDEX(journeyCounter))
|
||||||
|
ENGINE = MEMORY
|
||||||
|
SELECT sub.id,
|
||||||
|
sub.direction,
|
||||||
|
sub.timed,
|
||||||
|
IF(sub.direction = 'in' OR @hasOut OR sub.userFk <> @lastUserFk, @journeyCounter := @journeyCounter + 1, @journeyCounter) journeyCounter,
|
||||||
|
@lastUserFk := sub.userFk workerFk,
|
||||||
|
IF(sub.direction = 'out', @hasOut:= TRUE, @hasOut:= FALSE)
|
||||||
|
FROM (
|
||||||
|
SELECT DISTINCT wtc.id,
|
||||||
|
wtc.direction,
|
||||||
|
wtc.timed,
|
||||||
|
wtc.userFk
|
||||||
|
FROM workerTimeControl wtc
|
||||||
|
JOIN tmp.`user` w ON w.userFk = wtc.userFk
|
||||||
|
WHERE wtc.timed BETWEEN DATE_SUB(vDatedFrom, INTERVAL 1 DAY) AND DATE_ADD(vDatedTo, INTERVAL 1 DAY)
|
||||||
|
ORDER BY wtc.userFk, wtc.timed
|
||||||
|
) sub;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.timeControlAux;
|
||||||
|
CREATE TEMPORARY TABLE tmp.timeControlAux
|
||||||
|
(INDEX(id), INDEX(journeyCounter))
|
||||||
|
ENGINE = MEMORY
|
||||||
|
SELECT * FROM tmp.timeControl;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.timeControlError;
|
||||||
|
CREATE TEMPORARY TABLE tmp.timeControlError
|
||||||
|
(INDEX(id))
|
||||||
|
ENGINE = MEMORY
|
||||||
|
SELECT id
|
||||||
|
FROM tmp.timeControlAux tca
|
||||||
|
JOIN (SELECT journeyCounter,
|
||||||
|
UNIX_TIMESTAMP(MAX(timed)) - UNIX_TIMESTAMP(MIN(timed)) timeWork,
|
||||||
|
SUM(direction = 'in') totalIn,
|
||||||
|
SUM(direction = 'out') totalOut,
|
||||||
|
timed
|
||||||
|
FROM tmp.timeControl
|
||||||
|
GROUP BY journeyCounter
|
||||||
|
HAVING COUNT(*) MOD 2 = 1
|
||||||
|
OR totalIn <> 1
|
||||||
|
OR totalOut <> 1
|
||||||
|
OR timeWork >= vDayMaxTime
|
||||||
|
)sub ON sub.journeyCounter = tca.journeyCounter
|
||||||
|
WHERE sub.timed BETWEEN vDatedFrom AND vDatedTo;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.timeControl;
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.timeControlAux;
|
||||||
|
|
||||||
|
END$$
|
||||||
|
DELIMITER ;
|
|
@ -99,8 +99,8 @@ describe('Worker time control path', () => {
|
||||||
|
|
||||||
expect(result).toEqual(scanTime);
|
expect(result).toEqual(scanTime);
|
||||||
});
|
});
|
||||||
// 3736 check proc vn.timeControl_calculate
|
|
||||||
xit(`should check Hank Pym worked 6:40 hours`, async() => {
|
it(`should check Hank Pym worked 6:40 hours`, async() => {
|
||||||
await page.waitForTextInElement(selectors.workerTimeControl.mondayWorkedHours, '06:40 h.');
|
await page.waitForTextInElement(selectors.workerTimeControl.mondayWorkedHours, '06:40 h.');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue