mirror of
https://github.com/softprops/action-gh-release.git
synced 2025-05-10 18:44:19 +00:00
node_modules
This commit is contained in:
parent
0e414c630a
commit
78c309ef59
555 changed files with 103819 additions and 1 deletions
237
node_modules/bottleneck/test/retries.js
generated
vendored
Normal file
237
node_modules/bottleneck/test/retries.js
generated
vendored
Normal file
|
@ -0,0 +1,237 @@
|
|||
var makeTest = require('./context')
|
||||
var Bottleneck = require('./bottleneck')
|
||||
var assert = require('assert')
|
||||
var child_process = require('child_process')
|
||||
|
||||
describe('Retries', function () {
|
||||
var c
|
||||
|
||||
afterEach(function () {
|
||||
return c.limiter.disconnect(false)
|
||||
})
|
||||
|
||||
it('Should retry when requested by the user (sync)', async function () {
|
||||
c = makeTest({ trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
return 50
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
var times = 0
|
||||
const job = function () {
|
||||
times++
|
||||
if (times <= 2) {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
return Promise.resolve('Success!')
|
||||
}
|
||||
|
||||
c.mustEqual(await c.limiter.schedule(job), 'Success!')
|
||||
const results = await c.results()
|
||||
assert(results.elapsed > 90 && results.elapsed < 130)
|
||||
c.mustEqual(failedEvents, 2)
|
||||
c.mustEqual(retryEvents, 2)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
it('Should retry when requested by the user (async)', async function () {
|
||||
c = makeTest({ trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
return Promise.resolve(50)
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
var times = 0
|
||||
const job = function () {
|
||||
times++
|
||||
if (times <= 2) {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
return Promise.resolve('Success!')
|
||||
}
|
||||
|
||||
c.mustEqual(await c.limiter.schedule(job), 'Success!')
|
||||
const results = await c.results()
|
||||
assert(results.elapsed > 90 && results.elapsed < 130)
|
||||
c.mustEqual(failedEvents, 2)
|
||||
c.mustEqual(retryEvents, 2)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
it('Should not retry when user returns an error (sync)', async function () {
|
||||
c = makeTest({ errorEventsExpected: true, trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
var errorEvents = 0
|
||||
var caught = false
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
throw new Error('Nope')
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
c.limiter.on('error', function (error, info) {
|
||||
c.mustEqual(error.message, 'Nope')
|
||||
errorEvents++
|
||||
})
|
||||
|
||||
const job = function () {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
|
||||
try {
|
||||
await c.limiter.schedule(job)
|
||||
throw new Error('Should not reach')
|
||||
} catch (error) {
|
||||
c.mustEqual(error.message, 'boom')
|
||||
caught = true
|
||||
}
|
||||
c.mustEqual(failedEvents, 1)
|
||||
c.mustEqual(retryEvents, 0)
|
||||
c.mustEqual(errorEvents, 1)
|
||||
c.mustEqual(caught, true)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
it('Should not retry when user returns an error (async)', async function () {
|
||||
c = makeTest({ errorEventsExpected: true, trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
var errorEvents = 0
|
||||
var caught = false
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
return Promise.reject(new Error('Nope'))
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
c.limiter.on('error', function (error, info) {
|
||||
c.mustEqual(error.message, 'Nope')
|
||||
errorEvents++
|
||||
})
|
||||
|
||||
const job = function () {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
|
||||
try {
|
||||
await c.limiter.schedule(job)
|
||||
throw new Error('Should not reach')
|
||||
} catch (error) {
|
||||
c.mustEqual(error.message, 'boom')
|
||||
caught = true
|
||||
}
|
||||
c.mustEqual(failedEvents, 1)
|
||||
c.mustEqual(retryEvents, 0)
|
||||
c.mustEqual(errorEvents, 1)
|
||||
c.mustEqual(caught, true)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
it('Should not retry when user returns null (sync)', async function () {
|
||||
c = makeTest({ trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
var caught = false
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
return null
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
const job = function () {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
|
||||
try {
|
||||
await c.limiter.schedule(job)
|
||||
throw new Error('Should not reach')
|
||||
} catch (error) {
|
||||
c.mustEqual(error.message, 'boom')
|
||||
caught = true
|
||||
}
|
||||
c.mustEqual(failedEvents, 1)
|
||||
c.mustEqual(retryEvents, 0)
|
||||
c.mustEqual(caught, true)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
it('Should not retry when user returns null (async)', async function () {
|
||||
c = makeTest({ trackDoneStatus: true })
|
||||
var failedEvents = 0
|
||||
var retryEvents = 0
|
||||
var caught = false
|
||||
|
||||
c.limiter.on('failed', function (error, info) {
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 1)
|
||||
c.mustEqual(info.retryCount, failedEvents)
|
||||
failedEvents++
|
||||
return Promise.resolve(null)
|
||||
})
|
||||
|
||||
c.limiter.on('retry', function (error, info) {
|
||||
retryEvents++
|
||||
})
|
||||
|
||||
const job = function () {
|
||||
return Promise.reject(new Error('boom'))
|
||||
}
|
||||
|
||||
try {
|
||||
await c.limiter.schedule(job)
|
||||
throw new Error('Should not reach')
|
||||
} catch (error) {
|
||||
c.mustEqual(error.message, 'boom')
|
||||
caught = true
|
||||
}
|
||||
c.mustEqual(failedEvents, 1)
|
||||
c.mustEqual(retryEvents, 0)
|
||||
c.mustEqual(caught, true)
|
||||
c.mustEqual(c.limiter.counts().EXECUTING, 0)
|
||||
c.mustEqual(c.limiter.counts().DONE, 1)
|
||||
})
|
||||
|
||||
})
|
Loading…
Add table
Add a link
Reference in a new issue