860 lines
25 KiB
860 lines
25 KiB
/* eslint max-lines: 0, id-length: 0, func-names: 0, handle-callback-err: 0, max-lines: 0, |
|
no-unused-vars: 0, max-nested-callbacks: 0, no-shadow: 0, max-len: 0 */ |
|
|
|
"use strict"; |
|
|
|
var memoize = require("../..") |
|
, nextTick = require("next-tick") |
|
, delay = require("timers-ext/delay") |
|
, Promise = require("plain-promise"); |
|
|
|
require("../../ext/async"); |
|
require("../../ext/promise"); |
|
|
|
module.exports = function () { |
|
return { |
|
Regular: { |
|
Sync: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
++i; |
|
return x + y; |
|
}; |
|
mfn = memoize(fn, { maxAge: 100 }); |
|
|
|
a(mfn(3, 7), 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
a(mfn(3, 7), 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
a(mfn(5, 8), 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
a(mfn(3, 7), 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
a(mfn(5, 8), 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
a(mfn(5, 8), 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
|
|
a(mfn(9, 1), 10, "Result: C"); |
|
a(i, 3, "Called: C"); |
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait After"); |
|
a(i, 4, "Called: Wait After"); |
|
a(mfn(5, 8), 13, "Result: Wait After B"); |
|
a(i, 5, "Called: Wait After B"); |
|
|
|
a(mfn(3, 7), 10, "Result: Wait After #2"); |
|
a(i, 5, "Called: Wait After #2"); |
|
a(mfn(5, 8), 13, "Result: Wait After B #2"); |
|
a(i, 5, "Called: Wait After B #2"); |
|
|
|
a(mfn(9, 1), 10, "Result: WiatC"); |
|
a(i, 5, "Called: Wait C"); |
|
d(); |
|
}, 70); |
|
}, 40); |
|
}, |
|
Promise: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
return new Promise(function (res) { |
|
++i; |
|
res(x + y); |
|
}); |
|
}; |
|
|
|
mfn = memoize(fn, { promise: true, maxAge: 100 }); |
|
|
|
mfn(3, 7).done(function (res) { a(res, 10, "Result #1"); }); |
|
mfn(5, 8).done(function (res) { a(res, 13, "Result #2"); }); |
|
mfn(3, 7).done(function (res) { a(res, 10, "Result #3"); }); |
|
mfn(3, 7).done(function (res) { a(res, 10, "Result #4"); }); |
|
mfn(5, 8).done(function (res) { a(res, 13, "Result #5"); }); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Called #2"); |
|
|
|
mfn(3, 7).done(function (res) { a(res, 10, "Again: Result #1"); }); |
|
mfn(5, 8).done(function (res) { a(res, 13, "Again: Result #2"); }); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Again Called #2"); |
|
|
|
mfn(3, 7).done(function (res) { a(res, 10, "Again: Result #1"); }); |
|
mfn(5, 8).done(function (res) { a(res, 13, "Again: Result #2"); }); |
|
|
|
nextTick(function () { |
|
a(i, 4, "Call After clear"); |
|
d(); |
|
}); |
|
}, 100); |
|
}, 20); |
|
}, |
|
Async: function (a, d) { |
|
var mfn, fn, u = {}, i = 0; |
|
fn = function (x, y, cb) { |
|
nextTick(function () { |
|
++i; |
|
cb(null, x + y); |
|
}); |
|
return u; |
|
}; |
|
|
|
mfn = memoize(fn, { async: true, maxAge: 100 }); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #1"); }), |
|
u, "Initial" |
|
); |
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #2"); }), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Result B #1"); |
|
}), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #3"); }), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Result B #2"); |
|
}), |
|
u, "Initial #3" |
|
); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Called #2"); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { |
|
a.deep([err, res], [null, 10], "Again: Result"); |
|
}), |
|
u, "Again: Initial" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Again B: Result"); |
|
}), |
|
u, "Again B: Initial" |
|
); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Again Called #2"); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { |
|
a.deep([err, res], [null, 10], "Again: Result"); |
|
}), |
|
u, "Again: Initial" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Again B: Result"); |
|
}), |
|
u, "Again B: Initial" |
|
); |
|
|
|
nextTick(function () { |
|
a(i, 4, "Call After clear"); |
|
d(); |
|
}); |
|
}, 100); |
|
}, 20); |
|
} |
|
}, |
|
Primitive: { |
|
Sync: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
++i; |
|
return x + y; |
|
}; |
|
mfn = memoize(fn, { primitive: true, maxAge: 100 }); |
|
|
|
a(mfn(3, 7), 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
a(mfn(3, 7), 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
a(mfn(5, 8), 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
a(mfn(3, 7), 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
a(mfn(5, 8), 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
a(mfn(5, 8), 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait After"); |
|
a(i, 3, "Called: Wait After"); |
|
a(mfn(5, 8), 13, "Result: Wait After B"); |
|
a(i, 4, "Called: Wait After B"); |
|
|
|
a(mfn(3, 7), 10, "Result: Wait After #2"); |
|
a(i, 4, "Called: Wait After #2"); |
|
a(mfn(5, 8), 13, "Result: Wait After B #2"); |
|
a(i, 4, "Called: Wait After B #2"); |
|
d(); |
|
}, 100); |
|
}, 20); |
|
}, |
|
Async: function (a, d) { |
|
var mfn, fn, u = {}, i = 0; |
|
fn = function (x, y, cb) { |
|
nextTick(function () { |
|
++i; |
|
cb(null, x + y); |
|
}); |
|
return u; |
|
}; |
|
|
|
mfn = memoize(fn, { async: true, primitive: true, maxAge: 100 }); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #1"); }), |
|
u, "Initial" |
|
); |
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #2"); }), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Result B #1"); |
|
}), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(3, 7, function (err, res) { a.deep([err, res], [null, 10], "Result #3"); }), |
|
u, "Initial #2" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Result B #2"); |
|
}), |
|
u, "Initial #3" |
|
); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Called #2"); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { |
|
a.deep([err, res], [null, 10], "Again: Result"); |
|
}), |
|
u, "Again: Initial" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Again B: Result"); |
|
}), |
|
u, "Again B: Initial" |
|
); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Again Called #2"); |
|
|
|
a( |
|
mfn(3, 7, function (err, res) { |
|
a.deep([err, res], [null, 10], "Again: Result"); |
|
}), |
|
u, "Again: Initial" |
|
); |
|
a( |
|
mfn(5, 8, function (err, res) { |
|
a.deep([err, res], [null, 13], "Again B: Result"); |
|
}), |
|
u, "Again B: Initial" |
|
); |
|
|
|
nextTick(function () { |
|
a(i, 4, "Call After clear"); |
|
d(); |
|
}); |
|
}, 100); |
|
}, 20); |
|
}, |
|
Promise: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y, cb) { |
|
return new Promise(function (res) { |
|
++i; |
|
res(x + y); |
|
}); |
|
}; |
|
|
|
mfn = memoize(fn, { promise: true, primitive: true, maxAge: 100 }); |
|
|
|
mfn(3, 7).done(function (res) { a.deep(res, 10, "Result #1"); }); |
|
mfn(3, 7).done(function (res) { a.deep(res, 10, "Result #2"); }); |
|
mfn(5, 8).done(function (res) { a.deep(res, 13, "Result B #1"); }); |
|
mfn(3, 7).done(function (res) { a.deep(res, 10, "Result #3"); }); |
|
mfn(5, 8).done(function (res) { a.deep(res, 13, "Result B #2"); }); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Called #2"); |
|
|
|
mfn(3, 7).done(function (res) { a.deep(res, 10, "Again: Result"); }); |
|
mfn(5, 8).done(function (res) { a.deep(res, 13, "Again B: Result"); }); |
|
|
|
setTimeout(function () { |
|
a(i, 2, "Again Called #2"); |
|
|
|
mfn(3, 7).done(function (res) { a.deep(res, 10, "Again: Result"); }); |
|
mfn(5, 8).done(function (res) { a.deep(res, 13, "Again B: Result"); }); |
|
|
|
nextTick(function () { |
|
a(i, 4, "Call After clear"); |
|
d(); |
|
}); |
|
}, 100); |
|
}, 20); |
|
} |
|
}, |
|
Refetch: { |
|
Default: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
++i; |
|
return x + y; |
|
}; |
|
mfn = memoize(fn, { maxAge: 600, preFetch: true }); |
|
|
|
a(mfn(3, 7), 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
a(mfn(3, 7), 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
a(mfn(5, 8), 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
a(mfn(3, 7), 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
a(mfn(5, 8), 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
a(mfn(5, 8), 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait After"); |
|
a(i, 2, "Called: Wait After"); |
|
a(mfn(5, 8), 13, "Result: Wait After B"); |
|
a(i, 2, "Called: Wait After B"); |
|
|
|
a(mfn(3, 7), 10, "Result: Wait After #2"); |
|
a(i, 2, "Called: Wait After #2"); |
|
a(mfn(5, 8), 13, "Result: Wait After B #2"); |
|
a(i, 2, "Called: Wait After B #2"); |
|
|
|
setTimeout(function () { |
|
a(i, 4, "Called: After Refetch: Before"); |
|
a(mfn(3, 7), 10, "Result: After Refetch"); |
|
a(i, 4, "Called: After Refetch: After"); |
|
a(mfn(5, 8), 13, "Result: After Refetch B"); |
|
a(i, 4, "Called: After Refetch B: After"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: After Refetch #2"); |
|
a(i, 4, "Called: After Refetch #2"); |
|
a(mfn(5, 8), 13, "Result: After Refetch #2 B"); |
|
a(i, 4, "Called: After Refetch #2 B"); |
|
|
|
a(mfn(3, 7), 10, "Result: After Refetch #3"); |
|
a(i, 4, "Called: After Refetch #3"); |
|
a(mfn(5, 8), 13, "Result: After Refetch #3 B"); |
|
a(i, 4, "Called: After Refetch #3 B"); |
|
d(); |
|
}, 200); |
|
}, 200); |
|
}, 200); |
|
}, 300); |
|
}, |
|
Async: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y, cb) { |
|
++i; |
|
setTimeout(function () { cb(null, x + y); }, 0); |
|
}; |
|
mfn = memoize(fn, { maxAge: 600, preFetch: true, async: true }); |
|
|
|
// 1.Start |
|
mfn(3, 7, function (err, result) { |
|
a(result, 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
mfn(3, 7, function (err, result) { |
|
a(result, 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
mfn(5, 8, function (err, result) { |
|
a(result, 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
mfn(3, 7, function (err, result) { |
|
a(result, 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
mfn(5, 8, function (err, result) { |
|
a(result, 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
// 2. Wait 300ms |
|
setTimeout(function () { |
|
// From cache, prefetch not triggered |
|
mfn(3, 7, function (err, result) { |
|
a(result, 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
mfn(5, 8, function (err, result) { |
|
a(result, 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
// Wait 200ms |
|
setTimeout(function () { |
|
// From cache, prefetch triggered |
|
mfn(3, 7, function (err, result) { |
|
a(result, 10, "Result: Wait After"); |
|
a(i, 2, "Called: Wait After"); |
|
mfn(5, 8, function (err, result) { |
|
a(result, 13, "Result: Wait After B"); |
|
a(i, 3, "Called: Wait After B"); |
|
mfn(3, 7, function (err, result) { |
|
a( |
|
result, 10, |
|
"Result: Wait After #2" |
|
); |
|
a(i, 4, "Called: Wait After #2"); |
|
mfn(5, 8, function (err, result) { |
|
a( |
|
result, 13, |
|
"Result: Wait After B #2" |
|
); |
|
a( |
|
i, 4, |
|
"Called: Wait After B #2" |
|
); |
|
// Wait 200ms |
|
setTimeout(function () { |
|
// From cache, prefetch not triggered |
|
a( |
|
i, 4, |
|
"Called: After Refetch: Before" |
|
); |
|
mfn(3, 7, function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, 10, |
|
"Result: After Refetch" |
|
); |
|
a( |
|
i, 4, |
|
"Called: After Refetch: After" |
|
); |
|
mfn(5, 8, function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, 13, |
|
"Result: After Refetch B" |
|
); |
|
a( |
|
i, 4, |
|
"Called: After Refetch B: After" |
|
); |
|
// Wait 250ms |
|
setTimeout( |
|
function () { |
|
// From cache, prefetch triggered |
|
mfn( |
|
3, |
|
7, |
|
function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, |
|
10, |
|
"Result: After Refetch #2" |
|
); |
|
a( |
|
i, |
|
4, |
|
"Called: After Refetch #2" |
|
); |
|
mfn( |
|
5, |
|
8, |
|
function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, |
|
13, |
|
"Result: After Refetch #2 B" |
|
); |
|
a( |
|
i, |
|
5, |
|
"Called: After Refetch #2 B" |
|
); |
|
mfn( |
|
3, |
|
7, |
|
function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, |
|
10, |
|
"Result: After Refetch #3" |
|
); |
|
a( |
|
i, |
|
6, |
|
"Called: After Refetch #3" |
|
); |
|
mfn( |
|
5, |
|
8, |
|
function ( |
|
err, |
|
result |
|
) { |
|
a( |
|
result, |
|
13, |
|
"Result: After Refetch #3 B" |
|
); |
|
a( |
|
i, |
|
6, |
|
"Called: After Refetch #3 B" |
|
); |
|
d(); |
|
} |
|
); |
|
} |
|
); |
|
} |
|
); |
|
} |
|
); |
|
}, |
|
250 |
|
); |
|
}); |
|
}); |
|
}, 200); |
|
}); |
|
}); |
|
}); |
|
}); |
|
}, 200); |
|
}); |
|
}); |
|
}, 300); |
|
}); |
|
}); |
|
}); |
|
}); |
|
}); |
|
}, |
|
Promise: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
++i; |
|
return new Promise(function (res) { res(x + y); }); |
|
}; |
|
mfn = memoize(fn, { maxAge: 1200, preFetch: true, promise: true }); |
|
|
|
mfn(3, 7).done(function (result) { |
|
a(result, 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
mfn(3, 7).done(function (result) { |
|
a(result, 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
mfn(5, 8).done(function (result) { |
|
a(result, 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
mfn(3, 7).done(function (result) { |
|
a(result, 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
mfn(5, 8).done(function (result) { |
|
a(result, 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
// 600 |
|
setTimeout(function () { |
|
mfn(3, 7).done(function (result) { |
|
a(result, 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
mfn(5, 8).done(function (result) { |
|
a(result, 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
// 400 |
|
setTimeout(function () { |
|
mfn(3, 7).done( |
|
// 0 |
|
delay(function (result) { |
|
a(result, 10, "Result: Wait After"); |
|
a(i, 3, "Called: Wait After"); |
|
mfn(5, 8).done( |
|
// 0 |
|
delay(function (result) { |
|
a( |
|
result, 13, |
|
"Result: Wait After B" |
|
); |
|
a(i, 4, "Called: Wait After B"); |
|
mfn(3, 7).done( |
|
// next tick |
|
delay(function (result) { |
|
a( |
|
result, 10, |
|
"Result: Wait After #2" |
|
); |
|
a( |
|
i, 4, |
|
"Called: Wait After #2" |
|
); |
|
mfn(5, 8).done( |
|
function (result) { |
|
a( |
|
result, 13, |
|
"Result: Wait After B #2" |
|
); |
|
a( |
|
i, 4, |
|
"Called: Wait After B #2" |
|
); |
|
// 400 |
|
setTimeout( |
|
function () { |
|
a( |
|
i, |
|
4, |
|
"Called: After Refetch: Before" |
|
); |
|
mfn( |
|
3, 7 |
|
).done( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
10, |
|
"Result: After Refetch" |
|
); |
|
a( |
|
i, |
|
4, |
|
"Called: After Refetch: After" |
|
); |
|
mfn( |
|
5, |
|
8 |
|
).done( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
13, |
|
"Result: After Refetch B" |
|
); |
|
a( |
|
i, |
|
4, |
|
"Called: After Refetch B: After" |
|
); |
|
// 400 |
|
setTimeout( |
|
function () { |
|
mfn( |
|
3, |
|
7 |
|
).done( |
|
// 0 |
|
delay( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
10, |
|
"Result: After Refetch #2" |
|
); |
|
a( |
|
i, |
|
5, |
|
"Called: After Refetch #2" |
|
); |
|
mfn( |
|
5, |
|
8 |
|
).done( |
|
// 0 |
|
delay( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
13, |
|
"Result: After Refetch #2 B" |
|
); |
|
a( |
|
i, |
|
6, |
|
"Called: After Refetch #2 B" |
|
); |
|
mfn( |
|
3, |
|
7 |
|
).done( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
10, |
|
"Result: After Refetch #3" |
|
); |
|
a( |
|
i, |
|
6, |
|
"Called: After Refetch #3" |
|
); |
|
mfn( |
|
5, |
|
8 |
|
).done( |
|
function ( |
|
result |
|
) { |
|
a( |
|
result, |
|
13, |
|
"Result: After Refetch #3 B" |
|
); |
|
a( |
|
i, |
|
6, |
|
"Called: After Refetch #3 B" |
|
); |
|
d(); |
|
} |
|
); |
|
} |
|
); |
|
}, |
|
0 |
|
) |
|
); |
|
}, |
|
0 |
|
) |
|
); |
|
}, |
|
400 |
|
); |
|
} |
|
); |
|
} |
|
); |
|
}, |
|
400 |
|
); |
|
} |
|
); |
|
}) |
|
); |
|
}, 0) |
|
); |
|
}, 0) |
|
); |
|
}, 400); |
|
}); |
|
}); |
|
}, 600); |
|
}); |
|
}); |
|
}); |
|
}); |
|
}); |
|
}, |
|
Custom: function (a, d) { |
|
var mfn, fn, i = 0; |
|
fn = function (x, y) { |
|
++i; |
|
return x + y; |
|
}; |
|
mfn = memoize(fn, { maxAge: 6000, preFetch: 1 / 6 }); |
|
a(mfn(3, 7), 10, "Result #1"); |
|
a(i, 1, "Called #1"); |
|
a(mfn(3, 7), 10, "Result #2"); |
|
a(i, 1, "Called #2"); |
|
a(mfn(5, 8), 13, "Result B #1"); |
|
a(i, 2, "Called B #1"); |
|
a(mfn(3, 7), 10, "Result #3"); |
|
a(i, 2, "Called #3"); |
|
a(mfn(5, 8), 13, "Result B #2"); |
|
a(i, 2, "Called B #2"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait"); |
|
a(i, 2, "Called: Wait"); |
|
a(mfn(5, 8), 13, "Result: Wait B"); |
|
a(i, 2, "Called: Wait B"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: Wait After"); |
|
a(i, 2, "Called: Wait After"); |
|
a(mfn(5, 8), 13, "Result: Wait After B"); |
|
a(i, 2, "Called: Wait After B"); |
|
|
|
a(mfn(3, 7), 10, "Result: Wait After #2"); |
|
a(i, 2, "Called: Wait After #2"); |
|
a(mfn(5, 8), 13, "Result: Wait After B #2"); |
|
a(i, 2, "Called: Wait After B #2"); |
|
|
|
setTimeout(function () { |
|
a(i, 4, "Called: After Refetch: Before"); |
|
a(mfn(3, 7), 10, "Result: After Refetch"); |
|
a(i, 4, "Called: After Refetch: After"); |
|
a(mfn(5, 8), 13, "Result: After Refetch B"); |
|
a(i, 4, "Called: After Refetch B: After"); |
|
|
|
setTimeout(function () { |
|
a(mfn(3, 7), 10, "Result: After Refetch #2"); |
|
a(i, 4, "Called: After Refetch #2"); |
|
a(mfn(5, 8), 13, "Result: After Refetch #2 B"); |
|
a(i, 4, "Called: After Refetch #2 B"); |
|
|
|
a(mfn(3, 7), 10, "Result: After Refetch #3"); |
|
a(i, 4, "Called: After Refetch #3"); |
|
a(mfn(5, 8), 13, "Result: After Refetch #3 B"); |
|
a(i, 4, "Called: After Refetch #3 B"); |
|
d(); |
|
}, 2000); |
|
}, 3000); |
|
}, 1000); |
|
}, 4500); |
|
} |
|
} |
|
}; |
|
};
|
|
|