Skip to content

Commit

Permalink
Support redis 2.4 info command
Browse files Browse the repository at this point in the history
  • Loading branch information
Ruben Bridgewater committed Mar 16, 2016
1 parent eb9500b commit 359820c
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 8 deletions.
8 changes: 4 additions & 4 deletions lib/individualCommands.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,14 +37,14 @@ RedisClient.prototype.select = RedisClient.prototype.SELECT = function select (d
RedisClient.prototype.info = RedisClient.prototype.INFO = function info (section, callback) {
var self = this;
var ready = this.ready;
var args = [];
if (typeof section === 'function') {
callback = section;
section = 'default';
} else if (section === undefined) {
section = 'default';
} else if (section !== undefined) {
args = Array.isArray(section) ? section : [section];
}
this.ready = ready || this.offline_queue.length === 0; // keep the execution order intakt
var tmp = this.send_command('info', [section], function (err, res) {
var tmp = this.send_command('info', args, function (err, res) {
if (res) {
var obj = {};
var lines = res.toString().split('\r\n');
Expand Down
20 changes: 16 additions & 4 deletions test/commands/info.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,14 @@ describe("The 'info' method", function () {
describe("using " + parser + " and " + ip, function () {
var client;

before(function (done) {
beforeEach(function (done) {
client = redis.createClient.apply(null, args);
client.once("ready", function () {
client.flushall(done);
});
});

after(function () {
afterEach(function () {
client.end(true);
});

Expand All @@ -41,9 +41,10 @@ describe("The 'info' method", function () {
client.set('foo', 'bar');
client.info('keyspace');
client.select(2, function () {
assert.strictEqual(Object.keys(client.server_info).length, 3, 'Key length should be three');
assert(typeof client.server_info.db2 === 'object', 'db2 keyspace should be an object');
assert.strictEqual(Object.keys(client.server_info).length, 2, 'Key length should be three');
assert.strictEqual(typeof client.server_info.db0, 'object', 'db0 keyspace should be an object');
});
client.info(['keyspace']);
client.set('foo', 'bar');
client.info('all', function (err, res) {
assert(Object.keys(client.server_info).length > 3, 'Key length should be way above three');
Expand All @@ -53,6 +54,17 @@ describe("The 'info' method", function () {
});
});

it('check redis v.2.4 support', function (done) {
var end = helper.callFuncAfter(done, 2);
client.send_command = function (command, args, callback) {
assert.strictEqual(args.length, 0);
assert.strictEqual(command, 'info');
end();
};
client.info();
client.info(function () {});
});

it("emit error after a failure", function (done) {
client.info();
client.once('error', function (err) {
Expand Down

0 comments on commit 359820c

Please sign in to comment.