2011-08-15 06:16:56 +04:00
|
|
|
var vows = require("vows"),
|
2013-03-15 00:29:24 +04:00
|
|
|
load = require("../load"),
|
2013-03-14 23:59:54 +04:00
|
|
|
assert = require("../assert"),
|
2012-02-29 23:27:30 +04:00
|
|
|
time = require("./time"),
|
|
|
|
local = time.local,
|
|
|
|
utc = time.utc;
|
2011-08-15 06:16:56 +04:00
|
|
|
|
|
|
|
var suite = vows.describe("d3.time.minute");
|
|
|
|
|
|
|
|
suite.addBatch({
|
|
|
|
"minute": {
|
2013-03-15 00:29:24 +04:00
|
|
|
topic: load("time/minute").expression("d3.time.minute"),
|
2012-02-19 09:23:17 +04:00
|
|
|
"defaults to floor": function(interval) {
|
|
|
|
assert.strictEqual(interval, interval.floor);
|
2011-08-15 06:16:56 +04:00
|
|
|
},
|
2012-02-19 09:23:17 +04:00
|
|
|
"floor": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.floor;
|
2011-08-15 06:16:56 +04:00
|
|
|
},
|
|
|
|
"returns minutes": function(floor) {
|
2012-02-19 09:23:17 +04:00
|
|
|
assert.deepEqual(floor(local(2010, 11, 31, 23, 59, 59)), local(2010, 11, 31, 23, 59));
|
|
|
|
assert.deepEqual(floor(local(2011, 00, 01, 00, 00, 00)), local(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(floor(local(2011, 00, 01, 00, 00, 59)), local(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(floor(local(2011, 00, 01, 00, 01, 00)), local(2011, 00, 01, 00, 01));
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"ceil": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.ceil;
|
|
|
|
},
|
|
|
|
"returns minutes": function(ceil) {
|
|
|
|
assert.deepEqual(ceil(local(2010, 11, 31, 23, 59, 59)), local(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(ceil(local(2011, 00, 01, 00, 00, 00)), local(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(ceil(local(2011, 00, 01, 00, 00, 59)), local(2011, 00, 01, 00, 01));
|
|
|
|
assert.deepEqual(ceil(local(2011, 00, 01, 00, 01, 00)), local(2011, 00, 01, 00, 01));
|
Add interval.range, and time.scale.nice.
This commit provides a standard interface for time intervals:
interval.floor(date)
interval.ceil(date)
interval.offset(date, k)
interval.range(start, stop, step)
All local-time intervals (such as d3.time.day) have a UTC-equivalent interval,
available as interval.utc (such as d3.time.day.utc).
Fixes #463. Note that for the time.scale, an interval function is required to
nice (such as d3.time.day). In the future, we might relax that to allow a count
of ticks, similar to the ticks method, but in that case we'd also need the
ability to floor to a given tick number (e.g., every other week) and likewise
for ceil. This seems like a reasonable first implementation.
2012-02-19 10:56:54 +04:00
|
|
|
}
|
|
|
|
},
|
2012-02-20 00:24:38 +04:00
|
|
|
"offset": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.offset;
|
|
|
|
},
|
|
|
|
"does not modify the passed-in date": function(offset) {
|
|
|
|
var date = local(2010, 11, 31, 23, 59, 59, 999);
|
|
|
|
offset(date, +1);
|
|
|
|
assert.deepEqual(date, local(2010, 11, 31, 23, 59, 59, 999));
|
|
|
|
},
|
|
|
|
"does not round the passed-in-date": function(offset) {
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59, 59, 999), +1), local(2011, 00, 01, 00, 00, 59, 999));
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59, 59, 456), -2), local(2010, 11, 31, 23, 57, 59, 456));
|
|
|
|
},
|
|
|
|
"allows negative offsets": function(offset) {
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 12), -1), local(2010, 11, 31, 23, 11));
|
|
|
|
assert.deepEqual(offset(local(2011, 00, 01, 00, 01), -2), local(2010, 11, 31, 23, 59));
|
|
|
|
assert.deepEqual(offset(local(2011, 00, 01, 00, 00), -1), local(2010, 11, 31, 23, 59));
|
|
|
|
},
|
|
|
|
"allows positive offsets": function(offset) {
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 11), +1), local(2010, 11, 31, 23, 12));
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59), +2), local(2011, 00, 01, 00, 01));
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59), +1), local(2011, 00, 01, 00, 00));
|
|
|
|
},
|
|
|
|
"allows zero offset": function(offset) {
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59, 59, 999), 0), local(2010, 11, 31, 23, 59, 59, 999));
|
|
|
|
assert.deepEqual(offset(local(2010, 11, 31, 23, 59, 58, 000), 0), local(2010, 11, 31, 23, 59, 58, 000));
|
|
|
|
}
|
|
|
|
},
|
Add interval.range, and time.scale.nice.
This commit provides a standard interface for time intervals:
interval.floor(date)
interval.ceil(date)
interval.offset(date, k)
interval.range(start, stop, step)
All local-time intervals (such as d3.time.day) have a UTC-equivalent interval,
available as interval.utc (such as d3.time.day.utc).
Fixes #463. Note that for the time.scale, an interval function is required to
nice (such as d3.time.day). In the future, we might relax that to allow a count
of ticks, similar to the ticks method, but in that case we'd also need the
ability to floor to a given tick number (e.g., every other week) and likewise
for ceil. This seems like a reasonable first implementation.
2012-02-19 10:56:54 +04:00
|
|
|
"UTC": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.utc;
|
|
|
|
},
|
|
|
|
"defaults to floor": function(interval) {
|
|
|
|
assert.strictEqual(interval, interval.floor);
|
|
|
|
},
|
|
|
|
"floor": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.floor;
|
|
|
|
},
|
|
|
|
"returns minutes": function(floor) {
|
|
|
|
assert.deepEqual(floor(utc(2010, 11, 31, 23, 59, 59)), utc(2010, 11, 31, 23, 59));
|
|
|
|
assert.deepEqual(floor(utc(2011, 00, 01, 00, 00, 00)), utc(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(floor(utc(2011, 00, 01, 00, 00, 59)), utc(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(floor(utc(2011, 00, 01, 00, 01, 00)), utc(2011, 00, 01, 00, 01));
|
|
|
|
}
|
2012-02-19 09:23:17 +04:00
|
|
|
},
|
Add interval.range, and time.scale.nice.
This commit provides a standard interface for time intervals:
interval.floor(date)
interval.ceil(date)
interval.offset(date, k)
interval.range(start, stop, step)
All local-time intervals (such as d3.time.day) have a UTC-equivalent interval,
available as interval.utc (such as d3.time.day.utc).
Fixes #463. Note that for the time.scale, an interval function is required to
nice (such as d3.time.day). In the future, we might relax that to allow a count
of ticks, similar to the ticks method, but in that case we'd also need the
ability to floor to a given tick number (e.g., every other week) and likewise
for ceil. This seems like a reasonable first implementation.
2012-02-19 10:56:54 +04:00
|
|
|
"ceil": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.ceil;
|
2012-02-19 09:23:17 +04:00
|
|
|
},
|
|
|
|
"returns minutes": function(ceil) {
|
|
|
|
assert.deepEqual(ceil(utc(2010, 11, 31, 23, 59, 59)), utc(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(ceil(utc(2011, 00, 01, 00, 00, 00)), utc(2011, 00, 01, 00, 00));
|
|
|
|
assert.deepEqual(ceil(utc(2011, 00, 01, 00, 00, 59)), utc(2011, 00, 01, 00, 01));
|
|
|
|
assert.deepEqual(ceil(utc(2011, 00, 01, 00, 01, 00)), utc(2011, 00, 01, 00, 01));
|
|
|
|
}
|
2012-02-20 00:24:38 +04:00
|
|
|
},
|
|
|
|
"offset": {
|
|
|
|
topic: function(interval) {
|
|
|
|
return interval.offset;
|
|
|
|
},
|
|
|
|
"does not modify the passed-in date": function(offset) {
|
|
|
|
var date = utc(2010, 11, 31, 23, 59, 59, 999);
|
|
|
|
offset(date, +1);
|
|
|
|
assert.deepEqual(date, utc(2010, 11, 31, 23, 59, 59, 999));
|
|
|
|
},
|
|
|
|
"does not round the passed-in-date": function(offset) {
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59, 59, 999), +1), utc(2011, 00, 01, 00, 00, 59, 999));
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59, 59, 456), -2), utc(2010, 11, 31, 23, 57, 59, 456));
|
|
|
|
},
|
|
|
|
"allows negative offsets": function(offset) {
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 12), -1), utc(2010, 11, 31, 23, 11));
|
|
|
|
assert.deepEqual(offset(utc(2011, 00, 01, 00, 01), -2), utc(2010, 11, 31, 23, 59));
|
|
|
|
assert.deepEqual(offset(utc(2011, 00, 01, 00, 00), -1), utc(2010, 11, 31, 23, 59));
|
|
|
|
},
|
|
|
|
"allows positive offsets": function(offset) {
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 11), +1), utc(2010, 11, 31, 23, 12));
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59), +2), utc(2011, 00, 01, 00, 01));
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59), +1), utc(2011, 00, 01, 00, 00));
|
|
|
|
},
|
|
|
|
"allows zero offset": function(offset) {
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59, 59, 999), 0), utc(2010, 11, 31, 23, 59, 59, 999));
|
|
|
|
assert.deepEqual(offset(utc(2010, 11, 31, 23, 59, 58, 000), 0), utc(2010, 11, 31, 23, 59, 58, 000));
|
|
|
|
}
|
2011-08-15 06:16:56 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
suite.export(module);
|