UNPKG

d3

Version:

A small, free JavaScript library for manipulating documents based on data.

104 lines (98 loc) 3.49 kB
require("../env"); require("../../d3"); var vows = require("vows"), assert = require("assert"); var suite = vows.describe("d3.bisect"); suite.addBatch({ "bisectLeft": { topic: function() { return d3.bisectLeft; }, "finds the index of an exact match": function(bisect) { var array = [1, 2, 3]; assert.equal(bisect(array, 1), 0); assert.equal(bisect(array, 2), 1); assert.equal(bisect(array, 3), 2); }, "finds the index of the first match": function(bisect) { var array = [1, 2, 2, 3]; assert.equal(bisect(array, 1), 0); assert.equal(bisect(array, 2), 1); assert.equal(bisect(array, 3), 3); }, "finds the insertion point of a non-exact match": function(bisect) { var array = [1, 2, 3]; assert.equal(bisect(array, 0.5), 0); assert.equal(bisect(array, 1.5), 1); assert.equal(bisect(array, 2.5), 2); assert.equal(bisect(array, 3.5), 3); }, "observes the optional lower bound": function(bisect) { var array = [1, 2, 3, 4, 5]; assert.equal(bisect(array, 0, 2), 2); assert.equal(bisect(array, 1, 2), 2); assert.equal(bisect(array, 2, 2), 2); assert.equal(bisect(array, 3, 2), 2); assert.equal(bisect(array, 4, 2), 3); assert.equal(bisect(array, 5, 2), 4); assert.equal(bisect(array, 6, 2), 5); }, "observes the optional bounds": function(bisect) { var array = [1, 2, 3, 4, 5]; assert.equal(bisect(array, 0, 2, 3), 2); assert.equal(bisect(array, 1, 2, 3), 2); assert.equal(bisect(array, 2, 2, 3), 2); assert.equal(bisect(array, 3, 2, 3), 2); assert.equal(bisect(array, 4, 2, 3), 3); assert.equal(bisect(array, 5, 2, 3), 3); assert.equal(bisect(array, 6, 2, 3), 3); } } }); suite.addBatch({ "bisectRight": { topic: function() { return d3.bisectRight; }, "finds the index after an exact match": function(bisect) { var array = [1, 2, 3]; assert.equal(bisect(array, 1), 1); assert.equal(bisect(array, 2), 2); assert.equal(bisect(array, 3), 3); }, "finds the index after the last match": function(bisect) { var array = [1, 2, 2, 3]; assert.equal(bisect(array, 1), 1); assert.equal(bisect(array, 2), 3); assert.equal(bisect(array, 3), 4); }, "finds the insertion point of a non-exact match": function(bisect) { var array = [1, 2, 3]; assert.equal(bisect(array, 0.5), 0); assert.equal(bisect(array, 1.5), 1); assert.equal(bisect(array, 2.5), 2); assert.equal(bisect(array, 3.5), 3); }, "observes the optional lower bound": function(bisect) { var array = [1, 2, 3, 4, 5]; assert.equal(bisect(array, 0, 2), 2); assert.equal(bisect(array, 1, 2), 2); assert.equal(bisect(array, 2, 2), 2); assert.equal(bisect(array, 3, 2), 3); assert.equal(bisect(array, 4, 2), 4); assert.equal(bisect(array, 5, 2), 5); assert.equal(bisect(array, 6, 2), 5); }, "observes the optional bounds": function(bisect) { var array = [1, 2, 3, 4, 5]; assert.equal(bisect(array, 0, 2, 3), 2); assert.equal(bisect(array, 1, 2, 3), 2); assert.equal(bisect(array, 2, 2, 3), 2); assert.equal(bisect(array, 3, 2, 3), 3); assert.equal(bisect(array, 4, 2, 3), 3); assert.equal(bisect(array, 5, 2, 3), 3); assert.equal(bisect(array, 6, 2, 3), 3); } } }); suite.export(module);