|
1 require("../env"); |
|
2 require("../../d3"); |
|
3 |
|
4 var vows = require("vows"), |
|
5 assert = require("assert"); |
|
6 |
|
7 var suite = vows.describe("d3.median"); |
|
8 |
|
9 suite.addBatch({ |
|
10 "median": { |
|
11 topic: function() { |
|
12 return d3.median; |
|
13 }, |
|
14 "returns the median value for numbers": function(median) { |
|
15 assert.equal(median([1]), 1); |
|
16 assert.equal(median([5, 1, 2, 3, 4]), 3); |
|
17 assert.equal(median([20, 3]), 11.5); |
|
18 assert.equal(median([3, 20]), 11.5); |
|
19 }, |
|
20 "ignores null, undefined and NaN": function(median) { |
|
21 assert.equal(median([NaN, 1, 2, 3, 4, 5]), 3); |
|
22 assert.equal(median([1, 2, 3, 4, 5, NaN]), 3); |
|
23 assert.equal(median([10, null, 3, undefined, 5, NaN]), 5); |
|
24 }, |
|
25 "can handle large numbers without overflowing": function(median) { |
|
26 assert.equal(median([Number.MAX_VALUE, Number.MAX_VALUE]), Number.MAX_VALUE); |
|
27 assert.equal(median([-Number.MAX_VALUE, -Number.MAX_VALUE]), -Number.MAX_VALUE); |
|
28 }, |
|
29 "returns undefined for empty array": function(median) { |
|
30 assert.isUndefined(median([])); |
|
31 assert.isUndefined(median([null])); |
|
32 assert.isUndefined(median([undefined])); |
|
33 assert.isUndefined(median([NaN])); |
|
34 assert.isUndefined(median([NaN, NaN])); |
|
35 }, |
|
36 "applies the optional accessor function": function(median) { |
|
37 assert.equal(d3.median([[1, 2, 3, 4, 5], [2, 4, 6, 8, 10]], function(d) { return d3.median(d); }), 4.5); |
|
38 assert.equal(d3.median([1, 2, 3, 4, 5], function(d, i) { return i; }), 2); |
|
39 } |
|
40 } |
|
41 }); |
|
42 |
|
43 suite.export(module); |