Skip to content

Commit

Permalink
fix: support parallel script execution in pipelines
Browse files Browse the repository at this point in the history
  • Loading branch information
marcbachmann committed Mar 19, 2021
1 parent 5006247 commit fb80fae
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 3 deletions.
20 changes: 17 additions & 3 deletions lib/pipeline.ts
Original file line number Diff line number Diff line change
Expand Up @@ -313,12 +313,15 @@ Pipeline.prototype.exec = function (callback: CallbackFunction) {

const script = this._shaToScript[item.args[0]];

if (!script || this.redis._addedScriptHashes[script.sha]) {
if (
!script ||
this.redis._addedScriptHashes[script.sha] ||
scripts.includes(script)
) {
continue;
}

scripts.push(script);
this.redis._addedScriptHashes[script.sha] = true;
}

const _this = this;
Expand All @@ -330,7 +333,13 @@ Pipeline.prototype.exec = function (callback: CallbackFunction) {
if (this.isCluster) {
return pMap(scripts, (script) => _this.redis.script("load", script.lua), {
concurrency: 10,
}).then(execPipeline);
})
.then(function () {
for (let i = 0; i < scripts.length; i++) {
_this.redis._addedScriptHashes[scripts[i].sha] = true;
}
})
.then(execPipeline);
}

return this.redis
Expand All @@ -352,6 +361,11 @@ Pipeline.prototype.exec = function (callback: CallbackFunction) {
})
);
})
.then(function () {
for (let i = 0; i < scripts.length; i++) {
_this.redis._addedScriptHashes[scripts[i].sha] = true;
}
})
.then(execPipeline);

function execPipeline() {
Expand Down
22 changes: 22 additions & 0 deletions test/functional/pipeline.ts
Original file line number Diff line number Diff line change
Expand Up @@ -320,6 +320,28 @@ describe("pipeline", function () {
});
});
});

it("should support parallel script execution", function (done) {
const random = `${Math.random()}`;
const redis = new Redis();
redis.defineCommand("something", {
numberOfKeys: 0,
lua: `return "${random}"`,
});
Promise.all([
redis.multi([["something"]]).exec(),
redis.multi([["something"]]).exec(),
])
.then(([[first], [second]]) => {
expect(first[0]).to.equal(null);
expect(first[1]).to.equal(random);
expect(second[0]).to.equal(null);
expect(second[1]).to.equal(random);
redis.disconnect();
done();
})
.catch(done);
});
});

describe("#length", function () {
Expand Down

0 comments on commit fb80fae

Please sign in to comment.