cooperative
Version:
cooperative threading versions of map, filter, forEach, etc, suitable for big processing in single-threaded Node.js
56 lines (44 loc) • 1.44 kB
JavaScript
var filter = require('../filter')
var expect = require('chai').expect
var _ = require('underscore')
require('es6-promise').polyfill();
describe('filter', function () {
it('filters an array', function () {
var items = [1, 2, 3, 4]
return filter(items, function (n) { return n % 2 == 0 }).then(function (results) {
expect(results).to.eql([2, 4])
})
})
it('filters an array with promise predicate', function () {
var items = [1, 2, 3, 4]
return filter(items, function (n) { return Promise.resolve(n % 2 == 0) }).then(function (results) {
expect(results).to.eql([2, 4])
})
})
it('filters an empty array', function () {
var items = []
return filter(items, function (n) { return n % 2 == 0 }).then(function (results) {
expect(results).to.eql([])
})
})
it("doesn't hold up the main thread", function () {
var lastTime = Date.now()
var times = []
setInterval(function () {
var thisTime = Date.now()
var timeSinceLastInterval = thisTime - lastTime
times.push(timeSinceLastInterval)
lastTime = thisTime
}, 10)
var items = _.range(0, 50)
return filter(items, function (n) {
var startTime = Date.now()
while ((Date.now() - startTime) <= 5) {
}
return n % 2 == 0
}).then(function () {
expect(times.length).to.be.greaterThan(1)
expect(_.max(times)).to.be.lessThan(20)
})
})
})