You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

185 lines
5.6 KiB

1 month ago
var makeTest = require('./context')
var Bottleneck = require('./bottleneck')
var assert = require('assert')
describe('Priority', function () {
var c
afterEach(function () {
return c.limiter.disconnect(false)
})
it('Should do basic ordering', function () {
c = makeTest({maxConcurrent: 1, minTime: 100, rejectOnDrop: false})
return Promise.all([
c.pNoErrVal(c.limiter.schedule(c.slowPromise, 50, null, 1), 1),
c.pNoErrVal(c.limiter.schedule(c.promise, null, 2), 2),
c.pNoErrVal(c.limiter.schedule({priority: 1}, c.promise, null, 5, 6), 5, 6),
c.pNoErrVal(c.limiter.schedule(c.promise, null, 3), 3),
c.pNoErrVal(c.limiter.schedule(c.promise, null, 4), 4)
])
.then(function () {
return c.last()
})
.then(function (results) {
c.checkResultsOrder([[1], [5,6], [2] ,[3], [4]])
c.checkDuration(400)
})
})
it('Should support LEAK', function () {
c = makeTest({
maxConcurrent: 1,
minTime: 100,
highWater: 3,
strategy: Bottleneck.strategy.LEAK,
rejectOnDrop: false
})
var called = false
c.limiter.on('dropped', function (dropped) {
c.mustExist(dropped.task)
c.mustExist(dropped.args)
c.mustExist(dropped.promise)
called = true
})
c.limiter.submit(c.slowJob, 50, null, 1, c.noErrVal(1))
c.limiter.submit(c.job, null, 2, c.noErrVal(2))
c.limiter.submit(c.job, null, 3, c.noErrVal(3))
c.limiter.submit(c.job, null, 4, c.noErrVal(4))
c.limiter.submit({priority: 2}, c.job, null, 5, c.noErrVal(5))
c.limiter.submit({priority: 1}, c.job, null, 6, c.noErrVal(6))
c.limiter.submit({priority: 9}, c.job, null, 7, c.noErrVal(7))
return c.last({ weight: 0 })
.then(function (results) {
c.checkDuration(200)
c.checkResultsOrder([[1], [6], [5]])
c.mustEqual(called, true)
})
})
it('Should support OVERFLOW', function () {
c = makeTest({
maxConcurrent: 1,
minTime: 100,
highWater: 2,
strategy: Bottleneck.strategy.OVERFLOW,
rejectOnDrop: false
})
var called = false
c.limiter.on('dropped', function (dropped) {
c.mustExist(dropped.task)
c.mustExist(dropped.args)
c.mustExist(dropped.promise)
called = true
})
c.limiter.submit(c.slowJob, 50, null, 1, c.noErrVal(1))
c.limiter.submit(c.job, null, 2, c.noErrVal(2))
c.limiter.submit(c.job, null, 3, c.noErrVal(3))
c.limiter.submit(c.job, null, 4, c.noErrVal(4))
c.limiter.submit({priority: 2}, c.job, null, 5, c.noErrVal(5))
c.limiter.submit({priority: 1}, c.job, null, 6, c.noErrVal(6))
return c.limiter.submit({priority: 9}, c.job, null, 7, c.noErrVal(7))
.then(function () {
return c.limiter.updateSettings({ highWater: null })
})
.then(c.last)
.then(function (results) {
c.checkDuration(200)
c.checkResultsOrder([[1], [2], [3]])
c.mustEqual(called, true)
})
})
it('Should support OVERFLOW_PRIORITY', function () {
c = makeTest({
maxConcurrent: 1,
minTime: 100,
highWater: 2,
strategy: Bottleneck.strategy.OVERFLOW_PRIORITY,
rejectOnDrop: false
})
var called = false
c.limiter.on('dropped', function (dropped) {
c.mustExist(dropped.task)
c.mustExist(dropped.args)
c.mustExist(dropped.promise)
called = true
})
c.limiter.submit(c.slowJob, 50, null, 1, c.noErrVal(1))
c.limiter.submit(c.job, null, 2, c.noErrVal(2))
c.limiter.submit(c.job, null, 3, c.noErrVal(3))
c.limiter.submit(c.job, null, 4, c.noErrVal(4))
c.limiter.submit({priority: 2}, c.job, null, 5, c.noErrVal(5))
c.limiter.submit({priority: 2}, c.job, null, 6, c.noErrVal(6))
return c.limiter.submit({priority: 2}, c.job, null, 7, c.noErrVal(7))
.then(function () {
return c.limiter.updateSettings({highWater: null})
})
.then(c.last)
.then(function (results) {
c.checkDuration(200)
c.checkResultsOrder([[1], [5], [6]])
c.mustEqual(called, true)
})
})
it('Should support BLOCK', function (done) {
c = makeTest({
maxConcurrent: 1,
minTime: 100,
highWater: 2,
trackDoneStatus: true,
strategy: Bottleneck.strategy.BLOCK
})
var called = 0
c.limiter.on('dropped', function (dropped) {
c.mustExist(dropped.task)
c.mustExist(dropped.args)
c.mustExist(dropped.promise)
called++
if (called === 3) {
c.limiter.updateSettings({ highWater: null })
.then(function () {
return c.limiter.schedule(c.job, null, 8)
})
.catch(function (err) {
assert(err instanceof Bottleneck.BottleneckError)
c.mustEqual(err.message, 'This job has been dropped by Bottleneck')
c.limiter.removeAllListeners('error')
done()
})
}
})
c.limiter.submit(c.slowJob, 20, null, 1, c.noErrVal(1))
c.limiter.submit(c.slowJob, 20, null, 2, (err) => c.mustExist(err))
c.limiter.submit(c.slowJob, 20, null, 3, (err) => c.mustExist(err))
c.limiter.submit(c.slowJob, 20, null, 4, (err) => c.mustExist(err))
})
it('Should have the right priority', function () {
c = makeTest({maxConcurrent: 1, minTime: 100})
c.pNoErrVal(c.limiter.schedule({priority: 6}, c.slowPromise, 50, null, 1), 1)
c.pNoErrVal(c.limiter.schedule({priority: 5}, c.promise, null, 2), 2)
c.pNoErrVal(c.limiter.schedule({priority: 4}, c.promise, null, 3), 3)
c.pNoErrVal(c.limiter.schedule({priority: 3}, c.promise, null, 4), 4)
return c.last()
.then(function (results) {
c.checkDuration(300)
c.checkResultsOrder([[1], [4], [3], [2]])
})
})
})