WME/aufgabe5/node_modules/csvtojson/.ts-node/46be5da2105bfdf13e8db086405c89f751746b6e7f1dbb5a5600bad96af1b73b/204d44a3b08589411788351f533b2a96e89ab84d86142a1bc9b7767bb5601d6d.js

522 lines
No EOL
66 KiB
JavaScript

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var Converter_1 = require("../src/Converter");
var src_1 = __importDefault(require("../src"));
var assert = require("assert");
var fs = require("fs");
var sandbox = require('sinon').sandbox.create();
describe("testCSVConverter2", function () {
afterEach(function () {
sandbox.restore();
});
it("should convert from large csv string", function (done) {
var csvStr = fs.readFileSync(__dirname + "/data/large-csv-sample.csv", "utf8");
var conv = new Converter_1.Converter({});
conv.fromString(csvStr).then(function (res) {
assert(res.length === 5290);
done();
});
});
it("should set eol", function (done) {
var rs = fs.createReadStream(__dirname + "/data/large-csv-sample.csv");
var conv = new Converter_1.Converter({
eol: "\n"
});
var count = 0;
conv.subscribe(function (resultJson, index) {
count++;
assert(resultJson);
// assert(row.length === 2);
assert(index >= 0);
});
conv.on("error", function () {
console.log(arguments);
});
conv.then(function (result) {
assert(result);
assert(count === 5290);
done();
});
rs.pipe(conv);
});
it("should convert tsv String", function (done) {
var tsv = __dirname + "/data/dataTsv";
var csvStr = fs.readFileSync(tsv, "utf8");
var conv = new Converter_1.Converter({
delimiter: "\t",
"checkType": false
});
conv.fromString(csvStr).then(function (res) {
assert(res);
assert.equal(res.length, 200);
done();
});
});
it("should allow customised header with nohead csv string.", function (done) {
var testData = __dirname + "/data/noheadercsv";
var rs = fs.readFileSync(testData, "utf8");
var conv = new Converter_1.Converter({
noheader: true,
headers: ["a", "b", "c", "e", "f", "g"]
});
conv.fromString(rs).then(function (json) {
assert.equal(json[0].field7, 40);
assert.equal(json[0].a, "CC102-PDMI-001");
done();
});
});
it("should parse fromFile", function (done) {
var csvFile = __dirname + "/data/large-csv-sample.csv";
var conv = new Converter_1.Converter({});
conv.fromFile(csvFile).then(function (res) {
assert.equal(res.length, 5290);
done();
});
});
it("should fromFile should emit error", function (done) {
var csvFile = __dirname + "/data/dataWithUnclosedQuotes";
var conv = new Converter_1.Converter({});
conv.fromFile(csvFile).then(function (res) {
done();
}, function (err) {
assert(err);
done();
});
});
it("should parse no header with dynamic column number", function (done) {
var testData = __dirname + "/data/noheaderWithVaryColumnNum";
var rs = fs.readFileSync(testData, "utf8");
var conv = new Converter_1.Converter({
noheader: true
});
conv.fromString(rs).then(function (json) {
assert.equal(json.length, 2);
assert.equal(json[1].field4, 7);
done();
});
});
it("should parse tabsv data with dynamic columns", function (done) {
var testData = __dirname + "/data/tabsv";
var rs = fs.readFileSync(testData, "utf8");
var conv = new Converter_1.Converter({
delimiter: "\t"
});
conv.fromString(rs).then(function (json) {
assert.equal(json[0].Idevise, "");
done();
});
});
it("should use first line break as eol", function (done) {
var testData = __dirname + "/data/testEol";
var conv = new Converter_1.Converter({
noheader: true
});
conv.fromFile(testData).then(function (json) {
assert(json);
done();
});
});
it("should detect delimiter", function (done) {
var testData = __dirname + "/data/dataWithAutoDelimiter";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({ delimiter: "auto" });
conv.then(function (res) {
assert.equal(res[0].col1, "Mini. Sectt:hisar S.O");
assert.equal(res[1].col1, "#Mini. Sectt");
done();
});
rs.pipe(conv);
});
it("should emit delimiter event", function (done) {
var testData = __dirname + "/data/dataWithAutoDelimiter";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({ delimiter: "auto" });
var delimiterCallback = sandbox.spy(function (delimiter) {
assert.equal(delimiter, ":");
});
conv.on("delimiter", delimiterCallback);
conv.then(function () {
assert.equal(delimiterCallback.callCount, 1);
done();
});
rs.pipe(conv);
});
it("should emit delimiter event when no header", function (done) {
var testData = __dirname + "/data/dataWithAutoDelimiter";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({ delimiter: "auto", noheader: true });
var delimiterCallback = sandbox.spy(function (delimiter) {
assert.equal(delimiter, ":");
});
conv.on("delimiter", delimiterCallback);
conv.then(function () {
assert.equal(delimiterCallback.callCount, 1);
done();
});
rs.pipe(conv);
});
// it("should not emit delimiter event when delimiter is specified", function (done) {
// var testData = __dirname + "/data/columnArray";
// var rs = fs.createReadStream(testData);
// var conv = new Converter();
// conv.on("delimiter", function (delimiter) {
// assert.fail("delimiter event should not have been emitted");
// });
// conv.then(function () {
// done();
// });
// rs.pipe(conv);
// });
it("should stripe out whitespaces if trim is true", function (done) {
var testData = __dirname + "/data/dataWithWhiteSpace";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({ trim: true });
conv.then(function (res) {
assert.equal(res[0]["Column 1"], "Column1Row1");
assert.equal(res[0]["Column 2"], "Column2Row1");
done();
});
rs.pipe(conv);
});
it("should convert triple quotes correctly", function (done) {
var testData = __dirname + "/data/dataWithTripleQoutes";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({ trim: true });
conv.then(function (res) {
assert.equal(res[0].Description, "ac, abs, moon");
assert.equal(res[1].Model, "Venture \"Extended Edition\"");
assert.equal(res[2].Model, "Venture \"Extended Edition, Very Large\"");
done();
});
rs.pipe(conv);
});
it("should pre process raw data in the line", function (done) {
var testData = __dirname + "/data/quoteTolerant";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter();
conv.preRawData(function (d) {
return d.replace('THICK', 'THIN');
});
conv.then(function (res) {
assert(res[0].Description.indexOf('THIN') > -1);
done();
});
rs.pipe(conv);
});
it("should pre process by line in the line", function (done) {
var testData = __dirname + "/data/quoteTolerant";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter();
conv.preFileLine(function (line, lineNumber) {
if (lineNumber === 1) {
line = line.replace('THICK', 'THIN');
}
return line;
});
conv.then(function (res) {
assert(res[0].Description.indexOf('THIN') > -1);
done();
});
rs.pipe(conv);
});
it("should support object mode", function (done) {
var testData = __dirname + "/data/complexJSONCSV";
var rs = fs.createReadStream(testData);
var conv = new Converter_1.Converter({}, {
objectMode: true
});
conv.on("data", function (d) {
assert(typeof d === "object");
});
conv.then(function (res) {
assert(res);
assert(res.length > 0);
done();
});
rs.pipe(conv);
});
it("should get delimiter automatically if there is no header", function (done) {
var test_converter = new Converter_1.Converter({
delimiter: 'auto',
headers: ['col1', 'col2'],
noheader: true,
checkColumn: true
});
var my_data = 'first_val\tsecond_val';
test_converter.fromString(my_data).then(function (result) {
assert.equal(result.length, 1);
assert.equal(result[0].col1, "first_val");
assert.equal(result[0].col2, "second_val");
done();
});
});
it("should process escape chars", function (done) {
var test_converter = new Converter_1.Converter({
escape: "\\",
checkType: true
});
var testData = __dirname + "/data/dataWithSlashEscape";
var rs = fs.createReadStream(testData);
test_converter.then(function (res) {
assert.equal(res[0].raw.hello, "world");
assert.equal(res[0].raw.test, true);
done();
});
rs.pipe(test_converter);
});
it("should output ndjson format", function (done) {
var conv = new Converter_1.Converter();
conv.fromString("a,b,c\n1,2,3\n4,5,6")
.on("data", function (d) {
d = d.toString();
assert.equal(d[d.length - 1], "\n");
})
.on("done", done);
});
it("should parse from stream", function (done) {
var testData = __dirname + "/data/complexJSONCSV";
var rs = fs.createReadStream(testData);
src_1.default()
.fromStream(rs)
.then(function (res) {
assert(res);
done();
});
});
it("should set output as csv", function (done) {
var testData = __dirname + "/data/complexJSONCSV";
var rs = fs.createReadStream(testData);
var numOfRow = 0;
src_1.default({ output: "csv" })
.fromStream(rs)
.subscribe(function (row, idx) {
numOfRow++;
assert(row);
assert(idx >= 0);
})
.on("done", function (error) {
assert(!error);
assert.equal(2, numOfRow);
assert(numOfRow !== 0);
done();
});
});
it("should transform with subscribe function", function (done) {
var testData = __dirname + "/data/complexJSONCSV";
var rs = fs.createReadStream(testData);
var numOfRow = 0;
var numOfJson = 0;
src_1.default()
.fromStream(rs)
.subscribe(function (json, idx) {
json.a = "test";
assert(idx >= 0);
})
.on("data", function (d) {
var j = JSON.parse(d.toString());
assert.equal(j.a, "test");
})
.on("end", function () {
done();
});
});
it("should parse a complex JSON", function (done) {
var converter = new Converter_1.Converter({ checkType: true });
var r = fs.createReadStream(__dirname + "/data/complexJSONCSV");
converter.then(function (res) {
assert(res);
assert(res.length === 2);
assert(res[0].fieldA.title === "Food Factory");
assert(res[0].fieldA.children.length === 2);
assert(res[0].fieldA.children[0].name === "Oscar");
assert(res[0].fieldA.children[0].id === 23);
assert(res[0].fieldA.children[1].name === "Tikka");
assert.equal(res[0].fieldA.children[1].employee.length, 2);
assert(res[0].fieldA.children[1].employee[0].name === "Tim", JSON.stringify(res[0].fieldA.children[1].employee[0]));
assert(res[0].fieldA.address.length === 2);
assert(res[0].fieldA.address[0] === "3 Lame Road");
assert(res[0].fieldA.address[1] === "Grantstown");
assert(res[0].description === "A fresh new food factory", res[0].description);
done();
});
r.pipe(converter);
});
it("should allow flatKey to change parse behaviour", function (done) {
var conv = new Converter_1.Converter({
flatKeys: true
});
conv.fromString("a.b,b.d,c.a\n1,2,3\n4,5,6").subscribe(function (d) {
assert(d["a.b"]);
assert(d["b.d"]);
assert(d["c.a"]);
})
.on("done", done);
});
it("should allow flat mods to change parse behaviour", function (done) {
var conv = new Converter_1.Converter({
colParser: {
"a.b": {
flat: true
}
}
});
conv.fromString("a.b,b.d,c.a\n1,2,3\n4,5,6").subscribe(function (d) {
assert(d["a.b"]);
})
.on("done", done);
});
it("should process long header", function (done) {
var testData = __dirname + "/data/longHeader";
var rs = fs.createReadStream(testData, { highWaterMark: 100 });
var numOfRow = 0;
var numOfJson = 0;
src_1.default({}, { highWaterMark: 100 })
.fromStream(rs)
.subscribe(function (res, idx) {
numOfJson++;
assert.equal(res.Date, '8/26/16');
assert(idx >= 0);
})
.on("done", function () {
assert(numOfJson === 1);
done();
});
});
it("should parse #139", function (done) {
var rs = fs.createReadStream(__dirname + "/data/data#139");
src_1.default()
.fromStream(rs)
.then(function (res) {
assert.equal(res[1].field3, "9001009395 9001009990");
done();
});
});
it("should ignore column", function (done) {
var rs = fs.createReadStream(__dirname + "/data/dataWithQoutes");
var headerEmitted = false;
src_1.default({
ignoreColumns: /TIMESTAMP/
})
.fromStream(rs)
.on("header", function (header) {
assert.equal(header.indexOf("TIMESTAMP"), -1);
assert.equal(header.indexOf("UPDATE"), 0);
if (headerEmitted) {
throw ("header event should only happen once");
}
headerEmitted = true;
})
// .on("csv", function (row, idx) {
// if (!headerEmitted) {
// throw ("header should be emitted before any data events");
// }
// assert(idx >= 0);
// if (idx === 1) {
// assert.equal(row[0], "n");
// }
// })
.subscribe(function (j, idx) {
assert(!j.TIMESTAMP);
assert(idx >= 0);
})
.on("done", function () {
assert(headerEmitted);
done();
});
});
it("should keep space around comma in csv", function () {
var str = "\"Name\",\"Number\"\n \"John , space\", 1234\n \"Mr. , space\", 4321\n ";
return src_1.default().fromString(str)
.then(function (data) {
assert.equal(data[0].Name, "John , space");
assert.equal(data[1].Name, "Mr. , space");
});
});
it("should include column", function (done) {
var rs = fs.createReadStream(__dirname + "/data/dataWithQoutes");
src_1.default({
includeColumns: /TIMESTAMP/
})
.fromStream(rs)
.on("header", function (header) {
assert.equal(header.indexOf("TIMESTAMP"), 0);
assert.equal(header.indexOf("UPDATE"), -1);
assert.equal(header.length, 1);
})
.subscribe(function (j, idx) {
assert(idx >= 0);
if (idx === 1) {
assert.equal(j.TIMESTAMP, "abc, def, ccc");
}
assert(!j.UID);
assert(!j['BYTES SENT']);
})
.on("done", function () {
done();
});
});
it("should allow headers and include columns to be given as reference to the same var", function (done) {
var rs = fs.createReadStream(__dirname + "/data/complexJSONCSV");
var headers = [
'first',
'second',
'third',
];
var expected = headers;
src_1.default({
headers: headers,
includeColumns: /(first|second|third)/,
})
.fromStream(rs)
.on("header", function (header) {
expected.forEach(function (value, index) {
assert.equal(header.indexOf(value), index);
});
})
.subscribe(function (j, idx) {
assert(idx >= 0);
assert.equal(expected.length, Object.keys(j).length);
expected.forEach(function (attribute) {
assert(j.hasOwnProperty(attribute));
});
})
.on("done", function () {
done();
});
});
it("should leave provided params objects unmutated", function () {
var rs = fs.createReadStream(__dirname + "/data/complexJSONCSV");
var includeColumns = [
'fieldA.title',
'description',
];
return src_1.default({
includeColumns: /(fieldA\.title|description)/,
})
.fromStream(rs)
.on("json", function (j, idx) {
assert(idx >= 0);
})
.on("header", function (header) {
includeColumns.forEach(function (value, index) {
assert.equal(index, header.indexOf(value));
});
});
});
it("should only call done once", function (done) {
var counter = 0;
src_1.default()
.fromString('"a","b", "c""')
.on('done', function () {
counter++;
});
setTimeout(function () {
assert.equal(counter, 1);
done();
}, 100);
});
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/test/testCSVConverter2.ts","sources":["/Users/kxiang/work/projects/csv2json/test/testCSVConverter2.ts"],"names":[],"mappings":"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","sourcesContent":["import { Converter } from \"../src/Converter\";\nimport csv from \"../src\";\nvar assert = require(\"assert\");\nvar fs = require(\"fs\");\nvar sandbox = require('sinon').sandbox.create();\ndescribe(\"testCSVConverter2\", function () {\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  it(\"should convert from large csv string\", function (done) {\n    var csvStr = fs.readFileSync(__dirname + \"/data/large-csv-sample.csv\", \"utf8\");\n    var conv = new Converter({\n    });\n    conv.fromString(csvStr).then(function (res) {\n      assert(res.length === 5290);\n      done();\n    });\n  });\n\n  it(\"should set eol\", function (done) {\n    var rs = fs.createReadStream(__dirname + \"/data/large-csv-sample.csv\");\n    var conv = new Converter({\n      eol: \"\\n\"\n    });\n    var count = 0;\n    conv.subscribe(function (resultJson, index) {\n      count++;\n      assert(resultJson);\n      // assert(row.length === 2);\n      assert(index >= 0);\n    });\n    conv.on(\"error\", function () {\n      console.log(arguments);\n    });\n    conv.then(function (result) {\n      assert(result);\n      assert(count === 5290);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should convert tsv String\", function (done) {\n    var tsv = __dirname + \"/data/dataTsv\";\n    var csvStr = fs.readFileSync(tsv, \"utf8\");\n    var conv = new Converter({\n      delimiter: \"\\t\",\n      \"checkType\": false\n    });\n    conv.fromString(csvStr).then(function (res) {\n      assert(res);\n      assert.equal(res.length, 200);\n      done();\n    });\n  });\n\n  it(\"should allow customised header with nohead csv string.\", function (done) {\n    var testData = __dirname + \"/data/noheadercsv\";\n    var rs = fs.readFileSync(testData, \"utf8\");\n    var conv = new Converter({\n      noheader: true,\n      headers: [\"a\", \"b\", \"c\", \"e\", \"f\", \"g\"]\n    });\n    conv.fromString(rs).then(function (json) {\n      assert.equal(json[0].field7, 40);\n      assert.equal(json[0].a, \"CC102-PDMI-001\");\n      done();\n    });\n  });\n\n  it(\"should parse fromFile\", function (done) {\n    var csvFile = __dirname + \"/data/large-csv-sample.csv\";\n    var conv = new Converter({\n    });\n    conv.fromFile(csvFile).then(function (res) {\n      assert.equal(res.length, 5290);\n      done();\n    });\n  });\n\n  it(\"should fromFile should emit error\", function (done) {\n    var csvFile = __dirname + \"/data/dataWithUnclosedQuotes\";\n    var conv = new Converter({\n    });\n    conv.fromFile(csvFile).then(function (res) {\n\n      done();\n    }, function (err) {\n      assert(err);\n      done();\n    });\n  });\n\n  it(\"should parse no header with dynamic column number\", function (done) {\n    var testData = __dirname + \"/data/noheaderWithVaryColumnNum\";\n    var rs = fs.readFileSync(testData, \"utf8\");\n    var conv = new Converter({\n      noheader: true\n    });\n    conv.fromString(rs).then(function (json) {\n      assert.equal(json.length, 2);\n      assert.equal(json[1].field4, 7);\n      done();\n    });\n  });\n\n  it(\"should parse tabsv data with dynamic columns\", function (done) {\n    var testData = __dirname + \"/data/tabsv\";\n    var rs = fs.readFileSync(testData, \"utf8\");\n    var conv = new Converter({\n      delimiter: \"\\t\"\n    });\n    conv.fromString(rs).then(function (json) {\n      assert.equal(json[0].Idevise, \"\");\n      done();\n    });\n  });\n\n  it(\"should use first line break as eol\", function (done) {\n    var testData = __dirname + \"/data/testEol\";\n    var conv = new Converter({\n      noheader: true\n    });\n    conv.fromFile(testData).then(function (json) {\n      assert(json);\n      done();\n    });\n  });\n\n\n  it(\"should detect delimiter\", function (done) {\n    var testData = __dirname + \"/data/dataWithAutoDelimiter\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({ delimiter: \"auto\" });\n    conv.then(function (res) {\n      assert.equal(res[0].col1, \"Mini. Sectt:hisar S.O\");\n      assert.equal(res[1].col1, \"#Mini. Sectt\");\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should emit delimiter event\", function (done) {\n    var testData = __dirname + \"/data/dataWithAutoDelimiter\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({ delimiter: \"auto\" });\n    var delimiterCallback = sandbox.spy(function (delimiter) {\n      assert.equal(delimiter, \":\");\n    });\n    conv.on(\"delimiter\", delimiterCallback);\n    conv.then(function () {\n      assert.equal(delimiterCallback.callCount, 1);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should emit delimiter event when no header\", function (done) {\n    var testData = __dirname + \"/data/dataWithAutoDelimiter\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({ delimiter: \"auto\", noheader: true });\n    var delimiterCallback = sandbox.spy(function (delimiter) {\n      assert.equal(delimiter, \":\");\n    });\n    conv.on(\"delimiter\", delimiterCallback);\n    conv.then(function () {\n      assert.equal(delimiterCallback.callCount, 1);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  // it(\"should not emit delimiter event when delimiter is specified\", function (done) {\n  //   var testData = __dirname + \"/data/columnArray\";\n  //   var rs = fs.createReadStream(testData);\n  //   var conv = new Converter();\n  //   conv.on(\"delimiter\", function (delimiter) {\n  //     assert.fail(\"delimiter event should not have been emitted\");\n  //   });\n  //   conv.then(function () {\n  //     done();\n  //   });\n\n  //   rs.pipe(conv);\n  // });\n\n  it(\"should stripe out whitespaces if trim is true\", function (done) {\n    var testData = __dirname + \"/data/dataWithWhiteSpace\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({ trim: true });\n    conv.then(function (res) {\n      assert.equal(res[0][\"Column 1\"], \"Column1Row1\");\n      assert.equal(res[0][\"Column 2\"], \"Column2Row1\");\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should convert triple quotes correctly\", function (done) {\n    var testData = __dirname + \"/data/dataWithTripleQoutes\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({ trim: true });\n    conv.then(function (res) {\n      assert.equal(res[0].Description, \"ac, abs, moon\");\n      assert.equal(res[1].Model, \"Venture \\\"Extended Edition\\\"\");\n      assert.equal(res[2].Model, \"Venture \\\"Extended Edition, Very Large\\\"\");\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n\n\n  it(\"should pre process raw data in the line\", function (done) {\n    var testData = __dirname + \"/data/quoteTolerant\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter();\n    conv.preRawData(function (d) {\n      return d.replace('THICK', 'THIN');\n    });\n    conv.then(function (res) {\n      assert(res[0].Description.indexOf('THIN') > -1);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should pre process by line in the line\", function (done) {\n    var testData = __dirname + \"/data/quoteTolerant\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter();\n    conv.preFileLine(function (line, lineNumber) {\n      if (lineNumber === 1) {\n        line = line.replace('THICK', 'THIN');\n      }\n      return line;\n    });\n\n    conv.then(function (res) {\n      assert(res[0].Description.indexOf('THIN') > -1);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should support object mode\", function (done) {\n    var testData = __dirname + \"/data/complexJSONCSV\";\n    var rs = fs.createReadStream(testData);\n    var conv = new Converter({}, {\n      objectMode: true\n    });\n    conv.on(\"data\", function (d) {\n      assert(typeof d === \"object\");\n    });\n    conv.then(function (res) {\n      assert(res);\n      assert(res.length > 0);\n      done();\n    });\n    rs.pipe(conv);\n  });\n\n  it(\"should get delimiter automatically if there is no header\", function (done) {\n    var test_converter = new Converter({\n      delimiter: 'auto',\n      headers: ['col1', 'col2'],\n      noheader: true,\n      checkColumn: true\n    });\n\n    var my_data = 'first_val\\tsecond_val';\n    test_converter.fromString(my_data).then(function (result) {\n      assert.equal(result.length, 1);\n      assert.equal(result[0].col1, \"first_val\");\n      assert.equal(result[0].col2, \"second_val\");\n      done();\n    });\n  });\n\n  it(\"should process escape chars\", function (done) {\n    var test_converter = new Converter({\n      escape: \"\\\\\",\n      checkType: true\n    });\n\n    var testData = __dirname + \"/data/dataWithSlashEscape\";\n    var rs = fs.createReadStream(testData);\n    test_converter.then(function (res) {\n      assert.equal(res[0].raw.hello, \"world\");\n      assert.equal(res[0].raw.test, true);\n      done();\n    });\n    rs.pipe(test_converter);\n  });\n\n  it(\"should output ndjson format\", function (done) {\n    var conv = new Converter();\n    conv.fromString(\"a,b,c\\n1,2,3\\n4,5,6\")\n      .on(\"data\", function (d) {\n        d = d.toString();\n        assert.equal(d[d.length - 1], \"\\n\");\n      })\n      .on(\"done\", done);\n  });\n\n  it(\"should parse from stream\", function (done) {\n    var testData = __dirname + \"/data/complexJSONCSV\";\n    var rs = fs.createReadStream(testData);\n    csv()\n      .fromStream(rs)\n      .then(function (res) {\n        assert(res);\n        done();\n      });\n  });\n\n  it(\"should set output as csv\", function (done) {\n    var testData = __dirname + \"/data/complexJSONCSV\";\n    var rs = fs.createReadStream(testData);\n    var numOfRow = 0;\n    csv({ output: \"csv\" })\n      .fromStream(rs)\n      .subscribe(function (row, idx) {\n        numOfRow++;\n        assert(row);\n        assert(idx >= 0);\n      })\n\n      .on(\"done\", function (error) {\n        assert(!error);\n        assert.equal(2, numOfRow);\n        assert(numOfRow !== 0);\n        done();\n      });\n  });\n\n  it(\"should transform with subscribe function\", function (done) {\n    var testData = __dirname + \"/data/complexJSONCSV\";\n    var rs = fs.createReadStream(testData);\n    var numOfRow = 0;\n    var numOfJson = 0;\n    csv()\n      .fromStream(rs)\n      .subscribe(function (json, idx) {\n        json.a = \"test\";\n        assert(idx >= 0);\n      })\n      .on(\"data\", function (d) {\n        const j = JSON.parse(d.toString());\n        assert.equal(j.a, \"test\");\n      })\n      .on(\"end\", function () {\n        done();\n      });\n  });\n\n  it(\"should parse a complex JSON\", function (done) {\n    var converter = new Converter({ checkType: true });\n    var r = fs.createReadStream(__dirname + \"/data/complexJSONCSV\");\n    converter.then(function (res) {\n      assert(res);\n      assert(res.length === 2);\n      assert(res[0].fieldA.title === \"Food Factory\");\n      assert(res[0].fieldA.children.length === 2);\n      assert(res[0].fieldA.children[0].name === \"Oscar\");\n      assert(res[0].fieldA.children[0].id === 23);\n      assert(res[0].fieldA.children[1].name === \"Tikka\");\n      assert.equal(res[0].fieldA.children[1].employee.length, 2);\n      assert(res[0].fieldA.children[1].employee[0].name === \"Tim\", JSON.stringify(res[0].fieldA.children[1].employee[0]));\n      assert(res[0].fieldA.address.length === 2);\n      assert(res[0].fieldA.address[0] === \"3 Lame Road\");\n      assert(res[0].fieldA.address[1] === \"Grantstown\");\n      assert(res[0].description === \"A fresh new food factory\", res[0].description);\n      done();\n    });\n    r.pipe(converter);\n  });\n\n  it(\"should allow flatKey to change parse behaviour\", function (done) {\n    var conv = new Converter({\n      flatKeys: true\n    });\n    conv.fromString(\"a.b,b.d,c.a\\n1,2,3\\n4,5,6\").subscribe(function (d) {\n      assert(d[\"a.b\"]);\n      assert(d[\"b.d\"]);\n      assert(d[\"c.a\"]);\n    })\n      .on(\"done\", done);\n  });\n  it(\"should allow flat mods to change parse behaviour\", function (done) {\n    var conv = new Converter({\n      colParser: {\n        \"a.b\": {\n          flat: true\n        }\n      }\n    });\n    conv.fromString(\"a.b,b.d,c.a\\n1,2,3\\n4,5,6\").subscribe(function (d) {\n      assert(d[\"a.b\"]);\n    })\n      .on(\"done\", done);\n  });\n\n  it(\"should process long header\", function (done) {\n    var testData = __dirname + \"/data/longHeader\";\n    var rs = fs.createReadStream(testData, { highWaterMark: 100 });\n    var numOfRow = 0;\n    var numOfJson = 0;\n    csv({}, { highWaterMark: 100 })\n      .fromStream(rs)\n      .subscribe(function (res, idx) {\n        numOfJson++;\n        assert.equal(res.Date, '8/26/16');\n        assert(idx >= 0);\n      })\n      .on(\"done\", function () {\n        assert(numOfJson === 1);\n        done();\n      });\n  });\n\n  it(\"should parse #139\", function (done) {\n    var rs = fs.createReadStream(__dirname + \"/data/data#139\");\n    csv()\n      .fromStream(rs)\n      .then(function (res) {\n        assert.equal(res[1].field3, \"9001009395 9001009990\");\n        done();\n      });\n  });\n\n  it(\"should ignore column\", function (done) {\n    var rs = fs.createReadStream(__dirname + \"/data/dataWithQoutes\");\n    var headerEmitted = false;\n    csv({\n      ignoreColumns: /TIMESTAMP/\n    })\n      .fromStream(rs)\n      .on(\"header\", function (header) {\n        assert.equal(header.indexOf(\"TIMESTAMP\"), -1);\n        assert.equal(header.indexOf(\"UPDATE\"), 0);\n        if (headerEmitted) {\n          throw (\"header event should only happen once\")\n        }\n        headerEmitted = true;\n      })\n      // .on(\"csv\", function (row, idx) {\n      //   if (!headerEmitted) {\n      //     throw (\"header should be emitted before any data events\");\n      //   }\n      //   assert(idx >= 0);\n      //   if (idx === 1) {\n      //     assert.equal(row[0], \"n\");\n      //   }\n      // })\n      .subscribe(function (j, idx) {\n        assert(!j.TIMESTAMP);\n        assert(idx >= 0);\n      })\n      .on(\"done\", function () {\n        assert(headerEmitted);\n        done();\n      });\n  });\n  it(\"should keep space around comma in csv\", function () {\n    const str = `\"Name\",\"Number\"\n    \"John , space\", 1234\n    \"Mr. , space\", 4321\n    `;\n    return csv().fromString(str)\n      .then((data) => {\n        assert.equal(data[0].Name, \"John , space\");\n        assert.equal(data[1].Name, \"Mr. , space\");\n      })\n  })\n\n  it(\"should include column\", function (done) {\n    var rs = fs.createReadStream(__dirname + \"/data/dataWithQoutes\");\n    csv({\n      includeColumns: /TIMESTAMP/\n    })\n      .fromStream(rs)\n      .on(\"header\", function (header) {\n        assert.equal(header.indexOf(\"TIMESTAMP\"), 0);\n        assert.equal(header.indexOf(\"UPDATE\"), -1);\n        assert.equal(header.length, 1);\n      })\n      .subscribe(function (j, idx) {\n        assert(idx >= 0);\n        if (idx === 1) {\n          assert.equal(j.TIMESTAMP, \"abc, def, ccc\");\n        }\n        assert(!j.UID)\n        assert(!j['BYTES SENT'])\n      })\n      .on(\"done\", function () {\n        done();\n      });\n  });\n\n  it(\"should allow headers and include columns to be given as reference to the same var\", function (done) {\n    var rs = fs.createReadStream(__dirname + \"/data/complexJSONCSV\");\n    var headers = [\n      'first',\n      'second',\n      'third',\n    ];\n\n    var expected = headers;\n\n    csv({\n      headers: headers,\n      includeColumns: /(first|second|third)/,\n    })\n      .fromStream(rs)\n      .on(\"header\", function (header) {\n        expected.forEach(function (value, index) {\n          assert.equal(header.indexOf(value), index);\n        });\n      })\n      .subscribe(function (j, idx) {\n        assert(idx >= 0);\n        assert.equal(expected.length, Object.keys(j).length);\n        expected.forEach(function (attribute) {\n          assert(j.hasOwnProperty(attribute));\n        });\n      })\n      .on(\"done\", function () {\n        done();\n      });\n  });\n\n  it(\"should leave provided params objects unmutated\", function() {\n    var rs = fs.createReadStream(__dirname + \"/data/complexJSONCSV\");\n    var includeColumns = [\n      'fieldA.title',\n      'description',\n    ];\n\n\n    return csv({\n      includeColumns: /(fieldA\\.title|description)/,\n    })\n      .fromStream(rs)\n      .on(\"json\", function(j, idx) {\n        assert(idx >= 0);\n      })\n      .on(\"header\", function(header) {\n        includeColumns.forEach(function (value, index) {\n          assert.equal(index, header.indexOf(value));\n        });\n      })\n  });\n\n  it(\"should only call done once\", function (done) {\n    var counter=0;\n    csv()\n    .fromString('\"a\",\"b\", \"c\"\"')\n    .on('done',function(){\n      counter++;\n    });\n    setTimeout(function(){\n      assert.equal(counter,1);\n      done();\n    },100);\n  })\n});\n"]}