More robust accept job controller
This commit is contained in:
parent
77666e3433
commit
d38541fd59
|
@ -1,4 +1,5 @@
|
||||||
import express, { UploadFiles } from 'express'
|
import express, { UploadFiles } from 'express'
|
||||||
|
import { retryTransactionWrapper } from '@server/helpers/database-utils'
|
||||||
import { createReqFiles } from '@server/helpers/express-utils'
|
import { createReqFiles } from '@server/helpers/express-utils'
|
||||||
import { logger, loggerTagsFactory } from '@server/helpers/logger'
|
import { logger, loggerTagsFactory } from '@server/helpers/logger'
|
||||||
import { generateRunnerJobToken } from '@server/helpers/token-generator'
|
import { generateRunnerJobToken } from '@server/helpers/token-generator'
|
||||||
|
@ -161,14 +162,29 @@ async function acceptRunnerJob (req: express.Request, res: express.Response) {
|
||||||
const runner = res.locals.runner
|
const runner = res.locals.runner
|
||||||
const runnerJob = res.locals.runnerJob
|
const runnerJob = res.locals.runnerJob
|
||||||
|
|
||||||
runnerJob.state = RunnerJobState.PROCESSING
|
const newRunnerJob = await retryTransactionWrapper(() => {
|
||||||
runnerJob.processingJobToken = generateRunnerJobToken()
|
return sequelizeTypescript.transaction(async transaction => {
|
||||||
runnerJob.startedAt = new Date()
|
await runnerJob.reload({ transaction })
|
||||||
runnerJob.runnerId = runner.id
|
|
||||||
|
|
||||||
const newRunnerJob = await sequelizeTypescript.transaction(transaction => {
|
if (runnerJob.state !== RunnerJobState.PENDING) {
|
||||||
return runnerJob.save({ transaction })
|
res.fail({
|
||||||
|
message: 'This job is not in pending state anymore',
|
||||||
|
status: HttpStatusCode.CONFLICT_409
|
||||||
|
})
|
||||||
|
|
||||||
|
return undefined
|
||||||
|
}
|
||||||
|
|
||||||
|
runnerJob.state = RunnerJobState.PROCESSING
|
||||||
|
runnerJob.processingJobToken = generateRunnerJobToken()
|
||||||
|
runnerJob.startedAt = new Date()
|
||||||
|
runnerJob.runnerId = runner.id
|
||||||
|
|
||||||
|
return runnerJob.save({ transaction })
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
if (!newRunnerJob) return
|
||||||
|
|
||||||
newRunnerJob.Runner = runner as RunnerModel
|
newRunnerJob.Runner = runner as RunnerModel
|
||||||
|
|
||||||
const result: AcceptRunnerJobResult = {
|
const result: AcceptRunnerJobResult = {
|
||||||
|
|
Loading…
Reference in New Issue