d3/test/dsv/csv-test.js

153 строки
4.9 KiB
JavaScript

require("../env");
var vows = require("vows"),
assert = require("assert");
var suite = vows.describe("d3.csv");
suite.addBatch({
"csv": {
topic: function() {
var cb = this.callback;
return d3.csv("examples/data/sample.csv", function(csv) {
cb(null, csv);
});
},
"invokes the callback with the parsed CSV": function(csv) {
assert.deepEqual(csv, [{"Hello":42,"World":"\"fish\""}]);
},
"overrides the mime type to text/csv": function(csv) {
assert.equal(XMLHttpRequest._last._info.mimeType, "text/csv");
},
"": {
topic: function() {
var cb = this.callback;
return d3.csv("//does/not/exist.csv", function(csv) {
cb(null, csv);
});
},
"invokes the callback with null when an error occurs": function(csv) {
assert.isNull(csv);
}
}
},
"parse": {
topic: function() {
return d3.csv.parse;
},
"returns an array of objects": function(parse) {
assert.deepEqual(parse("a,b,c\n1,2,3\n"), [{a: "1", b: "2", c: "3"}]);
},
"does not strip whitespace": function(parse) {
assert.deepEqual(parse("a,b,c\n 1, 2,3\n"), [{a: " 1", b: " 2", c: "3"}]);
},
"parses quoted values": function(parse) {
assert.deepEqual(parse("a,b,c\n\"1\",2,3"), [{a: "1", b: "2", c: "3"}]);
assert.deepEqual(parse("a,b,c\n\"1\",2,3\n"), [{a: "1", b: "2", c: "3"}]);
},
"parses quoted values with quotes": function(parse) {
assert.deepEqual(parse("a\n\"\"\"hello\"\"\""), [{a: "\"hello\""}]);
},
"parses quoted values with newlines": function(parse) {
assert.deepEqual(parse("a\n\"new\nline\""), [{a: "new\nline"}]);
assert.deepEqual(parse("a\n\"new\rline\""), [{a: "new\rline"}]);
assert.deepEqual(parse("a\n\"new\r\nline\""), [{a: "new\r\nline"}]);
},
"parses unix newlines": function(parse) {
assert.deepEqual(parse("a,b,c\n1,2,3\n4,5,\"6\"\n7,8,9"), [
{a: "1", b: "2", c: "3"},
{a: "4", b: "5", c: "6"},
{a: "7", b: "8", c: "9"}
]);
},
"parses mac newlines": function(parse) {
assert.deepEqual(parse("a,b,c\r1,2,3\r4,5,\"6\"\r7,8,9"), [
{a: "1", b: "2", c: "3"},
{a: "4", b: "5", c: "6"},
{a: "7", b: "8", c: "9"}
]);
},
"parses dos newlines": function(parse) {
assert.deepEqual(parse("a,b,c\r\n1,2,3\r\n4,5,\"6\"\r\n7,8,9"), [
{a: "1", b: "2", c: "3"},
{a: "4", b: "5", c: "6"},
{a: "7", b: "8", c: "9"}
]);
}
},
"parseRows": {
topic: function() {
return d3.csv.parseRows;
},
"returns an array of arrays": function(parse) {
assert.deepEqual(parse("a,b,c\n"), [["a", "b", "c"]]);
},
"parses quoted values": function(parse) {
assert.deepEqual(parse("\"1\",2,3\n"), [["1", "2", "3"]]);
assert.deepEqual(parse("\"hello\""), [["hello"]]);
},
"parses quoted values with quotes": function(parse) {
assert.deepEqual(parse("\"\"\"hello\"\"\""), [["\"hello\""]]);
},
"parses quoted values with newlines": function(parse) {
assert.deepEqual(parse("\"new\nline\""), [["new\nline"]]);
assert.deepEqual(parse("\"new\rline\""), [["new\rline"]]);
assert.deepEqual(parse("\"new\r\nline\""), [["new\r\nline"]]);
},
"parses unix newlines": function(parse) {
assert.deepEqual(parse("a,b,c\n1,2,3\n4,5,\"6\"\n7,8,9"), [
["a", "b", "c"],
["1", "2", "3"],
["4", "5", "6"],
["7", "8", "9"]
]);
},
"parses mac newlines": function(parse) {
assert.deepEqual(parse("a,b,c\r1,2,3\r4,5,\"6\"\r7,8,9"), [
["a", "b", "c"],
["1", "2", "3"],
["4", "5", "6"],
["7", "8", "9"]
]);
},
"parses dos newlines": function(parse) {
assert.deepEqual(parse("a,b,c\r\n1,2,3\r\n4,5,\"6\"\r\n7,8,9"), [
["a", "b", "c"],
["1", "2", "3"],
["4", "5", "6"],
["7", "8", "9"]
]);
}
},
"format": {
topic: function() {
return d3.csv.format;
},
"takes an array of arrays as input": function(format) {
assert.equal(format([["a", "b", "c"], ["1", "2", "3"]]), "a,b,c\n1,2,3");
},
"separates lines using unix newline": function(format) {
assert.equal(format([[], []]), "\n");
},
"does not strip whitespace": function(format) {
assert.equal(format([["a ", " b", "c"], ["1", "2", "3 "]]), "a , b,c\n1,2,3 ");
},
"does not quote simple values": function(format) {
assert.equal(format([["a"], [1]]), "a\n1");
},
"escapes double quotes": function(format) {
assert.equal(format([["\"fish\""]]), "\"\"\"fish\"\"\"");
},
"escapes unix newlines": function(format) {
assert.equal(format([["new\nline"]]), "\"new\nline\"");
},
"escapes commas": function(format) {
assert.equal(format([["oxford,comma"]]), "\"oxford,comma\"");
}
}
});
suite.export(module);