-
Notifications
You must be signed in to change notification settings - Fork 5
/
bluebird-parallel.js
153 lines (125 loc) · 2.73 KB
/
bluebird-parallel.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
var global = {};
var lifter = function(nodefn) {
return function() {
var self = this;
var l = arguments.length;
var args = new Array(l + 1);
for (var i = 0; i < l; ++i) {
args[i] = arguments[i];
}
return new Promise(function(resolve, reject) {
args[l] = function(err, val) {
if (err) reject(err);
else resolve(val);
};
nodefn.apply(self, args);
});
};
};
function dummy(n) {
return function dummy_n() {
var cb = arguments[n - 1];
cb();
}
}
function fakemaker(dummy, wrap) {
var dummy_2 = dummy(2),
dummy_1 = dummy(1);
// a queryish object with all
// kinds of functions
function queryish() {
return {
execWithin: dummy_2,
exec: dummy_1,
get: dummy_1,
all: dummy_1,
};
}
global.uuid = { v1: function v1() {} };
global.userAccount = { };
global.account = { };
global.blobManager = {
create: function create() {
return {
put: dummy_2,
}
}
};
var cqQueryish = queryish();
global.self = {
byUuidOrPath: queryish,
createQuery: wrap(function createQuery(x, y, cb, ctx) {
cb.call(ctx, null, cqQueryish);
})
};
global.File = {
insert: queryish,
whereUpdate: queryish
};
global.FileVersion = {
insert: queryish
};
global.Version = {
createHash: function createHash(v) { return 1; },
insert: queryish
};
global.db = {
begin: function begin() {
return {
commit: dummy_1,
rollback: dummy_1,
};
}
};
}
function dummyP(n) {
return lifter(dummy(n));
}
function upload(stream, idOrPath, tag, done) {
var queries = new Array(global.parallelQueries);
var tx = global.db.begin();
for (var i = 0, len = queries.length; i < len; ++i) {
queries[i] = global.FileVersion.insert({index: i}).execWithin(tx);
}
Promise.all(queries).then(function() {
tx.commit();
done();
}, function(err) {
tx.rollback();
done(err);
});
}
function perf() {
var errs = 0;
var lastErr;
var fn = upload;
var start = Date.now();
var warmedUp = 0;
var n = 10000;
var times = n;
var tot = Math.min(350, times);
global.parallelQueries = 25;
for (var k = 0, kn = tot; k < kn; ++k)
fn(k, 'b', 'c', warmup);
var memMax; var memStart; var start;
function warmup() {
warmedUp++
if (warmedUp === tot) {
start = Date.now();
for (var k = 0, kn = n; k < kn; ++k)
fn(k, 'b', 'c', cb);
}
}
function cb(err) {
if (err && err.message !== 'intentional failure') {
++errs;
lastErr = err;
}
if (!--times) {
fn.end && fn.end();
console.log(`Bluebird-parallel: ${Date.now() - start} ms.`);
}
}
}
fakemaker(dummyP, lifter);
perf();