WME/aufgabe5/node_modules/csvtojson/.ts-node/46be5da2105bfdf13e8db086405c89f751746b6e7f1dbb5a5600bad96af1b73b/5b7b6cc115cc8559849a34561c82531410ecb53ccdbe486e410336329db2fdb4.js

131 lines
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":";;AAAA,uCAAyE;AACzE,yCAAwC;AACxC,IAAM,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;AAEjC,QAAQ,CAAC,iBAAiB,EAAE;IAC1B,IAAM,YAAY,GAAG,UAAC,GAAG,EAAE,GAAqC;QAC9D,OAAO,mBAAQ,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC;YAC7C,IAAI,EAAE;gBACJ,UAAU,EAAE;oBACV,SAAS,EAAE,GAAG,CAAC,SAAS;iBACzB;aACF;SACF,EAAE,GAAG,CAAC,CAAC;IACV,CAAC,CAAA;IAED,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAI,SAAS,GAAG,GAAG,CAAC;QACpB,IAAI,MAAM,GAAG,OAAO,CAAC;QACrB,IAAI,iBAAiB,GAAG,YAAY,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;QACjE,MAAM,CAAC,KAAK,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE;QACjE,IAAI,MAAM,GAAG,OAAO,CAAC;QACrB,IAAI,iBAAiB,GAAG,YAAY,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;QACpE,MAAM,CAAC,iBAAiB,KAAK,GAAG,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qFAAqF,EAAE;QACxF,IAAI,MAAM,GAAG,KAAK,CAAC;QACnB,IAAI,iBAAiB,GAAG,YAAY,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;QACpE,MAAM,CAAC,iBAAiB,KAAK,GAAG,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE;QACrD,IAAI,MAAM,GAAG,OAAO,CAAC;QACrB,IAAI,iBAAiB,GAAG,YAAY,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7E,MAAM,CAAC,iBAAiB,KAAK,GAAG,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE;IAClC,IAAM,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,qBAAS,EAAE,CAAC,CAAC;IAC/C,IAAM,IAAI,GAAG,UAAC,KAAe;QAC3B,OAAO,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC,CAAA;IACD,EAAE,CAAC,mCAAmC,EAAE;QACtC,IAAI,KAAK,GAAG;YACV,SAAS;YACT,2BAA2B;YAC3B,SAAS;SACV,CAAC;QACF,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE;QAC/B,IAAI,KAAK,GAAG;YACV,OAAO;YACP,eAAe;YACf,OAAO;YACP,kBAAkB;SACnB,CAAC;QACF,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAC7C,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE;QAC7C,IAAI,KAAK,GAAG;YACV,OAAO;YACP,eAAe;YACf,OAAO;SACR,CAAC;QACF,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,0BAA0B,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE;IAClC,IAAM,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,qBAAS,EAAE,CAAC,CAAC;IAC/C,IAAM,IAAI,GAAG,UAAC,GAAG;QACf,OAAO,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC,CAAA;IACD,EAAE,CAAC,gCAAgC,EAAE;QACnC,IAAI,GAAG,GAAG,+BAA+B,CAAC;QAC1C,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;QACrC,IAAI,GAAG,GAAG,iCAAiC,CAAC;QAC5C,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE;QAC/B,IAAI,GAAG,GAAG,6CAA6C,CAAC;QACxD,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC/B,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,sBAAsB,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,2BAA2B,EAAE;QAC9B,IAAM,IAAI,GAAG,UAAU,CAAC;QAExB,IAAM,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,qBAAS,CAAC;YAC1C,SAAS,EAAE,GAAG;YACd,KAAK,EAAE,GAAG;YACV,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;QACJ,IAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACjC,CAAC,CAAC,CAAA;IACF,EAAE,CAAC,qCAAqC,EAAE;QACxC,IAAM,IAAI,GAAG,yBAAyB,CAAC;QAEvC,IAAM,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,qBAAS,CAAC;YAC1C,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;QACJ,IAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,oBAAoB,CAAC,CAAC;IACnD,CAAC,CAAC,CAAA;IACF,EAAE,CAAC,gEAAgE,EAAE;QACnE,IAAM,IAAI,GAAG,uCAAuC,CAAC;QACrD,IAAM,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,qBAAS,CAAC;YAC1C,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;QACJ,IAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAC,eAAe,CAAC,CAAC;QAC3C,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAC,YAAY,CAAC,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAC,cAAc,CAAC,CAAC;IAE5C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAC","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"]}