-import * as program from 'commander'
-
// /!\ Before imports /!\
process.env.NODE_ENV = 'test'
-import { REQUESTS_INTERVAL } from '../../initializers/constants'
-import { Video, VideoRateType, VideoFile } from '../../../shared'
+import * as program from 'commander'
+import { Video, VideoFile, VideoRateType } from '../../../shared'
import {
- ServerInfo as DefaultServerInfo,
flushAndRunMultipleServers,
- setAccessTokensToServers,
- makeFriends,
- wait,
+ flushTests, follow,
+ getVideo,
+ getVideosList, getVideosListPagination,
killallServers,
- flushTests,
- uploadVideo,
- getVideosList,
- updateVideo,
removeVideo,
- getVideo,
- getAllVideosListBy,
- getRequestsStats
+ ServerInfo as DefaultServerInfo,
+ setAccessTokensToServers,
+ updateVideo,
+ uploadVideo, viewVideo,
+ wait
} from '../utils'
+import { getJobsListPaginationAndSort } from '../utils/server/jobs'
interface ServerInfo extends DefaultServerInfo {
requestsNumber: number
.option('-v, --view [weight]', 'Weight for viewing videos')
.option('-l, --like [weight]', 'Weight for liking videos')
.option('-s, --dislike [weight]', 'Weight for disliking videos')
- .option('-p, --pods [n]', 'Number of pods to run (3 or 6)', /^3|6$/, 3)
+ .option('-p, --servers [n]', 'Number of servers to run (3 or 6)', /^3|6$/, 3)
.option('-i, --interval-action [interval]', 'Interval in ms for an action')
.option('-I, --interval-integrity [interval]', 'Interval in ms for an integrity check')
- .option('-f, --flush', 'Flush datas on exit')
+ .option('-f, --flush', 'Flush data on exit')
.option('-d, --difference', 'Display difference if integrity is not okay')
.parse(process.argv)
const integrityInterval = program['intervalIntegrity'] !== undefined ? parseInt(program['intervalIntegrity'], 10) : 60000
const displayDiffOnFail = program['difference'] || false
-const numberOfPods = 6
+const numberOfServers = 6
console.log(
'Create weight: %d, update weight: %d, remove weight: %d, view weight: %d, like weight: %d, dislike weight: %d.',
// ----------------------------------------------------------------------------
async function start () {
- const servers = await runServers(numberOfPods)
+ const servers = await runServers(numberOfServers)
- process.on('exit', async () => await exitServers(servers, flushAtExit))
+ process.on('exit', async () => {
+ await exitServers(servers, flushAtExit)
+
+ return
+ })
process.on('SIGINT', goodbye)
process.on('SIGTERM', goodbye)
- console.log('Servers runned')
+ console.log('Servers ran')
initializeRequestsPerServer(servers)
let checking = false
initializeRequestsPerServer(servers)
checking = false
clearInterval(waitingInterval)
- }, REQUESTS_INTERVAL)
+ }, 10000)
}, integrityInterval)
}
return getRandomInt(0, servers.length)
}
-async function runServers (numberOfPods: number) {
- let servers = null
-
- // Run servers
- servers = await flushAndRunMultipleServers(numberOfPods)
+async function runServers (numberOfServers: number) {
+ const servers: ServerInfo[] = (await flushAndRunMultipleServers(numberOfServers))
+ .map(s => Object.assign({ requestsNumber: 0 }, s))
// Get the access tokens
await setAccessTokensToServers(servers)
- await makeFriends(servers[1].url, servers[1].accessToken)
- await makeFriends(servers[0].url, servers[0].accessToken)
- await wait(1000)
+ for (let i = 0; i < numberOfServers; i++) {
+ for (let j = 0; j < numberOfServers; j++) {
+ if (i === j) continue
- await makeFriends(servers[3].url, servers[3].accessToken)
- await makeFriends(servers[5].url, servers[5].accessToken)
- await makeFriends(servers[4].url, servers[4].accessToken)
-
- await wait(1000)
+ await follow(servers[i].url, [ servers[j].url ], servers[i].accessToken)
+ }
+ }
return servers
}
const toView = videos[getRandomInt(0, videos.length)].id
console.log('Viewing video from server ' + numServer)
- return getVideo(servers[numServer].url, toView)
+ return viewVideo(servers[numServer].url, toView)
}
function like (servers: ServerInfo[], numServer: number) {
const videos: Video[][] = []
const tasks: Promise<any>[] = []
- // Fetch all videos and remove some fields that can differ between pods
+ // Fetch all videos and remove some fields that can differ between servers
for (const server of servers) {
- const p = getAllVideosListBy(server.url).then(res => videos.push(res.body.data))
+ const p = getVideosListPagination(server.url, 0, 1000000, '-createdAt')
+ .then(res => videos.push(res.body.data))
tasks.push(p)
}
// Check if each server has pending request
for (const server of servers) {
- const p = getRequestsStats(server).then(res => {
- const stats = res.body
-
- if (
- stats.requestScheduler.totalRequests !== 0 ||
- stats.requestVideoEventScheduler.totalRequests !== 0 ||
- stats.requestVideoQaduScheduler.totalRequests !== 0
- ) {
- pendingRequests = true
- }
- })
+ const p = getJobsListPaginationAndSort(server.url, server.accessToken, 0, 10, '-createdAt')
+ .then(res => {
+ const jobs = res.body.data
+
+ for (const job of jobs) {
+ if (job.state === 'pending' || job.state === 'processing') {
+ pendingRequests = true
+ }
+ }
+ })
tasks.push(p)
}