"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); var src_1 = __importDefault(require("../src")); var assert = require("assert"); var fs = require("fs"); var sinon_1 = require("sinon"); var sb = sinon_1.sandbox.create(); describe("testCSVConverter3", function () { afterEach(function () { sb.restore(); }); it("should parse large csv file with UTF-8 without spliting characters", function (done) { var testData = __dirname + "/data/large-utf8.csv"; var rs = fs.createReadStream(testData); var csvConverter = src_1.default({}); var count = 0; csvConverter.preRawData(function (csvRawData) { assert(csvRawData.charCodeAt(0) < 2000); return csvRawData; }); csvConverter.on("data", function () { count++; }); csvConverter.then(function () { assert(count === 5290); done(); }); rs.pipe(csvConverter); }); it("should setup customise type convert function", function (done) { src_1.default({ checkType: true, colParser: { "column1": "string", "column5": function (item, head, resultRow, row, i) { assert.equal(item, '{"hello":"world"}'); assert.equal(head, "column5"), assert(resultRow); assert(row); assert.equal(i, 5); return "hello world"; } } }) .fromFile(__dirname + "/data/dataWithType") .subscribe(function (json) { assert.equal(typeof json.column1, "string"); assert.equal(json.column5, "hello world"); assert.strictEqual(json["name#!"], false); assert.strictEqual(json["column9"], true); }) .on('done', function () { done(); }); }); it("should accept pipe as quote", function (done) { src_1.default({ quote: "|", output: "csv" }) .fromFile(__dirname + "/data/pipeAsQuote") .subscribe(function (csv) { assert.equal(csv[2], "blahhh, blah"); }) .on('done', function () { done(); }); }); it("emit file not exists error when try to open a non-exists file", function () { var called = false; var cb = sb.spy(function (err) { assert(err.toString().indexOf("File does not exist") > -1); }); return src_1.default() .fromFile("somefile") .subscribe(function (csv) { }) .on("error", cb) .then(function () { assert(false); }, function (err) { assert.equal(cb.callCount, 1); }); }); it("should include column that is both included and excluded", function () { return src_1.default({ includeColumns: /b/, ignoreColumns: /a|b/ }) .fromString("a,b,c\n1,2,3\n4,5,6") .subscribe(function (d) { assert(d.b); assert(!d.a); }); }); it("should allow async preLine hook", function () { return src_1.default() .preFileLine(function (line) { return new Promise(function (resolve, reject) { setTimeout(function () { resolve(line + "changed"); }, 20); }); }) .fromString("a,b\n1,2") .subscribe(function (d) { assert(d.bchanged); assert.equal(d.bchanged, "2changed"); }); }); it("should allow async subscribe function", function () { return src_1.default({ trim: true }) .fromString("a,b,c\n 1,2,3\n 4,5,6") .subscribe(function (d) { return new Promise(function (resolve, reject) { setTimeout(function () { d.a = 10; resolve(); }, 20); }); }) .then(function (d) { assert.equal(d[0].a, 10); assert.equal(d[1].a, 10); }); }); it("should propagate value to next then", function () { return src_1.default({ trim: true }) .fromString("a,b,c\n 1,2,3\n 4,5,6") .then(undefined, undefined) .then(function (d) { assert.equal(d.length, 2); assert.equal(d[0].a, "1"); }); }); it("should propagate error to next then", function () { return src_1.default({ trim: true }) .fromFile(__dirname + "/data/dataWithUnclosedQuotes") .then(undefined, undefined) .then(function () { assert(false); }, function (err) { assert(err); assert.equal(err.err, "unclosed_quote"); }); }); it("should fallback to text is number can not be parsed", function () { return src_1.default({ colParser: { "a": "number" } }) .fromString("a,b,c\n 1,2,3\n fefe,5,6") .then(function (d) { assert.strictEqual(d[0].a, 1); assert.equal(d[1].a, "fefe"); }); }); it("should omit a column", function () { return src_1.default({ colParser: { "a": "omit" } }) .fromString("a,b,c\n 1,2,3\n fefe,5,6") .then(function (d) { assert.strictEqual(d[0].a, undefined); assert.equal(d[1].a, undefined); }); }); it("could turn off quote and should trim even quote is turned off", function () { return src_1.default({ quote: "off", trim: true }) .fromString("a,b,c\n \"1\",\"2\",\"3\"\n \"fefe,5\",6") .then(function (d) { assert.equal(d[0].a, '"1"'); assert.equal(d[0].b, '"2"'); assert.equal(d[1].a, '"fefe'); assert.equal(d[1].b, '5"'); }); }); it("should allow ignoreEmpty with checkColumn", function () { return src_1.default({ checkColumn: true, ignoreEmpty: true }) .fromString("date,altitude,airtime\n 2016-07-08,2000,23\n \n 2016-07-09,3000,43") .then(function (data) { }, function (err) { console.log(err); assert(!err); }); }); it("should allow quotes without content", function () { var data = "a|^^|^b^"; return src_1.default({ delimiter: '|', quote: '^', noheader: true, }) .fromString(data) .then(function (jsonObj) { assert.equal(jsonObj[0].field2, ""); }); }); it("should parse header with quotes correctly", function () { var testData = __dirname + "/data/csvWithUnclosedHeader"; return src_1.default({ headers: ["exam_date", "sample_no", "status", "sample_type", "patient_id", "last_name", "first_name", "gender_of_patient", "patient_birth_date", "patient_note", "patient_department", "accession_number", "sample_site", "physician", "operator", "department", "note", "test_order_code", "draw_time", "approval_status", "approval_time", "report_layout", "patient_account_number", "none_1", "errors_detected_during_measurement", "age", "error_code_01", "weight", "error_code_02", "height", "error_code_03", "hcg_beta_p", "error_code_04", "troponin_i_p", "error_code_05", "ck_mb_p", "error_code_06", "d_dimer_p", "error_code_07", "hscrp_p", "error_code_08", "myoglobin_p", "error_code_09", "nt_probnp", "error_code_10", "crp", "error_code_11", "bnp", "error_code_12", "tnt", "error_code_13", "demo_p", "error_code_14", "pct", "error_code_15"] }) .fromFile(testData) .then(function (d) { assert.equal(d.length, 2); assert.equal(d[0].sample_no, "12669"); }); }); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/test/testCSVConverter3.ts","sources":["/Users/kxiang/work/projects/csv2json/test/testCSVConverter3.ts"],"names":[],"mappings":"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","sourcesContent":["import csv from \"../src\";\nvar assert = require(\"assert\");\nvar fs = require(\"fs\");\nimport { sandbox } from \"sinon\";\nimport CSVError from \"../src/CSVError\";\nconst sb = sandbox.create();\ndescribe(\"testCSVConverter3\", function () {\n  afterEach(function () {\n    sb.restore();\n  });\n  it(\"should parse large csv file with UTF-8 without spliting characters\", function (done) {\n    var testData = __dirname + \"/data/large-utf8.csv\";\n    var rs = fs.createReadStream(testData);\n    var csvConverter = csv({\n    });\n    var count = 0;\n    csvConverter.preRawData(function (csvRawData) {\n      assert(csvRawData.charCodeAt(0) < 2000);\n      return csvRawData;\n    })\n    csvConverter.on(\"data\", function () {\n      count++;\n    });\n    csvConverter.then(function () {\n      assert(count === 5290);\n      done();\n    });\n    rs.pipe(csvConverter);\n  });\n  it(\"should setup customise type convert function\", function (done) {\n    csv({\n      checkType: true,\n      colParser: {\n        \"column1\": \"string\",\n        \"column5\": function (item, head, resultRow, row, i) {\n          assert.equal(item, '{\"hello\":\"world\"}');\n          assert.equal(head, \"column5\"),\n            assert(resultRow);\n          assert(row);\n          assert.equal(i, 5);\n          return \"hello world\";\n        }\n      }\n    })\n      .fromFile(__dirname + \"/data/dataWithType\")\n      .subscribe(function (json) {\n        assert.equal(typeof json.column1, \"string\");\n        assert.equal(json.column5, \"hello world\");\n        assert.strictEqual(json[\"name#!\"], false);\n        assert.strictEqual(json[\"column9\"], true);\n      })\n      .on('done', function () {\n        done()\n      });\n  })\n  it(\"should accept pipe as quote\", function (done) {\n    csv({\n      quote: \"|\",\n      output: \"csv\"\n    })\n      .fromFile(__dirname + \"/data/pipeAsQuote\")\n      .subscribe(function (csv) {\n        assert.equal(csv[2], \"blahhh, blah\");\n      })\n      .on('done', function () {\n        done()\n      });\n  })\n  it(\"emit file not exists error when try to open a non-exists file\", function () {\n    let called = false;\n    const cb = sb.spy((err) => {\n      assert(err.toString().indexOf(\"File does not exist\") > -1);\n    });\n    return csv()\n      .fromFile(\"somefile\")\n      .subscribe(function (csv) {\n\n      })\n      .on(\"error\", cb)\n      .then(() => {\n        assert(false);\n      }, (err) => {\n        assert.equal(cb.callCount, 1);\n      })\n\n  })\n  it(\"should include column that is both included and excluded\", () => {\n    return csv({\n      includeColumns: /b/,\n      ignoreColumns: /a|b/\n    })\n      .fromString(`a,b,c\n1,2,3\n4,5,6`)\n      .subscribe((d) => {\n        assert(d.b);\n        assert(!d.a);\n      })\n  })\n  it(\"should allow async preLine hook\", () => {\n    return csv()\n      .preFileLine((line) => {\n        return new Promise((resolve, reject) => {\n          setTimeout(() => {\n            resolve(line + \"changed\")\n          }, 20);\n\n        })\n      })\n      .fromString(`a,b\n1,2`)\n      .subscribe((d) => {\n        assert(d.bchanged);\n        assert.equal(d.bchanged, \"2changed\");\n      })\n\n  })\n\n  it(\"should allow async subscribe function\", () => {\n    return csv({ trim: true })\n      .fromString(`a,b,c\n    1,2,3\n    4,5,6`)\n      .subscribe((d) => {\n        return new Promise((resolve, reject) => {\n          setTimeout(() => {\n            d.a = 10;\n            resolve();\n          }, 20);\n        })\n      })\n      .then((d) => {\n        assert.equal(d[0].a, 10);\n        assert.equal(d[1].a, 10);\n      })\n  })\n  it(\"should propagate value to next then\", () => {\n    return csv({ trim: true })\n      .fromString(`a,b,c\n  1,2,3\n  4,5,6`)\n      .then(undefined, undefined)\n      .then((d) => {\n        assert.equal(d.length, 2);\n        assert.equal(d[0].a, \"1\");\n      })\n\n  })\n  it(\"should propagate error to next then\", () => {\n    return csv({ trim: true })\n      .fromFile(__dirname + \"/data/dataWithUnclosedQuotes\")\n      .then(undefined, undefined)\n      .then(() => {\n        assert(false)\n      }, (err: CSVError) => {\n        assert(err);\n        assert.equal(err.err, \"unclosed_quote\");\n      })\n  })\n  it(\"should fallback to text is number can not be parsed\", () => {\n    return csv({\n      colParser: {\n        \"a\": \"number\"\n      }\n    })\n      .fromString(`a,b,c\n  1,2,3\n  fefe,5,6`)\n      .then((d) => {\n        assert.strictEqual(d[0].a, 1);\n        assert.equal(d[1].a, \"fefe\");\n      })\n  })\n  it(\"should omit a column\", () => {\n    return csv({\n      colParser: {\n        \"a\": \"omit\"\n      }\n    })\n      .fromString(`a,b,c\n  1,2,3\n  fefe,5,6`)\n      .then((d) => {\n        assert.strictEqual(d[0].a, undefined);\n        assert.equal(d[1].a, undefined);\n      })\n  })\n  it(\"could turn off quote and should trim even quote is turned off\", () => {\n    return csv({\n      quote: \"off\",\n      trim: true\n    })\n      .fromString(`a,b,c\n  \"1\",\"2\",\"3\"\n  \"fefe,5\",6`)\n      .then((d) => {\n        assert.equal(d[0].a, '\"1\"');\n        assert.equal(d[0].b, '\"2\"');\n        assert.equal(d[1].a, '\"fefe');\n        assert.equal(d[1].b, '5\"');\n      })\n  })\n  it(\"should allow ignoreEmpty with checkColumn\", () => {\n    return csv({\n      checkColumn: true,\n      ignoreEmpty: true\n    })\n      .fromString(`date,altitude,airtime\n    2016-07-08,2000,23\n    \n    2016-07-09,3000,43`)\n      .then((data) => {\n\n      }, (err) => {\n        console.log(err);\n        assert(!err);\n      })\n  });\n  it(\"should allow quotes without content\", () => {\n    const data = \"a|^^|^b^\";\n    return csv({\n      delimiter: '|',\n      quote: '^',\n      noheader: true,\n    })\n      .fromString(data)\n      .then((jsonObj) => {\n        assert.equal(jsonObj[0].field2, \"\");\n      });\n  })\n  it(\"should parse header with quotes correctly\", function () {\n    var testData = __dirname + \"/data/csvWithUnclosedHeader\";\n    return csv({\n      headers:[\"exam_date\",\"sample_no\",\"status\",\"sample_type\",\"patient_id\",\"last_name\",\"first_name\",\"gender_of_patient\",\"patient_birth_date\",\"patient_note\",\"patient_department\",\"accession_number\",\"sample_site\",\"physician\",\"operator\",\"department\",\"note\",\"test_order_code\",\"draw_time\",\"approval_status\",\"approval_time\",\"report_layout\",\"patient_account_number\",\"none_1\",\"errors_detected_during_measurement\",\"age\",\"error_code_01\",\"weight\",\"error_code_02\",\"height\",\"error_code_03\",\"hcg_beta_p\",\"error_code_04\",\"troponin_i_p\",\"error_code_05\",\"ck_mb_p\",\"error_code_06\",\"d_dimer_p\",\"error_code_07\",\"hscrp_p\",\"error_code_08\",\"myoglobin_p\",\"error_code_09\",\"nt_probnp\",\"error_code_10\",\"crp\",\"error_code_11\",\"bnp\",\"error_code_12\",\"tnt\",\"error_code_13\",\"demo_p\",\"error_code_14\",\"pct\",\"error_code_15\"]\n    })\n    .fromFile(testData)\n    .then((d)=>{\n      assert.equal(d.length,2);\n      assert.equal(d[0].sample_no,\"12669\");\n    })\n    \n  });\n});\n"]}