You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-03 04:01:40 +03:00
Reduce timeouts if possible Extend timeouts if needed (windows tests need their time) Don't expose the redis socket to others than the owner Don't create the stunnel log
106 lines
4.2 KiB
JavaScript
106 lines
4.2 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 has already been 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);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|