require("../env"); require("../../d3"); var vows = require("vows"), assert = require("assert"); var suite = vows.describe("d3.min"); suite.addBatch({ "min": { topic: function() { return d3.min; }, "returns the least numeric value for numbers": function(min) { assert.equal(min([1]), 1); assert.equal(min([5, 1, 2, 3, 4]), 1); assert.equal(min([20, 3]), 3); assert.equal(min([3, 20]), 3); }, "returns the least lexicographic value for strings": function(min) { assert.equal(min(["c", "a", "b"]), "a"); assert.equal(min(["20", "3"]), "20"); assert.equal(min(["3", "20"]), "20"); }, "ignores null, undefined and NaN": function(min) { assert.equal(min([NaN, 1, 2, 3, 4, 5]), 1); assert.equal(min([1, 2, 3, 4, 5, NaN]), 1); assert.equal(min([10, null, 3, undefined, 5, NaN]), 3); }, "compares heterogenous types as numbers": function(min) { assert.strictEqual(min([20, "3"]), "3"); assert.strictEqual(min(["20", 3]), 3); assert.strictEqual(min([3, "20"]), 3); assert.strictEqual(min(["3", 20]), "3"); }, "returns undefined for empty array": function(min) { assert.isUndefined(min([])); assert.isUndefined(min([null])); assert.isUndefined(min([undefined])); assert.isUndefined(min([NaN])); assert.isUndefined(min([NaN, NaN])); }, "applies the optional accessor function": function(min) { assert.equal(d3.min([[1, 2, 3, 4, 5], [2, 4, 6, 8, 10]], function(d) { return d3.max(d); }), 5); assert.equal(d3.min([1, 2, 3, 4, 5], function(d, i) { return i; }), 0); } } }); suite.export(module);