Browse Source

refactored redis example store, added ttl function to caching.js

feature/specify-what-to-cache
Bryan Donovan 10 years ago
parent
commit
c2eac33895
  1. 19
      examples/redis_example/example.js
  2. 51
      examples/redis_example/redis_store.js
  3. 4
      lib/caching.js
  4. 22
      test/caching.unit.js

19
examples/redis_example/example.js

@ -3,6 +3,7 @@
// node examples/redis_example/example.js // node examples/redis_example/example.js
var util = require('util'); var util = require('util');
var assert = require('assert');
var cacheManager = require('../../'); var cacheManager = require('../../');
var redisStore = require('./redis_store'); var redisStore = require('./redis_store');
// Note: ttl is in seconds // Note: ttl is in seconds
@ -18,11 +19,17 @@ redisCache.set('foo', 'bar', {ttl: ttl}, function(err) {
if (err) { throw err; } if (err) { throw err; }
console.log("result fetched from cache: " + result); console.log("result fetched from cache: " + result);
// >> 'bar' // >> 'bar'
redisCache.ttl('foo', function(err, result) {
if (err) { throw err; }
assert.ok(result > 59 && result < 61);
redisCache.del('foo', function(err) { redisCache.del('foo', function(err) {
if (err) { throw err; } if (err) { throw err; }
}); });
}); });
}); });
});
// TTL defaults to what we passed into the caching function (100) // TTL defaults to what we passed into the caching function (100)
redisCache.set('foo-no-ttl', 'bar-no-ttl', function(err) { redisCache.set('foo-no-ttl', 'bar-no-ttl', function(err) {
@ -32,11 +39,17 @@ redisCache.set('foo-no-ttl', 'bar-no-ttl', function(err) {
if (err) { throw err; } if (err) { throw err; }
console.log("result fetched from cache: " + result); console.log("result fetched from cache: " + result);
// >> 'bar' // >> 'bar'
redisCache.ttl('foo-no-ttl', function(err, result) {
if (err) { throw err; }
assert.ok(result > 99 && result < 101);
redisCache.del('foo-no-ttl', function(err) { redisCache.del('foo-no-ttl', function(err) {
if (err) { throw err; } if (err) { throw err; }
}); });
}); });
}); });
});
// Calls Redis 'set' instead of 'setex' // Calls Redis 'set' instead of 'setex'
redisCache.set('foo-zero-ttl', 'bar-zero-ttl', {ttl: 0}, function(err) { redisCache.set('foo-zero-ttl', 'bar-zero-ttl', {ttl: 0}, function(err) {
@ -46,11 +59,17 @@ redisCache.set('foo-zero-ttl', 'bar-zero-ttl', {ttl: 0}, function(err) {
if (err) { throw err; } if (err) { throw err; }
console.log("result fetched from cache: " + result); console.log("result fetched from cache: " + result);
// >> 'bar' // >> 'bar'
redisCache.ttl('foo-zero-ttl', function(err, result) {
if (err) { throw err; }
assert.ok(result < 0);
redisCache.del('foo-zero-ttl', function(err) { redisCache.del('foo-zero-ttl', function(err) {
if (err) { throw err; } if (err) { throw err; }
}); });
}); });
}); });
});
var userId = 123; var userId = 123;

51
examples/redis_example/redis_store.js

@ -33,6 +33,22 @@ function redisStore(args) {
}); });
} }
function handleResponse(conn, cb, opts) {
opts = opts || {};
return function(err, result) {
pool.release(conn);
if (err) { return cb(err); }
if (opts.parse) {
result = JSON.parse(result);
}
cb(null, result);
};
}
self.get = function(key, options, cb) { self.get = function(key, options, cb) {
if (typeof options === 'function') { if (typeof options === 'function') {
cb = options; cb = options;
@ -40,12 +56,7 @@ function redisStore(args) {
connect(function(err, conn) { connect(function(err, conn) {
if (err) { return cb(err); } if (err) { return cb(err); }
conn.get(key, handleResponse(conn, cb, {parse: true}));
conn.get(key, function(err, result) {
pool.release(conn);
if (err) { return cb(err); }
cb(null, JSON.parse(result));
});
}); });
}; };
@ -60,17 +71,12 @@ function redisStore(args) {
connect(function(err, conn) { connect(function(err, conn) {
if (err) { return cb(err); } if (err) { return cb(err); }
var val = JSON.stringify(value);
if (ttl) { if (ttl) {
conn.setex(key, ttl, JSON.stringify(value), function(err, result) { conn.setex(key, ttl, val, handleResponse(conn, cb));
pool.release(conn);
cb(err, result);
});
} else { } else {
conn.set(key, JSON.stringify(value), function(err, result) { conn.set(key, val, handleResponse(conn, cb));
pool.release(conn);
cb(err, result);
});
} }
}); });
}; };
@ -78,11 +84,14 @@ function redisStore(args) {
self.del = function(key, cb) { self.del = function(key, cb) {
connect(function(err, conn) { connect(function(err, conn) {
if (err) { return cb(err); } if (err) { return cb(err); }
conn.del(key, handleResponse(conn, cb));
conn.del(key, function(err, result) {
pool.release(conn);
cb(err, result);
}); });
};
self.ttl = function(key, cb) {
connect(function(err, conn) {
if (err) { return cb(err); }
conn.ttl(key, handleResponse(conn, cb));
}); });
}; };
@ -94,11 +103,7 @@ function redisStore(args) {
connect(function(err, conn) { connect(function(err, conn) {
if (err) { return cb(err); } if (err) { return cb(err); }
conn.keys(pattern, handleResponse(conn, cb));
conn.keys(pattern, function(err, result) {
pool.release(conn);
cb(err, result);
});
}); });
}; };

4
lib/caching.js

@ -95,6 +95,10 @@ var caching = function(args) {
self.keys = self.store.keys.bind(self.store); self.keys = self.store.keys.bind(self.store);
} }
if (typeof self.store.ttl === 'function') {
self.ttl = self.store.ttl.bind(self.store);
}
return self; return self;
}; };

22
test/caching.unit.js

@ -194,6 +194,28 @@ describe("caching", function() {
}); });
}); });
describe("ttl()", function() {
var fakeStore;
beforeEach(function() {
fakeStore = {
get: function() {},
set: function() {},
del: function() {},
ttl: function() {}
};
sinon.stub(fakeStore, 'ttl');
cache = caching({store: fakeStore});
});
it("passes the params to the underlying store's ttl() method", function() {
cache.ttl('foo');
assert.ok(fakeStore.ttl.calledWith('foo'));
});
});
describe("keys()", function() { describe("keys()", function() {
var keyCount; var keyCount;
var savedKeys = []; var savedKeys = [];

Loading…
Cancel
Save