342 lines
38 KiB
Plaintext
342 lines
38 KiB
Plaintext
"use strict";
|
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
});
|
|
};
|
|
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
function step(op) {
|
|
if (f) throw new TypeError("Generator is already executing.");
|
|
while (_) try {
|
|
if (f = 1, y && (t = y[op[0] & 2 ? "return" : op[0] ? "throw" : "next"]) && !(t = t.call(y, op[1])).done) return t;
|
|
if (y = 0, t) op = [0, t.value];
|
|
switch (op[0]) {
|
|
case 0: case 1: t = op; break;
|
|
case 4: _.label++; return { value: op[1], done: false };
|
|
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
default:
|
|
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
if (t[2]) _.ops.pop();
|
|
_.trys.pop(); continue;
|
|
}
|
|
op = body.call(thisArg, _);
|
|
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
}
|
|
};
|
|
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_1 = __importDefault(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_1.default(csvRawData.charCodeAt(0) < 2000);
|
|
return csvRawData;
|
|
});
|
|
csvConverter.on("data", function () {
|
|
count++;
|
|
});
|
|
csvConverter.then(function () {
|
|
assert_1.default(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_1.default.equal(item, '{"hello":"world"}');
|
|
assert_1.default.equal(head, "column5"),
|
|
assert_1.default(resultRow);
|
|
assert_1.default(row);
|
|
assert_1.default.equal(i, 5);
|
|
return "hello world";
|
|
}
|
|
}
|
|
})
|
|
.fromFile(__dirname + "/data/dataWithType")
|
|
.subscribe(function (json) {
|
|
assert_1.default.equal(typeof json.column1, "string");
|
|
assert_1.default.equal(json.column5, "hello world");
|
|
assert_1.default.strictEqual(json["name#!"], false);
|
|
assert_1.default.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_1.default.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_1.default(err.toString().indexOf("File does not exist") > -1);
|
|
});
|
|
return src_1.default()
|
|
.fromFile("somefile")
|
|
.subscribe(function (csv) {
|
|
})
|
|
.on("error", cb)
|
|
.then(function () {
|
|
assert_1.default(false);
|
|
}, function (err) {
|
|
assert_1.default.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_1.default(d.b);
|
|
assert_1.default(!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_1.default(d.bchanged);
|
|
assert_1.default.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_1.default.equal(d[0].a, 10);
|
|
assert_1.default.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_1.default.equal(d.length, 2);
|
|
assert_1.default.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_1.default(false);
|
|
}, function (err) {
|
|
assert_1.default(err);
|
|
assert_1.default.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_1.default.strictEqual(d[0].a, 1);
|
|
assert_1.default.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_1.default.strictEqual(d[0].a, undefined);
|
|
assert_1.default.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_1.default.equal(d[0].a, '"1"');
|
|
assert_1.default.equal(d[0].b, '"2"');
|
|
assert_1.default.equal(d[1].a, '"fefe');
|
|
assert_1.default.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_1.default(!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_1.default.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_1.default.equal(d.length, 2);
|
|
assert_1.default.equal(d[0].sample_no, "12669");
|
|
});
|
|
});
|
|
it("should stream json string correctly", function (done) {
|
|
var data = "a,b,c\n1,2,3\n4,5,6";
|
|
var hasLeftBracket = false;
|
|
var hasRightBracket = false;
|
|
src_1.default({
|
|
downstreamFormat: "array"
|
|
})
|
|
.fromString(data)
|
|
.on("data", function (d) {
|
|
var str = d.toString();
|
|
if (str[0] === "[" && str.length === 2) {
|
|
hasLeftBracket = true;
|
|
}
|
|
else if (str[0] === "]" && str.length === 2) {
|
|
hasRightBracket = true;
|
|
}
|
|
else {
|
|
assert_1.default.equal(str[str.length - 2], ",");
|
|
}
|
|
})
|
|
.on("end", function () {
|
|
assert_1.default.equal(hasLeftBracket, true);
|
|
assert_1.default.equal(hasRightBracket, true);
|
|
done();
|
|
});
|
|
});
|
|
it("should stream json line correctly", function (done) {
|
|
var data = "a,b,c\n1,2,3\n4,5,6";
|
|
src_1.default({
|
|
downstreamFormat: "line"
|
|
})
|
|
.fromString(data)
|
|
.on("data", function (d) {
|
|
var str = d.toString();
|
|
assert_1.default.notEqual(str[str.length - 2], ",");
|
|
})
|
|
.on("end", function () {
|
|
done();
|
|
});
|
|
});
|
|
it("should not send json if needEmitAll is false", function () {
|
|
return __awaiter(this, void 0, void 0, function () {
|
|
var data;
|
|
return __generator(this, function (_a) {
|
|
data = "a,b,c\n1,2,3\n4,5,6";
|
|
return [2 /*return*/, src_1.default({
|
|
needEmitAll: false
|
|
})
|
|
.fromString(data)
|
|
.then(function (d) {
|
|
assert_1.default(d.length === 0);
|
|
})];
|
|
});
|
|
});
|
|
});
|
|
it("should convert null to null object", function () {
|
|
return __awaiter(this, void 0, void 0, function () {
|
|
var data;
|
|
return __generator(this, function (_a) {
|
|
data = "a,b,c\nnull,2,3\n4,5,6";
|
|
return [2 /*return*/, src_1.default({
|
|
nullObject: true
|
|
})
|
|
.fromString(data)
|
|
.then(function (d) {
|
|
assert_1.default.equal(d[0].a, null);
|
|
})];
|
|
});
|
|
});
|
|
});
|
|
it("should process period properly", function () {
|
|
return __awaiter(this, void 0, void 0, function () {
|
|
var data;
|
|
return __generator(this, function (_a) {
|
|
data = "a..,b,c\n1,2,3\n4,5,6";
|
|
return [2 /*return*/, src_1.default({})
|
|
.fromString(data)
|
|
.then(function (d) {
|
|
assert_1.default.equal(d[0]["a.."], 1);
|
|
assert_1.default.equal(d[1]["a.."], 4);
|
|
})];
|
|
});
|
|
});
|
|
});
|
|
});
|
|
//# 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\";\nimport assert from \"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  it (\"should stream json string correctly\",function(done){\n    const data=`a,b,c\n1,2,3\n4,5,6`\n    let hasLeftBracket=false;\n    let hasRightBracket=false;\n    csv({\n      downstreamFormat:\"array\"\n    })\n    .fromString(data)\n    .on(\"data\",(d)=>{\n      const str=d.toString();\n      if (str[0]===\"[\" && str.length ===2){\n        hasLeftBracket=true;\n      }else if (str[0]===\"]\" && str.length===2){\n        hasRightBracket=true;\n      }else{\n        assert.equal(str[str.length-2],\",\");\n      }\n      \n    })\n    .on(\"end\",()=>{\n      assert.equal(hasLeftBracket,true);\n      assert.equal(hasRightBracket,true);\n      done();\n    })\n  })\n  it (\"should stream json line correctly\",function(done){\n    const data=`a,b,c\n1,2,3\n4,5,6`\n    csv({\n      downstreamFormat:\"line\"\n    })\n    .fromString(data)\n    .on(\"data\",(d)=>{\n      const str=d.toString();\n      \n      assert.notEqual(str[str.length-2],\",\");\n    })\n    .on(\"end\",()=>{\n      done();\n    })\n  })\n  it (\"should not send json if needEmitAll is false\",async function(){\n    const data=`a,b,c\n1,2,3\n4,5,6`\n    return csv({\n      needEmitAll:false\n    })\n    .fromString(data)\n    .then((d)=>{\n      assert(d.length===0);\n    })\n  })\n  it (\"should convert null to null object\",async function(){\n    const data=`a,b,c\nnull,2,3\n4,5,6`\n    return csv({\n      nullObject:true\n    })\n    .fromString(data)\n    .then((d)=>{\n      assert.equal(d[0].a,null)\n    })\n  })\n  it (\"should process period properly\",async function(){\n    const data=`a..,b,c\n1,2,3\n4,5,6`\n    return csv({\n    })\n    .fromString(data)\n    .then((d)=>{\n      assert.equal(d[0][\"a..\"],1);\n      assert.equal(d[1][\"a..\"],4);\n    })\n  })\n});\n"]} |