Server: add update case to real world script
This commit is contained in:
parent
45abb8b97b
commit
f2cdb86675
|
@ -17,6 +17,7 @@ const videosUtils = require('../utils/videos')
|
|||
program
|
||||
.option('-c, --create [weight]', 'Weight for creating videos')
|
||||
.option('-r, --remove [weight]', 'Weight for removing videos')
|
||||
.option('-u, --update [weight]', 'Weight for updating videos')
|
||||
.option('-p, --pods [n]', 'Number of pods to run (3 or 6)', /^3|6$/, 3)
|
||||
.option('-a, --action [interval]', 'Interval in ms for an action')
|
||||
.option('-i, --integrity [interval]', 'Interval in ms for an integrity check')
|
||||
|
@ -26,6 +27,7 @@ program
|
|||
|
||||
const createWeight = program.create !== undefined ? parseInt(program.create) : 5
|
||||
const removeWeight = program.remove !== undefined ? parseInt(program.remove) : 4
|
||||
const updateWeight = program.update !== undefined ? parseInt(program.update) : 4
|
||||
const flushAtExit = program.flush || false
|
||||
const actionInterval = program.action !== undefined ? parseInt(program.action) : 500
|
||||
let integrityInterval = program.integrity !== undefined ? parseInt(program.integrity) : 60000
|
||||
|
@ -39,7 +41,7 @@ const requestsMaxPerInterval = baseRequestInterval / actionInterval
|
|||
const intervalsToMakeAllRequests = Math.ceil(requestsMaxPerInterval / (constants.REQUESTS_LIMIT_PER_POD * numberOfPods))
|
||||
const waitForBeforeIntegrityCheck = (intervalsToMakeAllRequests * constants.REQUESTS_INTERVAL) + 1000
|
||||
|
||||
console.log('Create weight: %d, remove weight: %d.', createWeight, removeWeight)
|
||||
console.log('Create weight: %d, update weight: %d, remove weight: %d.', createWeight, updateWeight, removeWeight)
|
||||
if (flushAtExit) {
|
||||
console.log('Program will flush data on exit.')
|
||||
} else {
|
||||
|
@ -71,10 +73,12 @@ runServers(numberOfPods, function (err, servers) {
|
|||
setInterval(function () {
|
||||
if (checking === true) return
|
||||
|
||||
const rand = getRandomInt(0, createWeight + removeWeight)
|
||||
const rand = getRandomInt(0, createWeight + updateWeight + removeWeight)
|
||||
|
||||
if (rand < createWeight) {
|
||||
upload(servers, getRandomNumServer(servers))
|
||||
} else if (rand < createWeight + updateWeight) {
|
||||
update(servers, getRandomNumServer(servers))
|
||||
} else {
|
||||
remove(servers, getRandomNumServer(servers))
|
||||
}
|
||||
|
@ -180,6 +184,26 @@ function upload (servers, numServer, callback) {
|
|||
videosUtils.uploadVideo(servers[numServer].url, servers[numServer].accessToken, name, description, tags, file, callback)
|
||||
}
|
||||
|
||||
function update (servers, numServer, callback) {
|
||||
if (!callback) callback = function () {}
|
||||
|
||||
videosUtils.getVideosList(servers[numServer].url, function (err, res) {
|
||||
if (err) throw err
|
||||
|
||||
const videos = res.body.data.filter(function (video) { return video.isLocal })
|
||||
if (videos.length === 0) return callback()
|
||||
|
||||
const toUpdate = videos[getRandomInt(0, videos.length)].id
|
||||
const name = Date.now() + ' name'
|
||||
const description = Date.now() + ' description'
|
||||
const tags = [ Date.now().toString().substring(0, 5) + 't1', Date.now().toString().substring(0, 5) + 't2' ]
|
||||
|
||||
console.log('Updating video of server ' + numServer)
|
||||
|
||||
videosUtils.updateVideo(servers[numServer].url, servers[numServer].accessToken, toUpdate, name, description, tags, callback)
|
||||
})
|
||||
}
|
||||
|
||||
function remove (servers, numServer, callback) {
|
||||
if (!callback) callback = function () {}
|
||||
|
||||
|
|
Loading…
Reference in New Issue