d3/test/scale/identity-test.js

164 строки
6.7 KiB
JavaScript

var vows = require("vows"),
load = require("../load"),
assert = require("../assert");
var suite = vows.describe("d3.scale.identity");
suite.addBatch({
"identity": {
topic: load("scale/identity").expression("d3.scale.identity").document(),
"domain and range": {
"are identical": function(identity) {
var x = identity();
assert.strictEqual(x.domain, x.range);
assert.strictEqual(x.domain(), x.range());
var x = identity().domain([-10, 0, 100]);
assert.deepEqual(x.range(), [-10, 0, 100]);
var x = identity().range([-10, 0, 100]);
assert.deepEqual(x.domain(), [-10, 0, 100]);
},
"default to [0, 1]": function(identity) {
var x = identity();
assert.deepEqual(x.domain(), [0, 1]);
assert.deepEqual(x.range(), [0, 1]);
assert.strictEqual(x(.5), .5);
},
"coerce values to numbers": function(identity) {
var x = identity().domain([new Date(1990, 0, 1), new Date(1991, 0, 1)]);
assert.typeOf(x.domain()[0], "number");
assert.typeOf(x.domain()[1], "number");
assert.strictEqual(x.domain()[0], +new Date(1990, 0, 1));
assert.strictEqual(x.domain()[1], +new Date(1991, 0, 1));
assert.typeOf(x(new Date(1989, 09, 20)), "number");
assert.strictEqual(x(new Date(1989, 09, 20)), +new Date(1989, 09, 20));
var x = identity().domain(["0", "1"]);
assert.typeOf(x.domain()[0], "number");
assert.typeOf(x.domain()[1], "number");
assert.strictEqual(x(.5), .5);
var x = identity().domain([new Number(0), new Number(1)]);
assert.typeOf(x.domain()[0], "number");
assert.typeOf(x.domain()[1], "number");
assert.strictEqual(x(.5), .5);
var x = identity().range([new Date(1990, 0, 1), new Date(1991, 0, 1)]);
assert.typeOf(x.range()[0], "number");
assert.typeOf(x.range()[1], "number");
assert.strictEqual(x.range()[0], +new Date(1990, 0, 1));
assert.strictEqual(x.range()[1], +new Date(1991, 0, 1));
assert.typeOf(x(new Date(1989, 09, 20)), "number");
assert.strictEqual(x(new Date(1989, 09, 20)), +new Date(1989, 09, 20));
var x = identity().range(["0", "1"]);
assert.typeOf(x.range()[0], "number");
assert.typeOf(x.range()[1], "number");
assert.strictEqual(x(.5), .5);
var x = identity().range([new Number(0), new Number(1)]);
assert.typeOf(x.range()[0], "number");
assert.typeOf(x.range()[1], "number");
assert.strictEqual(x(.5), .5);
},
"can specify a polyidentity domain and range": function(identity) {
var x = identity().domain([-10, 0, 100]);
assert.deepEqual(x.domain(), [-10, 0, 100]);
assert.strictEqual(x(-5), -5);
assert.strictEqual(x(50), 50);
assert.strictEqual(x(75), 75);
var x = identity().range([-10, 0, 100]);
assert.deepEqual(x.range(), [-10, 0, 100]);
assert.strictEqual(x(-5), -5);
assert.strictEqual(x(50), 50);
assert.strictEqual(x(75), 75);
},
"do not affect the identity function": function(identity) {
var x = identity().domain([Infinity, NaN]);
assert.strictEqual(x(42), 42);
assert.strictEqual(x.invert(-42), -42);
}
},
"is the identity function": function(identity) {
var x = identity().domain([1, 2]);
assert.strictEqual(x(.5), .5);
assert.strictEqual(x(1), 1);
assert.strictEqual(x(1.5), 1.5);
assert.strictEqual(x(2), 2);
assert.strictEqual(x(2.5), 2.5);
},
"coerces input to a number": function(identity) {
var x = identity().domain([1, 2]);
assert.strictEqual(x("2"), 2);
},
"invert": {
"is the identity function": function(identity) {
var x = identity().domain([1, 2]);
assert.strictEqual(x.invert(.5), .5);
assert.strictEqual(x.invert(1), 1);
assert.strictEqual(x.invert(1.5), 1.5);
assert.strictEqual(x.invert(2), 2);
assert.strictEqual(x.invert(2.5), 2.5);
},
"coerces range value to numbers": function(identity) {
var x = identity().range(["0", "2"]);
assert.strictEqual(x.invert("1"), 1);
var x = identity().range([new Date(1990, 0, 1), new Date(1991, 0, 1)]);
assert.strictEqual(x.invert(new Date(1990, 6, 2, 13)), +new Date(1990, 6, 2, 13));
var x = identity().range(["#000", "#fff"]);
assert.isNaN(x.invert("#999"));
},
"coerces input to a number": function(identity) {
var x = identity().domain([1, 2]);
assert.strictEqual(x.invert("2"), 2);
}
},
"ticks": {
"generates ticks of varying degree": function(identity) {
var x = identity();
assert.deepEqual(x.ticks(1).map(x.tickFormat(1)), [0, 1]);
assert.deepEqual(x.ticks(2).map(x.tickFormat(2)), [0, .5, 1]);
assert.deepEqual(x.ticks(5).map(x.tickFormat(5)), [0, .2, .4, .6, .8, 1]);
assert.deepEqual(x.ticks(10).map(x.tickFormat(10)), [0, .1, .2, .3, .4, .5, .6, .7, .8, .9, 1]);
var x = identity().domain([1, 0]);
assert.deepEqual(x.ticks(1).map(x.tickFormat(1)), [0, 1]);
assert.deepEqual(x.ticks(2).map(x.tickFormat(2)), [0, .5, 1]);
assert.deepEqual(x.ticks(5).map(x.tickFormat(5)), [0, .2, .4, .6, .8, 1]);
assert.deepEqual(x.ticks(10).map(x.tickFormat(10)), [0, .1, .2, .3, .4, .5, .6, .7, .8, .9, 1]);
},
"formats ticks with the appropriate precision": function(identity) {
var x = identity().domain([.123456789, 1.23456789]);
assert.strictEqual(x.tickFormat(1)(x.ticks(1)[0]), "1");
assert.strictEqual(x.tickFormat(2)(x.ticks(2)[0]), "0.5");
assert.strictEqual(x.tickFormat(4)(x.ticks(4)[0]), "0.2");
assert.strictEqual(x.tickFormat(8)(x.ticks(8)[0]), "0.2");
assert.strictEqual(x.tickFormat(16)(x.ticks(16)[0]), "0.2");
assert.strictEqual(x.tickFormat(32)(x.ticks(32)[0]), "0.15");
assert.strictEqual(x.tickFormat(64)(x.ticks(64)[0]), "0.14");
assert.strictEqual(x.tickFormat(128)(x.ticks(128)[0]), "0.13");
assert.strictEqual(x.tickFormat(256)(x.ticks(256)[0]), "0.125");
}
},
"copy": {
"changes to the domain or range are isolated": function(identity) {
var x = identity(), y = x.copy();
x.domain([1, 2]);
assert.deepEqual(y.domain(), [0, 1]);
y.domain([2, 3]);
assert.deepEqual(x.domain(), [1, 2]);
assert.deepEqual(y.domain(), [2, 3]);
var x = identity(), y = x.copy();
x.range([1, 2]);
assert.deepEqual(y.range(), [0, 1]);
y.range([2, 3]);
assert.deepEqual(x.range(), [1, 2]);
assert.deepEqual(y.range(), [2, 3]);
}
}
}
});
suite.export(module);