131 lines
No EOL
17 KiB
JavaScript
131 lines
No EOL
17 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
var rowSplit_1 = require("./rowSplit");
|
|
var Converter_1 = require("./Converter");
|
|
var assert = require("assert");
|
|
describe("Test delimiters", function () {
|
|
var getDelimiter = function (str, opt) {
|
|
return rowSplit_1.RowSplit.prototype["getDelimiter"].call({
|
|
conv: {
|
|
parseParam: {
|
|
delimiter: opt.delimiter
|
|
}
|
|
}
|
|
}, str);
|
|
};
|
|
it("should return the explicitly specified delimiter", function () {
|
|
var delimiter = ";";
|
|
var rowStr = "a;b;c";
|
|
var returnedDelimiter = getDelimiter(rowStr, { delimiter: ";" });
|
|
assert.equal(returnedDelimiter, delimiter);
|
|
});
|
|
it("should return the autodetected delimiter if 'auto' specified", function () {
|
|
var rowStr = "a;b;c";
|
|
var returnedDelimiter = getDelimiter(rowStr, { delimiter: "auto" });
|
|
assert(returnedDelimiter === ";");
|
|
});
|
|
it("should return the ',' delimiter if delimiter cannot be specified, in case of 'auto'", function () {
|
|
var rowStr = "abc";
|
|
var returnedDelimiter = getDelimiter(rowStr, { delimiter: "auto" });
|
|
assert(returnedDelimiter === ",");
|
|
});
|
|
it("should accetp an array with potential delimiters", function () {
|
|
var rowStr = "a$b$c";
|
|
var returnedDelimiter = getDelimiter(rowStr, { delimiter: [",", ";", "$"] });
|
|
assert(returnedDelimiter === '$');
|
|
});
|
|
});
|
|
describe("ParseMultiLine function", function () {
|
|
var rowSplit = new rowSplit_1.RowSplit(new Converter_1.Converter());
|
|
var func = function (lines) {
|
|
return rowSplit.parseMultiLines(lines);
|
|
};
|
|
it("should convert lines to csv lines", function () {
|
|
var lines = [
|
|
"a,b,c,d",
|
|
"hello,world,csvtojson,abc",
|
|
"1,2,3,4"
|
|
];
|
|
var res = func(lines);
|
|
assert.equal(res.rowsCells.length, 3);
|
|
assert.equal(res.partial, "");
|
|
});
|
|
it("should process line breaks", function () {
|
|
var lines = [
|
|
"a,b,c",
|
|
'15",hello,"ab',
|
|
"cde\"",
|
|
"\"b\"\"b\",cc,dd"
|
|
];
|
|
var res = func(lines);
|
|
assert.equal(res.rowsCells.length, 3);
|
|
assert.equal(res.rowsCells[1][0], "15\"");
|
|
assert.equal(res.rowsCells[1][2], "ab\ncde");
|
|
assert.equal(res.rowsCells[2][0], "b\"b");
|
|
assert.equal(res.partial, "");
|
|
});
|
|
it("should return partial if line not closed", function () {
|
|
var lines = [
|
|
"a,b,c",
|
|
'15",hello,"ab',
|
|
"d,e,f"
|
|
];
|
|
var res = func(lines);
|
|
assert.equal(res.rowsCells.length, 1);
|
|
assert.equal(res.partial, "15\",hello,\"ab\nd,e,f\n");
|
|
});
|
|
});
|
|
describe("RowSplit.parse function", function () {
|
|
var rowSplit = new rowSplit_1.RowSplit(new Converter_1.Converter());
|
|
var func = function (str) {
|
|
return rowSplit.parse(str);
|
|
};
|
|
it("should split complete csv line", function () {
|
|
var str = "hello,world,csvtojson,awesome";
|
|
var res = func(str);
|
|
assert.equal(res.cells.length, 4);
|
|
assert.equal(res.closed, true);
|
|
});
|
|
it("should split incomplete csv line", function () {
|
|
var str = "hello,world,\"csvtojson,awesome";
|
|
var res = func(str);
|
|
assert.equal(res.closed, false);
|
|
});
|
|
it("should allow multiple line", function () {
|
|
var str = "\"he\"llo\",world,\"csvtojson,a\"\nwesome\"";
|
|
var res = func(str);
|
|
assert.equal(res.closed, true);
|
|
assert.equal(res.cells[2], 'csvtojson,a"\nwesome');
|
|
});
|
|
it("should allow blank quotes", function () {
|
|
var data = "a|^^|^b^";
|
|
var rowSplit = new rowSplit_1.RowSplit(new Converter_1.Converter({
|
|
delimiter: '|',
|
|
quote: '^',
|
|
noheader: true
|
|
}));
|
|
var res = rowSplit.parse(data);
|
|
assert.equal(res.cells[1], "");
|
|
});
|
|
it("should allow blank quotes in quotes", function () {
|
|
var data = 'a,"hello,this,"", test"';
|
|
var rowSplit = new rowSplit_1.RowSplit(new Converter_1.Converter({
|
|
noheader: true
|
|
}));
|
|
var res = rowSplit.parse(data);
|
|
assert.equal(res.cells[1], 'hello,this,", test');
|
|
});
|
|
it("should smart detect if an initial quote is only part of value ", function () {
|
|
var data = '"Weight" (kg),Error code,"Height" (m)';
|
|
var rowSplit = new rowSplit_1.RowSplit(new Converter_1.Converter({
|
|
noheader: true
|
|
}));
|
|
var res = rowSplit.parse(data);
|
|
assert.equal(res.cells.length, 3);
|
|
assert(res.closed);
|
|
assert.equal(res.cells[0], '"Weight" (kg)');
|
|
assert.equal(res.cells[1], 'Error code');
|
|
assert.equal(res.cells[2], '"Height" (m)');
|
|
});
|
|
});
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/src/rowSplit.test.ts","sources":["/Users/kxiang/work/projects/csv2json/src/rowSplit.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { RowSplit, MultipleRowResult, RowSplitResult } from \"./rowSplit\";\nimport { Converter } from \"./Converter\";\nconst assert = require(\"assert\");\n\ndescribe(\"Test delimiters\", function () {\n  const getDelimiter = (str, opt: { delimiter: string | string[] }): string => {\n    return RowSplit.prototype[\"getDelimiter\"].call({\n      conv: {\n        parseParam: {\n          delimiter: opt.delimiter\n        }\n      }\n    }, str);\n  }\n\n  it(\"should return the explicitly specified delimiter\", function () {\n    var delimiter = \";\";\n    var rowStr = \"a;b;c\";\n    var returnedDelimiter = getDelimiter(rowStr, { delimiter: \";\" });\n    assert.equal(returnedDelimiter, delimiter);\n  });\n\n  it(\"should return the autodetected delimiter if 'auto' specified\", function () {\n    var rowStr = \"a;b;c\";\n    var returnedDelimiter = getDelimiter(rowStr, { delimiter: \"auto\" });\n    assert(returnedDelimiter === \";\");\n  });\n\n  it(\"should return the ',' delimiter if delimiter cannot be specified, in case of 'auto'\", function () {\n    var rowStr = \"abc\";\n    var returnedDelimiter = getDelimiter(rowStr, { delimiter: \"auto\" });\n    assert(returnedDelimiter === \",\");\n  });\n\n  it(\"should accetp an array with potential delimiters\", function () {\n    var rowStr = \"a$b$c\";\n    var returnedDelimiter = getDelimiter(rowStr, { delimiter: [\",\", \";\", \"$\"] });\n    assert(returnedDelimiter === '$');\n  });\n});\n\ndescribe(\"ParseMultiLine function\", function () {\n  const rowSplit = new RowSplit(new Converter());\n  const func = (lines: string[]): MultipleRowResult => {\n    return rowSplit.parseMultiLines(lines);\n  }\n  it(\"should convert lines to csv lines\", function () {\n    var lines = [\n      \"a,b,c,d\",\n      \"hello,world,csvtojson,abc\",\n      \"1,2,3,4\"\n    ];\n    var res = func(lines);\n    assert.equal(res.rowsCells.length, 3);\n    assert.equal(res.partial, \"\");\n  });\n\n  it(\"should process line breaks\", function () {\n    var lines = [\n      \"a,b,c\",\n      '15\",hello,\"ab',\n      \"cde\\\"\",\n      \"\\\"b\\\"\\\"b\\\",cc,dd\"\n    ];\n    var res = func(lines);\n    assert.equal(res.rowsCells.length, 3);\n    assert.equal(res.rowsCells[1][0], \"15\\\"\");\n    assert.equal(res.rowsCells[1][2], \"ab\\ncde\");\n    assert.equal(res.rowsCells[2][0], \"b\\\"b\");\n    assert.equal(res.partial, \"\");\n  });\n\n  it(\"should return partial if line not closed\", function () {\n    var lines = [\n      \"a,b,c\",\n      '15\",hello,\"ab',\n      \"d,e,f\"\n    ];\n    var res = func(lines);\n    assert.equal(res.rowsCells.length, 1);\n    assert.equal(res.partial, \"15\\\",hello,\\\"ab\\nd,e,f\\n\");\n  });\n});\n\ndescribe(\"RowSplit.parse function\", function () {\n  const rowSplit = new RowSplit(new Converter());\n  const func = (str): RowSplitResult => {\n    return rowSplit.parse(str);\n  }\n  it(\"should split complete csv line\", function () {\n    var str = \"hello,world,csvtojson,awesome\";\n    var res = func(str);\n    assert.equal(res.cells.length, 4);\n    assert.equal(res.closed, true);\n  });\n\n  it(\"should split incomplete csv line\", function () {\n    var str = \"hello,world,\\\"csvtojson,awesome\";\n    var res = func(str);\n    assert.equal(res.closed, false);\n  });\n\n  it(\"should allow multiple line\", function () {\n    var str = \"\\\"he\\\"llo\\\",world,\\\"csvtojson,a\\\"\\nwesome\\\"\";\n    var res = func(str);\n    assert.equal(res.closed, true);\n    assert.equal(res.cells[2], 'csvtojson,a\"\\nwesome');\n  });\n  it(\"should allow blank quotes\", () => {\n    const data = \"a|^^|^b^\";\n\n    const rowSplit = new RowSplit(new Converter({\n      delimiter: '|',\n      quote: '^',\n      noheader: true\n    }));\n    const res = rowSplit.parse(data);\n    assert.equal(res.cells[1], \"\");\n  })\n  it(\"should allow blank quotes in quotes\", () => {\n    const data = 'a,\"hello,this,\"\", test\"';\n\n    const rowSplit = new RowSplit(new Converter({\n      noheader: true\n    }));\n    const res = rowSplit.parse(data);\n    assert.equal(res.cells[1], 'hello,this,\", test');\n  })\n  it(\"should smart detect if an initial quote is only part of value \", () => {\n    const data = '\"Weight\" (kg),Error code,\"Height\" (m)';\n    const rowSplit = new RowSplit(new Converter({\n      noheader: true\n    }));\n    const res = rowSplit.parse(data);\n    assert.equal(res.cells.length, 3);\n    assert(res.closed);\n    assert.equal(res.cells[0],'\"Weight\" (kg)');\n    assert.equal(res.cells[1],'Error code');\n    assert.equal(res.cells[2],'\"Height\" (m)');\n    \n  })\n});\n"]}
|