Merged in release/2024-01-29 (pull request #1229)

IO-1532 resolve update logic issue for status timings.
This commit is contained in:
Patrick Fic
2024-01-29 17:06:19 +00:00
2 changed files with 82 additions and 65 deletions

View File

@@ -1989,12 +1989,20 @@ exports.UPDATE_OLD_TRANSITION = `mutation UPDATE_OLD_TRANSITION($jobid: uuid!, $
} }
}`; }`;
exports.INSERT_NEW_TRANSITION = `mutation INSERT_NEW_TRANSITION($newTransition: transitions_insert_input!, $oldTransitionId: uuid, $duration: numeric) { exports.INSERT_NEW_TRANSITION = (
includeOldTransition
) => `mutation INSERT_NEW_TRANSITION($newTransition: transitions_insert_input!, ${
includeOldTransition ? `$oldTransitionId: uuid!, $duration: numeric` : ""
}) {
insert_transitions_one(object: $newTransition) { insert_transitions_one(object: $newTransition) {
id id
} }
update_transitions(where: {id: {_eq: $oldTransitionId}}, _set: {duration: $duration}) { ${
includeOldTransition
? `update_transitions(where: {id: {_eq: $oldTransitionId}}, _set: {duration: $duration}) {
affected_rows affected_rows
}`
: ""
} }
}`; }`;

View File

@@ -48,12 +48,18 @@ async function StatusTransition(req, res) {
: new Date(update_transitions.returning[0].end) - : new Date(update_transitions.returning[0].end) -
new Date(update_transitions.returning[0].start); new Date(update_transitions.returning[0].start);
const resp2 = await client.request(queries.INSERT_NEW_TRANSITION, { const resp2 = await client.request(
queries.INSERT_NEW_TRANSITION(update_transitions.affected_rows > 0),
{
...(update_transitions.affected_rows > 0
? {
oldTransitionId: oldTransitionId:
update_transitions.affected_rows === 0 update_transitions.affected_rows === 0
? null ? null
: update_transitions.returning[0].id, : update_transitions.returning[0].id,
duration, duration,
}
: {}),
newTransition: { newTransition: {
bodyshopid: bodyshopid, bodyshopid: bodyshopid,
jobid: jobid, jobid: jobid,
@@ -68,7 +74,10 @@ async function StatusTransition(req, res) {
value: value, value: value,
type: "status", type: "status",
}, },
}); }
);
logger.log("job-transition-update-result", "DEBUG", null, jobid, resp2);
//Check to see if there is an existing status transition record. //Check to see if there is an existing status transition record.
//Query using Job ID, start is not null, end is null. //Query using Job ID, start is not null, end is null.