You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-04 15:02:09 +03:00
Added individual error classes Don't silently fail for commands without callback from now on General polishing (e.g. better error messages) Fix typos
106 lines
4.1 KiB
JavaScript
106 lines
4.1 KiB
JavaScript
'use strict';
|
|
|
|
var assert = require('assert');
|
|
var config = require('../lib/config');
|
|
var helper = require('../helper');
|
|
var redis = config.redis;
|
|
var uuid = require('uuid');
|
|
|
|
describe("The 'flushdb' method", function () {
|
|
|
|
helper.allTests(function (parser, ip, args) {
|
|
|
|
describe('using ' + parser + ' and ' + ip, function () {
|
|
var key, key2;
|
|
|
|
beforeEach(function () {
|
|
key = uuid.v4();
|
|
key2 = uuid.v4();
|
|
});
|
|
|
|
describe('when not connected', function () {
|
|
var client;
|
|
|
|
beforeEach(function (done) {
|
|
client = redis.createClient.apply(null, args);
|
|
client.once('ready', function () {
|
|
client.quit();
|
|
});
|
|
client.on('end', done);
|
|
});
|
|
|
|
it('reports an error', function (done) {
|
|
client.flushdb(function (err, res) {
|
|
assert(err.message.match(/The connection is already closed/));
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when connected', function () {
|
|
var client;
|
|
|
|
beforeEach(function (done) {
|
|
client = redis.createClient.apply(null, args);
|
|
client.once('ready', function () {
|
|
done();
|
|
});
|
|
});
|
|
|
|
afterEach(function () {
|
|
client.end(true);
|
|
});
|
|
|
|
describe('when there is data in Redis', function () {
|
|
|
|
beforeEach(function (done) {
|
|
client.mset(key, uuid.v4(), key2, uuid.v4(), helper.isNotError());
|
|
client.dbsize([], function (err, res) {
|
|
helper.isType.positiveNumber()(err, res);
|
|
assert.equal(res, 2, 'Two keys should have been inserted');
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('deletes all the keys', function (done) {
|
|
client.flushdb(function (err, res) {
|
|
assert.equal(res, 'OK');
|
|
client.mget(key, key2, function (err, res) {
|
|
assert.strictEqual(null, err, 'Unexpected error returned');
|
|
assert.strictEqual(true, Array.isArray(res), 'Results object should be an array.');
|
|
assert.strictEqual(2, res.length, 'Results array should have length 2.');
|
|
assert.strictEqual(null, res[0], 'Redis key should have been flushed.');
|
|
assert.strictEqual(null, res[1], 'Redis key should have been flushed.');
|
|
done(err);
|
|
});
|
|
});
|
|
});
|
|
|
|
it('results in a db size of zero', function (done) {
|
|
client.flushdb(function (err, res) {
|
|
client.dbsize([], function (err, res) {
|
|
helper.isNotError()(err, res);
|
|
helper.isType.number()(err, res);
|
|
assert.strictEqual(0, res, 'Flushing db should result in db size 0');
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
it('results in a db size of zero without a callback', function (done) {
|
|
client.flushdb();
|
|
setTimeout(function (err, res) {
|
|
client.dbsize(function (err, res) {
|
|
helper.isNotError()(err, res);
|
|
helper.isType.number()(err, res);
|
|
assert.strictEqual(0, res, 'Flushing db should result in db size 0');
|
|
done();
|
|
});
|
|
}, 25);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|