diff options
author | Graeme Yeates <gyeates@clearpath.ai> | 2017-08-21 19:57:58 -0400 |
---|---|---|
committer | Graeme Yeates <gyeates@clearpath.ai> | 2017-08-21 19:57:58 -0400 |
commit | 139421571d26b458a44f452c46b48230c4277a7a (patch) | |
tree | 2d20c7fa6e056933fbfc86a8b16a66f5a03a9bcb /mocha_test/memoize.js | |
parent | fa206affed3a13261c4fb4b314a5bf0df8e50308 (diff) | |
download | async-1465.tar.gz |
#1465; don't memoize results that had an error1465
Diffstat (limited to 'mocha_test/memoize.js')
-rw-r--r-- | mocha_test/memoize.js | 28 |
1 files changed, 22 insertions, 6 deletions
diff --git a/mocha_test/memoize.js b/mocha_test/memoize.js index 39620dd..df800cf 100644 --- a/mocha_test/memoize.js +++ b/mocha_test/memoize.js @@ -100,9 +100,8 @@ describe("memoize", function() { var fn2 = async.unmemoize(fn); fn2(1, 2, function(err, result) { expect(result).to.equal(3); + done(); }); - - done(); }); it('error', function(done) { @@ -112,8 +111,26 @@ describe("memoize", function() { }; async.memoize(fn)(1, 2, function (err) { expect(err).to.equal(testerr); + done(); + }); + }); + + it('should not memoize result if error occurs', function(done) { + var testerr = new Error('test'); + var fn = function (arg1, arg2, callback) { + callback(testerr, arg1 + arg2); + }; + var memoized = async.memoize(fn); + memoized(1, 2, function (err) { + expect(err).to.equal(testerr); + testerr = null; + + memoized(5, 6, function (err, result) { + expect(err).to.equal(null); + expect(result).to.equal(11); + done(); + }); }); - done(); }); it('multiple calls', function(done) { @@ -134,10 +151,8 @@ describe("memoize", function() { }); it('custom hash function', function(done) { - var testerr = new Error('test'); - var fn = function (arg1, arg2, callback) { - callback(testerr, arg1 + arg2); + callback(null, arg1 + arg2); }; var fn2 = async.memoize(fn, function () { return 'custom hash'; @@ -205,4 +220,5 @@ describe("memoize", function() { done(); }); }); + }); |