mirror of https://github.com/Chocobozzz/PeerTube
83 lines
2.4 KiB
TypeScript
83 lines
2.4 KiB
TypeScript
|
import * as request from 'supertest'
|
||
|
import { Job, JobState } from '../../models'
|
||
|
import { wait } from '../miscs/miscs'
|
||
|
import { ServerInfo } from './servers'
|
||
|
|
||
|
function getJobsList (url: string, accessToken: string, state: JobState) {
|
||
|
const path = '/api/v1/jobs/' + state
|
||
|
|
||
|
return request(url)
|
||
|
.get(path)
|
||
|
.set('Accept', 'application/json')
|
||
|
.set('Authorization', 'Bearer ' + accessToken)
|
||
|
.expect(200)
|
||
|
.expect('Content-Type', /json/)
|
||
|
}
|
||
|
|
||
|
function getJobsListPaginationAndSort (url: string, accessToken: string, state: JobState, start: number, count: number, sort: string) {
|
||
|
const path = '/api/v1/jobs/' + state
|
||
|
|
||
|
return request(url)
|
||
|
.get(path)
|
||
|
.query({ start })
|
||
|
.query({ count })
|
||
|
.query({ sort })
|
||
|
.set('Accept', 'application/json')
|
||
|
.set('Authorization', 'Bearer ' + accessToken)
|
||
|
.expect(200)
|
||
|
.expect('Content-Type', /json/)
|
||
|
}
|
||
|
|
||
|
async function waitJobs (serversArg: ServerInfo[] | ServerInfo) {
|
||
|
const pendingJobWait = process.env.NODE_PENDING_JOB_WAIT ? parseInt(process.env.NODE_PENDING_JOB_WAIT, 10) : 2000
|
||
|
let servers: ServerInfo[]
|
||
|
|
||
|
if (Array.isArray(serversArg) === false) servers = [ serversArg as ServerInfo ]
|
||
|
else servers = serversArg as ServerInfo[]
|
||
|
|
||
|
const states: JobState[] = [ 'waiting', 'active', 'delayed' ]
|
||
|
let pendingRequests = false
|
||
|
|
||
|
function tasksBuilder () {
|
||
|
const tasks: Promise<any>[] = []
|
||
|
pendingRequests = false
|
||
|
|
||
|
// Check if each server has pending request
|
||
|
for (const server of servers) {
|
||
|
for (const state of states) {
|
||
|
const p = getJobsListPaginationAndSort(server.url, server.accessToken, state, 0, 10, '-createdAt')
|
||
|
.then(res => res.body.data)
|
||
|
.then((jobs: Job[]) => jobs.filter(j => j.type !== 'videos-views'))
|
||
|
.then(jobs => {
|
||
|
if (jobs.length !== 0) pendingRequests = true
|
||
|
})
|
||
|
tasks.push(p)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return tasks
|
||
|
}
|
||
|
|
||
|
do {
|
||
|
await Promise.all(tasksBuilder())
|
||
|
|
||
|
// Retry, in case of new jobs were created
|
||
|
if (pendingRequests === false) {
|
||
|
await wait(pendingJobWait)
|
||
|
await Promise.all(tasksBuilder())
|
||
|
}
|
||
|
|
||
|
if (pendingRequests) {
|
||
|
await wait(1000)
|
||
|
}
|
||
|
} while (pendingRequests)
|
||
|
}
|
||
|
|
||
|
// ---------------------------------------------------------------------------
|
||
|
|
||
|
export {
|
||
|
getJobsList,
|
||
|
waitJobs,
|
||
|
getJobsListPaginationAndSort
|
||
|
}
|