"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"]}