New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

bull

Package Overview
Dependencies
Maintainers
1
Versions
198
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

bull - npm Package Compare versions

Comparing version

to
3.4.8

docs/_config.yml

238

CHANGELOG.md

@@ -1,7 +0,12 @@

Changelog
=========
# Changelog
v.3.4.7
-------
## v.3.4.8
- emit waiting event when waking up sleep jobs fixing #792
- throw error if missing processor file fixing #954
[Changes](https://github.com/OptimalBits/bull/compare/v3.4.7...v3.4.8)
## v.3.4.7
- Fixes to deal with removing correctly in priority queues #984

@@ -11,4 +16,3 @@

v.3.4.6
-------
## v.3.4.6

@@ -19,4 +23,4 @@ - Reverted use of arrow function that was incompatible with older versions of node.

v.3.4.5
-------
## v.3.4.5
- Fixed Unhandled promise rejections #1012.

@@ -26,4 +30,3 @@

v.3.4.4
-------
## v.3.4.4

@@ -37,4 +40,3 @@ - Partially fixed #845. When call queue.close() bull throws Error: Connection is closed.

v.3.4.3
-------
## v.3.4.3

@@ -51,4 +53,3 @@ - Fixed #994 queue.getJobs() race condition.

v.3.4.2
-------
## v.3.4.2

@@ -62,4 +63,3 @@ - Fixed #903 Globally paused queue cannot receive job (or not shown in Arena untill queue is globally resumed).

v.3.4.1
-------
## v.3.4.1

@@ -70,4 +70,3 @@ - Better check for closing in moveUnlockedJobsToWait, possibly fixing #806.

v.3.4.0
-------
## v.3.4.0

@@ -80,4 +79,3 @@ - Added support for prioritized delayed jobs.

v.3.3.10
-------
## v.3.3.10

@@ -90,6 +88,4 @@ - Faster next job fetch #868

## v.3.3.9
v.3.3.9
-------
- Support custom backoff strategies.

@@ -101,6 +97,4 @@ - Fixed #786. Handling of ES6 default export.

## v.3.3.8
v.3.3.8
-------
- Fixed #812. External process doesn't terminate on `queue.close()`.

@@ -112,6 +106,4 @@ - Fixed #830. Named Process Sent to Wrong Processor.

## v.3.3.7
v.3.3.7
-------
- Fixed #807.

@@ -122,4 +114,3 @@ - Adding ability to limit by stacktrace. #798.

v.3.3.6
-------
## v.3.3.6

@@ -132,4 +123,3 @@ - Fixed #766, #781, #716.

v.3.3.5
-------
## v.3.3.5

@@ -140,6 +130,4 @@ - Fixed #764, #762, #759.

## v.3.3.4
v.3.3.4
-------
- Fixed #748.

@@ -149,4 +137,3 @@

v.3.3.3
-------
## v.3.3.3

@@ -159,4 +146,3 @@ - Re-fixed #739.

v.3.3.2
-------
## v.3.3.2

@@ -169,4 +155,3 @@ - Fixed #721. SyntaxError: Unexpected token u in JSON at position 0.

v.3.3.1
-------
## v.3.3.1

@@ -177,6 +162,5 @@ - Fixed #714

v.3.3.0
-------
## v.3.3.0
- Added a method ```Queue##removeRepeatable``` to remove repeatable jobs.
- Added a method `Queue##removeRepeatable` to remove repeatable jobs.
- Now also emits drained as a global event.

@@ -187,4 +171,3 @@ - Fixed #518, #624

v.3.2.0
-------
## v.3.2.0

@@ -195,4 +178,3 @@ - Added support for running jobs in child processes #488

v.3.1.0
-------
## v.3.1.0

@@ -205,9 +187,7 @@ - Added rate limiter support.

v.3.0.0
-------
## v.3.0.0
- No changes.
v.3.0.0-rc.10
-------------
## v.3.0.0-rc.10

@@ -219,6 +199,4 @@ - Fixed #666.

## v.3.0.0-rc.9
v.3.0.0-rc.9
------------
- Fixed #672.

@@ -229,6 +207,4 @@ - Fixed #670

## v.3.0.0-rc.8
v.3.0.0-rc.8
------------
- Enhanced job fetching #651 (faster and more reliable).

@@ -238,4 +214,3 @@

v.3.0.0-rc.7
------------
## v.3.0.0-rc.7

@@ -246,6 +221,4 @@ - Fixed #659

## v.3.0.0-rc.6
v.3.0.0-rc.6
------------
- Fixed #645.

@@ -255,4 +228,3 @@

v.3.0.0-rc.5
------------
## v.3.0.0-rc.5

@@ -267,4 +239,3 @@ - Improved performance, specially when having many concurrent workers.

v.3.0.0-rc.4
------------
## v.3.0.0-rc.4

@@ -280,4 +251,3 @@ - Added support for naming workers in redis connections #530.

v.3.0.0-rc.3
------------
## v.3.0.0-rc.3

@@ -290,4 +260,3 @@ - Fixed #579.

v.3.0.0-rc.2
------------
## v.3.0.0-rc.2

@@ -299,4 +268,3 @@ - Improved performance of moveToActive #550.

v.3.0.0-rc.1
------------
## v.3.0.0-rc.1

@@ -309,4 +277,3 @@ - Improved error and lock handling for failed jobs #499, #539.

v.3.0.0-alpha.4
---------------
## v.3.0.0-alpha.4

@@ -317,4 +284,3 @@ - Implemented repeatable jobs. #252.

v.3.0.0-alpha.3
---------------
## v.3.0.0-alpha.3

@@ -325,4 +291,3 @@ - Simplified global events #501.

v.3.0.0-alpha.2
---------------
## v.3.0.0-alpha.2

@@ -333,6 +298,4 @@ - Eliminated possible memory leak #503

## v.3.0.0-alpha.1
v.3.0.0-alpha.1
---------------
- improved job fetch mechanism. #480.

@@ -347,4 +310,3 @@ - job.jobId changed to job.id.

v.2.2.6
-------
## v.2.2.6

@@ -356,6 +318,4 @@ - Persisted failedReason when storing job data.

## v.2.2.5
v.2.2.5
-------
- Fixed so that redis key prefix works properly.

@@ -365,6 +325,4 @@

## v.2.2.4
v.2.2.4
-------
- Allow reusing certain redis connections.

@@ -374,4 +332,3 @@

v.2.2.3
-------
## v.2.2.3

@@ -383,4 +340,3 @@ - Added getJobCounts.

v.2.2.2
-------
## v.2.2.2

@@ -391,4 +347,3 @@ - Fixed redis script cache gets bloated after update to bull 2.0 #426

v.2.2.1
-------
## v.2.2.1

@@ -400,4 +355,3 @@ - Re-added createClient option that was removed by mistake.

v.2.2.0
-------
## v.2.2.0

@@ -411,6 +365,4 @@ - Much improved priority queues, simpler, faster and more reliable.

## v.2.1.2
v.2.1.2
-------
- Fixed Error renewing lock LockError: Exceeded 0 attempts to lock the resource #437

@@ -421,4 +373,3 @@ - Fixed Unable to renew nonexisting lock on job fail #441

v.2.1.1
-------
## v.2.1.1

@@ -429,4 +380,3 @@ - Catch errors produced in timers. Related to #441

v.2.1.0
-------
## v.2.1.0

@@ -441,4 +391,3 @@ - Fixed #397, Error: Unable to renew nonexisting lock

v.2.0.0
-------
## v.2.0.0

@@ -449,4 +398,3 @@ - Changed redis module to ioredis fixing many issues along the way, see changes.

v.1.1.3
-------
## v.1.1.3

@@ -458,4 +406,3 @@ - fixed "Broken constructor pattern from recent commit" #384

v1.1.2
-------
## v1.1.2

@@ -466,4 +413,3 @@ - regained backwards compatibility in events by using disturbed 1.0.6

v1.1.1
-------
## v1.1.1

@@ -475,4 +421,3 @@ - Returned this in queue##on and queue##once for backwards compatibility.

v1.1.0
-------
## v1.1.0

@@ -487,4 +432,3 @@ - Fixed [job corruption issue](https://github.com/OptimalBits/bull/pull/359)

v1.0.0
-------
## v1.0.0

@@ -495,4 +439,3 @@ - improvements in clean (fixes and performance).

v1.0.0-rc4
----------
## v1.0.0-rc4

@@ -504,4 +447,3 @@ - fixed lock renew logic.

v1.0.0-rc3
----------
## v1.0.0-rc3

@@ -512,4 +454,3 @@ - smaller fixes.

v1.0.0-rc2
----------
## v1.0.0-rc2

@@ -526,7 +467,6 @@ - Improved locking when removing and processing stalled jobs.

v1.0.0-rc1
----------
## v1.0.0-rc1
- Removed all potential dangerous hazards by atomizing many operations using
cached LUA scripts.
cached LUA scripts.
- Improved performance around 400% compared to previous version.

@@ -538,4 +478,3 @@ - Better pause/resume (#266), and added pause for local workers.

v0.7.2
------
## v0.7.2

@@ -548,4 +487,3 @@ - Added local pause/resume functionality

v0.7.1
------
## v0.7.1

@@ -556,4 +494,3 @@ - fixed storing of stacktraces

v0.7.0
------
## v0.7.0

@@ -566,4 +503,3 @@ - store the return value from the job handlers.

v0.4.0
------
## v0.4.0

@@ -574,4 +510,3 @@ - added a Queue##clean method

v0.3.0
------
## v0.3.0

@@ -587,15 +522,12 @@ - added support for custom clients.

v0.2.7
------
## v0.2.7
[Changes](https://github.com/OptimalBits/bull/compare/v0.2.6...v0.2.7)
v0.2.6
------
## v0.2.6
- [Fix] #103 When a queue start it do not process delayed job.
[Changes](https://github.com/OptimalBits/bull/compare/v0.2.5...v0.2.6)
[Changes](https://github.com/OptimalBits/bull/compare/v0.2.5...v0.2.6)
v0.2.5
------
## v0.2.5

@@ -608,24 +540,19 @@ - [upgrade] Upgraded node redis to version 0.12.x

v0.2.4
------
## v0.2.4
[Changes](https://github.com/OptimalBits/bull/compare/v0.2.3...v0.2.4)
v0.2.3
------
## v0.2.3
[Changes](https://github.com/OptimalBits/bull/compare/v0.1.9...v0.2.3)
v0.1.9
------
## v0.1.9
- [Improvement] Faster job removal. (manast)
v0.1.8
------
## v0.1.8
- [Improvement] Better promisification of redis methods. (manast)
v0.1.7
------
## v0.1.7

@@ -636,4 +563,3 @@ - [Feature] Added a convenience method for getting a job. (loginx)

v0.1.6
------
## v0.1.6

@@ -640,0 +566,0 @@ - [Fix] Improved and corrected job's getters.

@@ -23,6 +23,2 @@ /**

//
// for some very strange reason, defining scripts with this code results in this error
// when executing the scripts: ERR value is not an integer or out of range
//
module.exports = (function() {

@@ -29,0 +25,0 @@ var scripts;

@@ -182,2 +182,9 @@ /*eslint-env node */

/**
* Moves a job to the completed queue.
* Returned job to be used with Queue.prototype.nextJobFromJobData.
* @param returnValue {string} The jobs success message.
* @param ignoreLock {boolean} True when wanting to ignore the redis lock on this job.
* @returns {Promise} Returns the jobData of the next job in the waiting queue.
*/
Job.prototype.moveToCompleted = function(returnValue, ignoreLock) {

@@ -204,2 +211,8 @@ this.returnvalue = returnValue || 0;

/**
* Moves a job to the failed queue.
* @param err {string} The jobs error message.
* @param ignoreLock {boolean} True when wanting to ignore the redis lock on this job.
* @returns void
*/
Job.prototype.moveToFailed = function(err, ignoreLock) {

@@ -206,0 +219,0 @@ var _this = this;

@@ -20,27 +20,25 @@ 'use strict';

var _this = this;
return checkProcessorFile(processFile).then(function() {
var child = _this.getFree(processFile).pop();
var child = _this.getFree(processFile).pop();
if (child) {
_this.retained[child.pid] = child;
return child;
}
if (child) {
_this.retained[child.pid] = child;
return Promise.resolve(child);
}
// if node process is running with --inspect, don't include that option
// when spawning the children
var execArgv = _.filter(process.execArgv, function(arg) {
return arg.indexOf('--inspect') === -1;
});
// if node process is running with --inspect, don't include that option
// when spawning the children
var execArgv = _.filter(process.execArgv, function(arg) {
return arg.indexOf('--inspect') === -1;
});
child = fork(path.join(__dirname, './master.js'), {
execArgv: execArgv
});
child.processFile = processFile;
child = fork(path.join(__dirname, './master.js'), {
execArgv: execArgv
});
child.processFile = processFile;
_this.retained[child.pid] = child;
_this.retained[child.pid] = child;
child.on('exit', _this.remove.bind(_this, child));
child.on('exit', _this.remove.bind(_this, child));
return initChild(child, processFile).return(child);
});
return initChild(child, processFile).return(child);
};

@@ -95,18 +93,2 @@

var checkProcessorFile = function(processorFile) {
return new Promise(function(resolve, reject) {
fs.exists(processorFile, function(stats, err) {
if (err) {
reject(err);
} else {
if (stats) {
resolve();
} else {
reject(new Error('File does not exists'));
}
}
});
});
};
module.exports = ChildPool;

@@ -9,2 +9,4 @@ /*eslint-env node */

var fs = require('fs');
var path = require('path');
var util = require('util');

@@ -41,3 +43,3 @@ var url = require('url');

v | -- > failed
delayed
delayed
*/

@@ -665,3 +667,11 @@

if (typeof handler === 'string') {
var processorFile =
handler + (path.extname(handler) === '.js' ? '' : '.js');
if (!fs.existsSync(processorFile)) {
throw new Error('File ' + processorFile + ' does not exist');
}
this.childPool = this.childPool || require('./process/child-pool')();
var sandbox = require('./process/sandbox');

@@ -668,0 +678,0 @@ this.handlers[name] = sandbox(handler, this.childPool).bind(this);

@@ -333,3 +333,3 @@ /**

];
var args = [queue.toKey(''), delayedTimestamp];
var args = [queue.toKey(''), delayedTimestamp, queue.token];
return queue.client.updateDelaySet(keys.concat(args));

@@ -336,0 +336,0 @@ },

{
"name": "bull",
"version": "3.4.7",
"version": "3.4.8",
"description": "Job manager",

@@ -5,0 +5,0 @@ "main": "./index.js",

@@ -13,2 +13,3 @@

- [Custom backoff strategy](#custom-backoff-strategy)
- [Async multiple-repo job processor](#async-multiple-repo-job-processor)

@@ -201,1 +202,50 @@ If you have any other common patterns you want to add, pull request them!

```
Manually fetching jobs
----------------------------------
If you want the actual job processing to be done in a seperate repo/service than where `bull` is running, this pattern may be for you.
Manually transitioning states for jobs can be done with a few simple methods.
1. Adding a job to the 'waiting' queue. Grab the queue and call `add`.
```typescript
import Queue from "bull";
const queue = new Queue(description, queueOptions);
queue.add({ random_attr: "random_value" });
```
2. Pulling a job from 'waiting' and moving it to 'active'.
```typescript
const job: Job = await queue.getNextJob();
```
3. Move the job to the 'failed' queue if something goes wrong.
```typescript
const (nextJobData, nextJobId) = await job.moveToFailed(
{
message: "Call to external service failed!",
},
true,
);
```
3. Move the job to the 'completed' queue.
```typescript
const (nextJobData, nextJobId) = await job.moveToCompleted("succeeded", true);
```
4. Return the next job if one is returned.
```typescript
if (nextJobdata) {
return Job.fromJSON(queue, nextJobData, nextJobId);
}
```
Then you can easily wrap `bull` in an API for use with external systems.

@@ -70,3 +70,3 @@

Do you want to sponsor bull development? Please, let us now!
Do you want to sponsor bull development? Please, let us know!

@@ -73,0 +73,0 @@

@@ -40,2 +40,4 @@

- [Job#finished](#jobfinished)
- [Job#moveToCompleted](#jobMoveToCompleted)
- [Job#moveToFailed](#moveToFailed)

@@ -119,3 +121,3 @@ - [Events](#events)

`drainDelay`: A timeout for when the queue is in `drained` state (empty waiting for jobs). It is used when calling `queue.getNextJob()`, which will pass itto `.brpoplpush` on the Redis client.
`drainDelay`: A timeout for when the queue is in `drained` state (empty waiting for jobs). It is used when calling `queue.getNextJob()`, which will pass it to `.brpoplpush` on the Redis client.

@@ -699,3 +701,23 @@ ```js

### Job#moveToCompleted
```ts
moveToCompleted(returnValue, ignoreLock): Promise<string[Jobdata, JobId] | null>
```
Moves a job to the `completed` queue. Pulls a job from 'waiting' to 'active' and returns a tuple containing the next jobs data and id. If no job is in the `waiting` queue, returns null.
---
### Job#moveToFailed
```ts
moveToFailed(errorInfo, ignoreLock): Promise<string[Jobdata, JobId] | null>
```
Moves a job to the `failed` queue. Pulls a job from 'waiting' to 'active' and returns a tuple containing the next jobs data and id. If no job is in the `waiting` queue, returns null.
---
Events

@@ -711,2 +733,6 @@ ------

.on('waiting', function(jobId){
// A Job is waiting to be processed as soon as a worker is idling.
});
.on('active', function(job, jobPromise){

@@ -713,0 +739,0 @@ // A job has started. You can use `jobPromise.cancel()`` to abort it.

@@ -19,13 +19,2 @@ /*eslint-env node */

it('should raise an expection if invalid processor', function() {
return pool.retain('foobar').then(
function() {
throw new Error('Should raise an exception');
},
function(err) {
expect(err).to.be.instanceOf(Error);
}
);
});
it('should return same child if free', function() {

@@ -32,0 +21,0 @@ var processor = __dirname + '/fixtures/fixture_processor_bar.js';

@@ -419,18 +419,21 @@ /*eslint-env node */

describe('.moveToCompleted', function() {
it('marks the job as completed', function() {
return Job.create(queue, { foo: 'bar' }).then(function(job) {
return job
.isCompleted()
.then(function(isCompleted) {
expect(isCompleted).to.be(false);
})
.then(function() {
return job.moveToCompleted('succeeded', true);
})
.then(function(/*moved*/) {
return job.isCompleted().then(function(isCompleted) {
expect(isCompleted).to.be(true);
expect(job.returnvalue).to.be('succeeded');
it('marks the job as completed and returns new job', function() {
return Job.create(queue, { foo: 'bar' }).then(function(job1) {
return Job.create(queue, { foo: 'bar' }).then(function(job2) {
return job2
.isCompleted()
.then(function(isCompleted) {
expect(isCompleted).to.be(false);
})
.then(function() {
return job2.moveToCompleted('succeeded', true);
})
.then(function(job1Id) {
return job2.isCompleted().then(function(isCompleted) {
expect(isCompleted).to.be(true);
expect(job2.returnvalue).to.be('succeeded');
expect(job1Id[1]).to.be(job1.id);
});
});
});
});
});

@@ -437,0 +440,0 @@ });

@@ -337,3 +337,3 @@ /*eslint-env node */

it('should not re-add a repeatable job after it has been deleted', function() {
it('should not re-add a repeatable job after it has been removed', function() {
var _this = this;

@@ -564,2 +564,26 @@ var date = new Date('2017-02-07 9:24:00');

});
it.only('should emit a waiting event when adding a repeatable job to the waiting list', function(done) {
var _this = this;
var date = new Date('2017-02-07 9:24:00');
this.clock.tick(date.getTime());
var nextTick = 2 * ONE_SECOND + 500;
queue.on('waiting', function(jobId) {
expect(jobId).to.be.equal(
'repeat:93168b0ea97b55fb5a8325e8c66e4300:1486455842000'
);
done();
});
queue
.add('repeat', { foo: 'bar' }, { repeat: { cron: '*/2 * * * * *' } })
.then(function() {
_this.clock.tick(nextTick);
});
queue.process('repeat', function() {
console.error('hiasd');
});
});
});

@@ -244,3 +244,12 @@ /*eslint-env node */

it('should process and fail', function(done) {
it('should error if processor file is missing', function(done) {
try {
queue.process(__dirname + '/fixtures/missing_processor.js');
done(new Error('did not throw error'));
} catch (err) {
done();
}
});
it('should process and fail using callback', function(done) {
queue.process(__dirname + '/fixtures/fixture_processor_callback_fail.js');

@@ -247,0 +256,0 @@

Sorry, the diff of this file is not supported yet