638 lines
No EOL
62 KiB
JavaScript
638 lines
No EOL
62 KiB
JavaScript
"use strict";
|
|
// import {Converter} from "../src/Converter";
|
|
// import csv from "../src";
|
|
// var assert = require("assert");
|
|
// var fs = require("fs");
|
|
// var sandbox = require("sinon").sandbox.create();
|
|
// var file = __dirname + "/data/testData";
|
|
// var trailCommaData = __dirname + "/data/trailingComma";
|
|
// describe("CSV Convert in Background Process", function () {
|
|
// afterEach(function () {
|
|
// sandbox.restore();
|
|
// });
|
|
// it("should read from a stream", function (done) {
|
|
// var obj = new Converter({
|
|
// fork: true
|
|
// });
|
|
// var stream = fs.createReadStream(file);
|
|
// obj.then(function (obj) {
|
|
// assert.equal(obj.length, 2);
|
|
// done();
|
|
// },(err)=>{
|
|
// console.log(err.toString());
|
|
// });
|
|
// stream.pipe(obj);
|
|
// });
|
|
// it("should call onNext once a row is parsed.", function (done) {
|
|
// var obj = new Converter({fork:true});
|
|
// var stream = fs.createReadStream(file);
|
|
// var called = false;
|
|
// obj.subscribe(function (resultRow) {
|
|
// assert(resultRow);
|
|
// called = true;
|
|
// });
|
|
// obj.on("done", function () {
|
|
// assert(called);
|
|
// done();
|
|
// });
|
|
// stream.pipe(obj);
|
|
// });
|
|
// it("should emit end_parsed message once it is finished.", function (done) {
|
|
// var obj = new Converter({fork:true});
|
|
// obj.then(function (result) {
|
|
// assert(result);
|
|
// assert(result.length === 2);
|
|
// assert(result[0].date);
|
|
// assert(result[0].employee);
|
|
// assert(result[0].employee.name);
|
|
// assert(result[0].employee.age);
|
|
// assert(result[0].employee.number);
|
|
// assert(result[0].employee.key.length === 2);
|
|
// assert(result[0].address.length === 2);
|
|
// done();
|
|
// });
|
|
// fs.createReadStream(file).pipe(obj);
|
|
// });
|
|
// it("should handle traling comma gracefully", function (done) {
|
|
// var stream = fs.createReadStream(trailCommaData);
|
|
// var obj = new Converter({fork:true});
|
|
// obj.then(function (result) {
|
|
// assert(result);
|
|
// assert(result.length > 0);
|
|
// done();
|
|
// });
|
|
// stream.pipe(obj);
|
|
// });
|
|
// it("should handle comma in column which is surrounded by qoutes", function (done) {
|
|
// var testData = __dirname + "/data/dataWithComma";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var obj = new Converter({
|
|
// "quote": "#",
|
|
// "fork":true
|
|
// });
|
|
// obj.then(function (result) {
|
|
// assert(result[0].col1 === "\"Mini. Sectt");
|
|
// assert.equal(result[3].col2, "125001,fenvkdsf");
|
|
// // console.log(result);
|
|
// done();
|
|
// });
|
|
// rs.pipe(obj);
|
|
// });
|
|
// it("should be able to convert a csv to column array data", function (done) {
|
|
// var columArrData = __dirname + "/data/columnArray";
|
|
// var rs = fs.createReadStream(columArrData);
|
|
// var result:any = {};
|
|
// var csvConverter = new Converter({fork:true});
|
|
// //end_parsed will be emitted once parsing finished
|
|
// csvConverter.then(function () {
|
|
// assert(result.TIMESTAMP.length === 5);
|
|
// done();
|
|
// });
|
|
// //record_parsed will be emitted each time a row has been parsed.
|
|
// csvConverter.subscribe(function (resultRow, rowIndex) {
|
|
// for (var key in resultRow) {
|
|
// if (resultRow.hasOwnProperty(key)) {
|
|
// if (!result[key] || !(result[key] instanceof Array)) {
|
|
// result[key] = [];
|
|
// }
|
|
// result[key][rowIndex] = resultRow[key];
|
|
// }
|
|
// }
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should be able to convert csv string directly", function (done) {
|
|
// var testData = __dirname + "/data/testData";
|
|
// var data = fs.readFileSync(testData).toString();
|
|
// var csvConverter = new Converter({fork:true});
|
|
// //end_parsed will be emitted once parsing finished
|
|
// csvConverter.then(function (jsonObj) {
|
|
// assert.equal(jsonObj.length, 2);
|
|
// });
|
|
// csvConverter.fromString(data).then(function (jsonObj) {
|
|
// assert(jsonObj.length === 2);
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should be able to convert csv string with error", function (done) {
|
|
// var testData = __dirname + "/data/dataWithUnclosedQuotes";
|
|
// var data = fs.readFileSync(testData).toString();
|
|
// var csvConverter = new Converter({fork:true});
|
|
// csvConverter.fromString(data).then(undefined, function (err) {
|
|
// // console.log(err);
|
|
// assert(err);
|
|
// assert.equal(err.err, "unclosed_quote");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should be able to convert csv string without callback provided", function (done) {
|
|
// var testData = __dirname + "/data/testData";
|
|
// var data = fs.readFileSync(testData).toString();
|
|
// var csvConverter = new Converter({fork:true});
|
|
// //end_parsed will be emitted once parsing finished
|
|
// csvConverter.then(function (jsonObj) {
|
|
// assert(jsonObj.length === 2);
|
|
// done();
|
|
// });
|
|
// csvConverter.fromString(data);
|
|
// });
|
|
// it("should be able to handle columns with double quotes", function (done) {
|
|
// var testData = __dirname + "/data/dataWithQoutes";
|
|
// var data = fs.readFileSync(testData).toString();
|
|
// var csvConverter = new Converter({fork:true});
|
|
// csvConverter.fromString(data).then(function (jsonObj) {
|
|
// assert(jsonObj[0].TIMESTAMP === '13954264"22', JSON.stringify(jsonObj[0].TIMESTAMP));
|
|
// assert(jsonObj[1].TIMESTAMP === 'abc, def, ccc', JSON.stringify(jsonObj[1].TIMESTAMP));
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should be able to handle columns with two double quotes", function (done) {
|
|
// var testData = __dirname + "/data/twodoublequotes";
|
|
// var data = fs.readFileSync(testData).toString();
|
|
// var csvConverter = new Converter({fork:true});
|
|
// csvConverter.fromString(data).then(function (jsonObj) {
|
|
// assert.equal(jsonObj[0].title, "\"");
|
|
// assert.equal(jsonObj[0].data, "xyabcde");
|
|
// assert.equal(jsonObj[0].uuid, "fejal\"eifa");
|
|
// assert.equal(jsonObj[0].fieldA, "bnej\"\"falkfe");
|
|
// assert.equal(jsonObj[0].fieldB, "\"eisjfes\"");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should handle empty csv file", function (done) {
|
|
// var testData = __dirname + "/data/emptyFile";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var csvConverter = new Converter({fork:true});
|
|
// csvConverter.then(function (jsonObj) {
|
|
// assert(jsonObj.length === 0);
|
|
// done();
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should parse large csv file", function (done) {
|
|
// var testData = __dirname + "/data/large-csv-sample.csv";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var csvConverter = new Converter({fork:true});
|
|
// var count = 0;
|
|
// csvConverter.subscribe(function () {
|
|
// // console.log(arguments);
|
|
// count++;
|
|
// });
|
|
// csvConverter.then(function () {
|
|
// assert.equal(count, 5290);
|
|
// done();
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should parse data and covert to specific types", function (done) {
|
|
// var testData = __dirname + "/data/dataWithType";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var csvConverter = new Converter({
|
|
// fork:true,
|
|
// checkType: true,
|
|
// colParser: {
|
|
// "column6": "string",
|
|
// "column7": "string"
|
|
// }
|
|
// });
|
|
// csvConverter.subscribe(function (d) {
|
|
// assert(typeof d.column1 === "number");
|
|
// assert(typeof d.column2 === "string");
|
|
// assert.equal(d["colume4"], "someinvaliddate");
|
|
// assert(d.column5.hello === "world");
|
|
// assert(d.column6 === '{"hello":"world"}');
|
|
// assert(d.column7 === "1234");
|
|
// assert(d.column8 === "abcd");
|
|
// assert(d.column9 === true);
|
|
// assert(d.column10[0] === 23);
|
|
// assert(d.column10[1] === 31);
|
|
// assert(d.column11[0].hello === "world");
|
|
// assert(d["name#!"] === false);
|
|
// });
|
|
// csvConverter.on("done", function () {
|
|
// done();
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should turn off field type check", function (done) {
|
|
// var testData = __dirname + "/data/dataWithType";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var csvConverter = new Converter({
|
|
// fork:true,
|
|
// checkType: false
|
|
// });
|
|
// csvConverter.subscribe(function (d) {
|
|
// assert(typeof d.column1 === "string");
|
|
// assert(typeof d.column2 === "string");
|
|
// assert(d["column3"] === "2012-01-01");
|
|
// assert(d["colume4"] === "someinvaliddate");
|
|
// assert(d.column5 === '{"hello":"world"}');
|
|
// assert.equal(d["column6"], '{"hello":"world"}');
|
|
// assert(d["column7"] === "1234");
|
|
// assert(d["column8"] === "abcd");
|
|
// assert(d.column9 === "true");
|
|
// assert(d.column10[0] === "23");
|
|
// assert(d.column10[1] === "31");
|
|
// assert(d["name#!"] === 'false');
|
|
// });
|
|
// csvConverter.then(function () {
|
|
// done();
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should emit data event correctly", function (done) {
|
|
// var testData = __dirname + "/data/large-csv-sample.csv";
|
|
// var csvConverter = new Converter({
|
|
// fork:true
|
|
// },{objectMode:true});
|
|
// var count = 0;
|
|
// csvConverter.on("data", function (d) {
|
|
// count++;
|
|
// });
|
|
// csvConverter.on("done", function () {
|
|
// assert.equal(csvConverter.parsedLineNumber, 5290);
|
|
// done();
|
|
// });
|
|
// var rs = fs.createReadStream(testData);
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("should process column with linebreaks", function (done) {
|
|
// var testData = __dirname + "/data/lineBreak";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var csvConverter = new Converter({
|
|
// fork:true,
|
|
// checkType: true
|
|
// });
|
|
// csvConverter.subscribe(function (d) {
|
|
// assert(d.Period === 13);
|
|
// assert(d["Apparent age"] === "Unknown");
|
|
// done();
|
|
// });
|
|
// rs.pipe(csvConverter);
|
|
// });
|
|
// it("be able to ignore empty columns", function (done) {
|
|
// var testData = __dirname + "/data/dataIgnoreEmpty";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(csv({
|
|
// ignoreEmpty: true ,
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 3);
|
|
// assert(j.col2.length === 2);
|
|
// assert(j.col2[1] === "d3");
|
|
// assert(j.col4.col3 === undefined);
|
|
// assert(j.col4.col5 === "world");
|
|
// assert(res[1].col1 === "d2");
|
|
// assert(res[2].col1 === "d4");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should allow no header", function (done) {
|
|
// var testData = __dirname + "/data/noheadercsv";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// noheader: true,
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 5);
|
|
// assert(j.field1 === "CC102-PDMI-001");
|
|
// assert(j.field2 === "eClass_5.1.3");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should allow customised header", function (done) {
|
|
// var testData = __dirname + "/data/noheadercsv";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// noheader: true,
|
|
// headers: ["a", "b"],
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 5);
|
|
// assert(j.a === "CC102-PDMI-001");
|
|
// assert(j.b === "eClass_5.1.3");
|
|
// assert(j.field3 === "10/3/2014");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should allow customised header to override existing header", function (done) {
|
|
// var testData = __dirname + "/data/complexJSONCSV";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// headers: [],
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 2);
|
|
// assert(j.field1 === "Food Factory");
|
|
// assert(j.field2 === "Oscar");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should handle when there is an empty string", function (done) {
|
|
// var testData = __dirname + "/data/dataWithEmptyString";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// noheader: true,
|
|
// headers: ["a", "b", "c"],
|
|
// checkType: true,
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// // assert(res.length===2);
|
|
// assert(j.a === "green");
|
|
// assert(j.b === 40);
|
|
// assert.equal(j.c, "");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should detect eol correctly when first chunk is smaller than header row length", function (done) {
|
|
// var testData = __dirname + "/data/dataNoTrimCRLF";
|
|
// var rs = fs.createReadStream(testData, { highWaterMark: 3 });
|
|
// var st = rs.pipe(new Converter({
|
|
// trim: false,
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 2);
|
|
// assert(j.name === "joe");
|
|
// assert(j.age === "20");
|
|
// assert.equal(res[1].name, "sam");
|
|
// assert.equal(res[1].age, "30");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should detect eol correctly when first chunk ends in middle of CRLF line break", function (done) {
|
|
// var testData = __dirname + "/data/dataNoTrimCRLF";
|
|
// var rs = fs.createReadStream(testData, { highWaterMark: 9 });
|
|
// var st = rs.pipe(new Converter({
|
|
// trim: false,
|
|
// fork:true
|
|
// }));
|
|
// st.then(function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length === 2);
|
|
// assert(j.name === "joe");
|
|
// assert(j.age === "20");
|
|
// assert.equal(res[1].name, "sam");
|
|
// assert.equal(res[1].age, "30");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should emit eol event when line ending is detected as CRLF", function (done) {
|
|
// var testData = __dirname + "/data/dataNoTrimCRLF";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// fork:true
|
|
// }));
|
|
// var eolCallback = sandbox.spy(function (eol) {
|
|
// assert.equal(eol, "\r\n");
|
|
// });
|
|
// st.on("eol", eolCallback);
|
|
// st.then(function () {
|
|
// assert.equal(eolCallback.callCount, 1, 'should emit eol event once');
|
|
// done();
|
|
// })
|
|
// });
|
|
// it("should emit eol event when line ending is detected as LF", function (done) {
|
|
// var testData = __dirname + "/data/columnArray";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// fork:true
|
|
// }));
|
|
// var eolCallback = sandbox.spy(function (eol) {
|
|
// assert.equal(eol, "\n");
|
|
// });
|
|
// st.on("eol", eolCallback);
|
|
// st.then(function () {
|
|
// assert.equal(eolCallback.callCount, 1, 'should emit eol event once');
|
|
// done();
|
|
// })
|
|
// });
|
|
// it("should remove the Byte Order Mark (BOM) from input", function (done) {
|
|
// var testData = __dirname + "/data/dataNoTrimBOM";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var st = rs.pipe(new Converter({
|
|
// trim: false,
|
|
// fork:true
|
|
// }));
|
|
// st.then( function (res) {
|
|
// var j = res[0];
|
|
// assert(res.length===2);
|
|
// assert(j.name === "joe");
|
|
// assert(j.age === "20");
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should set output as csv", function (done) {
|
|
// var testData = __dirname + "/data/complexJSONCSV";
|
|
// var rs = fs.createReadStream(testData);
|
|
// var numOfRow = 0;
|
|
// csv({ output: "csv",fork:true })
|
|
// .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 process long header", function (done) {
|
|
// var testData = __dirname + "/data/longHeader";
|
|
// var rs = fs.createReadStream(testData, { highWaterMark: 100 });
|
|
// var numOfRow = 0;
|
|
// var numOfJson = 0;
|
|
// csv({fork:true}, { 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");
|
|
// csv({fork:true})
|
|
// .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;
|
|
// csv({
|
|
// ignoreColumns: /TIMESTAMP/,
|
|
// fork:true
|
|
// })
|
|
// .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) {
|
|
// // console.log(j);
|
|
// assert(!j.TIMESTAMP);
|
|
// assert(idx >= 0);
|
|
// })
|
|
// .on("done", function (err) {
|
|
// assert(!err);
|
|
// assert(headerEmitted);
|
|
// done();
|
|
// });
|
|
// });
|
|
// it("should include column", function (done) {
|
|
// var rs = fs.createReadStream(__dirname + "/data/dataWithQoutes");
|
|
// csv({
|
|
// includeColumns: /TIMESTAMP/,
|
|
// fork:true
|
|
// })
|
|
// .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;
|
|
// csv({
|
|
// headers: headers,
|
|
// includeColumns: /(first|second|third)/,
|
|
// fork:true
|
|
// })
|
|
// .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 csv({
|
|
// includeColumns: /(fieldA\.title|description)/,
|
|
// fork:true
|
|
// })
|
|
// .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 accept pipe as quote", function (done) {
|
|
// csv({
|
|
// quote: "|",
|
|
// output: "csv",
|
|
// "fork":true
|
|
// })
|
|
// .fromFile(__dirname + "/data/pipeAsQuote")
|
|
// .subscribe(function (csv) {
|
|
// assert.equal(csv[2], "blahhh, blah");
|
|
// })
|
|
// .on('done', function () {
|
|
// done()
|
|
// });
|
|
// })
|
|
// it("should allow async subscribe function", () => {
|
|
// return csv({ trim: true,fork:true })
|
|
// .fromString(`a,b,c
|
|
// 1,2,3
|
|
// 4,5,6`)
|
|
// .subscribe((d) => {
|
|
// return new Promise((resolve, reject) => {
|
|
// setTimeout(() => {
|
|
// d.a = 10;
|
|
// resolve();
|
|
// }, 20);
|
|
// })
|
|
// })
|
|
// .then((d) => {
|
|
// assert.equal(d[0].a, 10);
|
|
// assert.equal(d[1].a, 10);
|
|
// })
|
|
// })
|
|
// it("should omit a column", () => {
|
|
// return csv({
|
|
// colParser: {
|
|
// "a": "omit"
|
|
// },
|
|
// fork:true
|
|
// })
|
|
// .fromString(`a,b,c
|
|
// 1,2,3
|
|
// fefe,5,6`)
|
|
// .then((d) => {
|
|
// assert.strictEqual(d[0].a, undefined);
|
|
// assert.equal(d[1].a, undefined);
|
|
// })
|
|
// })
|
|
// });
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/test/testCSVConverter.fork.ts","sources":["/Users/kxiang/work/projects/csv2json/test/testCSVConverter.fork.ts"],"names":[],"mappings":"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","sourcesContent":["// import {Converter} from \"../src/Converter\";\n// import csv from \"../src\";\n// var assert = require(\"assert\");\n// var fs = require(\"fs\");\n// var sandbox = require(\"sinon\").sandbox.create();\n// var file = __dirname + \"/data/testData\";\n// var trailCommaData = __dirname + \"/data/trailingComma\";\n// describe(\"CSV Convert in Background Process\", function () {\n//   afterEach(function () {\n//     sandbox.restore();\n//   });\n\n\n//   it(\"should read from a stream\", function (done) {\n//     var obj = new Converter({\n//       fork: true\n//     });\n//     var stream = fs.createReadStream(file);\n//     obj.then(function (obj) {\n//       assert.equal(obj.length, 2);\n//       done();\n//     },(err)=>{\n//       console.log(err.toString());\n//     });\n//     stream.pipe(obj);\n//   });\n\n//   it(\"should call onNext once a row is parsed.\", function (done) {\n//     var obj = new Converter({fork:true});\n//     var stream = fs.createReadStream(file);\n//     var called = false;\n//     obj.subscribe(function (resultRow) {\n//       assert(resultRow);\n//       called = true;\n//     });\n//     obj.on(\"done\", function () {\n//       assert(called);\n//       done();\n//     });\n//     stream.pipe(obj);\n//   });\n\n//   it(\"should emit end_parsed message once it is finished.\", function (done) {\n//     var obj = new Converter({fork:true});\n//     obj.then(function (result) {\n//       assert(result);\n//       assert(result.length === 2);\n//       assert(result[0].date);\n//       assert(result[0].employee);\n//       assert(result[0].employee.name);\n//       assert(result[0].employee.age);\n//       assert(result[0].employee.number);\n//       assert(result[0].employee.key.length === 2);\n//       assert(result[0].address.length === 2);\n//       done();\n//     });\n//     fs.createReadStream(file).pipe(obj);\n//   });\n\n//   it(\"should handle traling comma gracefully\", function (done) {\n//     var stream = fs.createReadStream(trailCommaData);\n//     var obj = new Converter({fork:true});\n//     obj.then(function (result) {\n//       assert(result);\n//       assert(result.length > 0);\n//       done();\n//     });\n//     stream.pipe(obj);\n//   });\n\n//   it(\"should handle comma in column which is surrounded by qoutes\", function (done) {\n//     var testData = __dirname + \"/data/dataWithComma\";\n//     var rs = fs.createReadStream(testData);\n//     var obj = new Converter({\n//       \"quote\": \"#\",\n//       \"fork\":true\n//     });\n//     obj.then(function (result) {\n//       assert(result[0].col1 === \"\\\"Mini. Sectt\");\n//       assert.equal(result[3].col2, \"125001,fenvkdsf\");\n//       // console.log(result);\n//       done();\n//     });\n//     rs.pipe(obj);\n//   });\n\n//   it(\"should be able to convert a csv to column array data\", function (done) {\n//     var columArrData = __dirname + \"/data/columnArray\";\n//     var rs = fs.createReadStream(columArrData);\n//     var result:any = {};\n//     var csvConverter = new Converter({fork:true});\n//     //end_parsed will be emitted once parsing finished\n//     csvConverter.then(function () {\n//       assert(result.TIMESTAMP.length === 5);\n//       done();\n//     });\n\n//     //record_parsed will be emitted each time a row has been parsed.\n//     csvConverter.subscribe(function (resultRow, rowIndex) {\n//       for (var key in resultRow) {\n//         if (resultRow.hasOwnProperty(key)) {\n//           if (!result[key] || !(result[key] instanceof Array)) {\n//             result[key] = [];\n//           }\n//           result[key][rowIndex] = resultRow[key];\n//         }\n//       }\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should be able to convert csv string directly\", function (done) {\n//     var testData = __dirname + \"/data/testData\";\n//     var data = fs.readFileSync(testData).toString();\n//     var csvConverter = new Converter({fork:true});\n//     //end_parsed will be emitted once parsing finished\n//     csvConverter.then(function (jsonObj) {\n//       assert.equal(jsonObj.length, 2);\n//     });\n//     csvConverter.fromString(data).then(function (jsonObj) {\n//       assert(jsonObj.length === 2);\n//       done();\n//     });\n//   });\n\n//   it(\"should be able to convert csv string with error\", function (done) {\n//     var testData = __dirname + \"/data/dataWithUnclosedQuotes\";\n//     var data = fs.readFileSync(testData).toString();\n//     var csvConverter = new Converter({fork:true});\n//     csvConverter.fromString(data).then(undefined, function (err) {\n//       // console.log(err);\n//       assert(err);\n//       assert.equal(err.err, \"unclosed_quote\");\n//       done();\n//     });\n//   });\n\n//   it(\"should be able to convert csv string without callback provided\", function (done) {\n//     var testData = __dirname + \"/data/testData\";\n//     var data = fs.readFileSync(testData).toString();\n//     var csvConverter = new Converter({fork:true});\n//     //end_parsed will be emitted once parsing finished\n//     csvConverter.then(function (jsonObj) {\n//       assert(jsonObj.length === 2);\n//       done();\n//     });\n//     csvConverter.fromString(data);\n//   });\n\n//   it(\"should be able to handle columns with double quotes\", function (done) {\n//     var testData = __dirname + \"/data/dataWithQoutes\";\n//     var data = fs.readFileSync(testData).toString();\n//     var csvConverter = new Converter({fork:true});\n//     csvConverter.fromString(data).then(function (jsonObj) {\n//       assert(jsonObj[0].TIMESTAMP === '13954264\"22', JSON.stringify(jsonObj[0].TIMESTAMP));\n\n//       assert(jsonObj[1].TIMESTAMP === 'abc, def, ccc', JSON.stringify(jsonObj[1].TIMESTAMP));\n//       done();\n//     });\n//   });\n\n//   it(\"should be able to handle columns with two double quotes\", function (done) {\n//     var testData = __dirname + \"/data/twodoublequotes\";\n//     var data = fs.readFileSync(testData).toString();\n//     var csvConverter = new Converter({fork:true});\n//     csvConverter.fromString(data).then(function (jsonObj) {\n//       assert.equal(jsonObj[0].title, \"\\\"\");\n//       assert.equal(jsonObj[0].data, \"xyabcde\");\n//       assert.equal(jsonObj[0].uuid, \"fejal\\\"eifa\");\n//       assert.equal(jsonObj[0].fieldA, \"bnej\\\"\\\"falkfe\");\n//       assert.equal(jsonObj[0].fieldB, \"\\\"eisjfes\\\"\");\n//       done();\n//     });\n//   });\n\n//   it(\"should handle empty csv file\", function (done) {\n//     var testData = __dirname + \"/data/emptyFile\";\n//     var rs = fs.createReadStream(testData);\n//     var csvConverter = new Converter({fork:true});\n//     csvConverter.then(function (jsonObj) {\n//       assert(jsonObj.length === 0);\n//       done();\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should parse large csv file\", function (done) {\n//     var testData = __dirname + \"/data/large-csv-sample.csv\";\n//     var rs = fs.createReadStream(testData);\n//     var csvConverter = new Converter({fork:true});\n//     var count = 0;\n//     csvConverter.subscribe(function () {\n//       // console.log(arguments);\n//       count++;\n//     });\n//     csvConverter.then(function () {\n//       assert.equal(count, 5290);\n//       done();\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should parse data and covert to specific types\", function (done) {\n//     var testData = __dirname + \"/data/dataWithType\";\n//     var rs = fs.createReadStream(testData);\n//     var csvConverter = new Converter({\n//       fork:true,\n//       checkType: true,\n//       colParser: {\n//         \"column6\": \"string\",\n//         \"column7\": \"string\"\n//       }\n//     });\n//     csvConverter.subscribe(function (d) {\n//       assert(typeof d.column1 === \"number\");\n//       assert(typeof d.column2 === \"string\");\n//       assert.equal(d[\"colume4\"], \"someinvaliddate\");\n//       assert(d.column5.hello === \"world\");\n//       assert(d.column6 === '{\"hello\":\"world\"}');\n//       assert(d.column7 === \"1234\");\n//       assert(d.column8 === \"abcd\");\n//       assert(d.column9 === true);\n//       assert(d.column10[0] === 23);\n//       assert(d.column10[1] === 31);\n//       assert(d.column11[0].hello === \"world\");\n//       assert(d[\"name#!\"] === false);\n//     });\n//     csvConverter.on(\"done\", function () {\n//       done();\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should turn off field type check\", function (done) {\n//     var testData = __dirname + \"/data/dataWithType\";\n//     var rs = fs.createReadStream(testData);\n//     var csvConverter = new Converter({\n//       fork:true,\n//       checkType: false\n//     });\n//     csvConverter.subscribe(function (d) {\n//       assert(typeof d.column1 === \"string\");\n//       assert(typeof d.column2 === \"string\");\n//       assert(d[\"column3\"] === \"2012-01-01\");\n//       assert(d[\"colume4\"] === \"someinvaliddate\");\n//       assert(d.column5 === '{\"hello\":\"world\"}');\n//       assert.equal(d[\"column6\"], '{\"hello\":\"world\"}');\n//       assert(d[\"column7\"] === \"1234\");\n//       assert(d[\"column8\"] === \"abcd\");\n//       assert(d.column9 === \"true\");\n//       assert(d.column10[0] === \"23\");\n//       assert(d.column10[1] === \"31\");\n//       assert(d[\"name#!\"] === 'false');\n//     });\n//     csvConverter.then(function () {\n//       done();\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should emit data event correctly\", function (done) {\n//     var testData = __dirname + \"/data/large-csv-sample.csv\";\n\n//     var csvConverter = new Converter({\n//       fork:true\n//     },{objectMode:true});\n//     var count = 0;\n//     csvConverter.on(\"data\", function (d) {\n//       count++;\n//     });\n//     csvConverter.on(\"done\", function () {\n//       assert.equal(csvConverter.parsedLineNumber, 5290);\n//       done();\n//     });\n//     var rs = fs.createReadStream(testData);\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"should process column with linebreaks\", function (done) {\n//     var testData = __dirname + \"/data/lineBreak\";\n//     var rs = fs.createReadStream(testData);\n//     var csvConverter = new Converter({\n//       fork:true,\n//       checkType: true\n//     });\n//     csvConverter.subscribe(function (d) {\n//       assert(d.Period === 13);\n//       assert(d[\"Apparent age\"] === \"Unknown\");\n//       done();\n//     });\n//     rs.pipe(csvConverter);\n//   });\n\n//   it(\"be able to ignore empty columns\", function (done) {\n//     var testData = __dirname + \"/data/dataIgnoreEmpty\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(csv({ \n//       ignoreEmpty: true ,\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 3);\n//       assert(j.col2.length === 2);\n//       assert(j.col2[1] === \"d3\");\n//       assert(j.col4.col3 === undefined);\n//       assert(j.col4.col5 === \"world\");\n//       assert(res[1].col1 === \"d2\");\n//       assert(res[2].col1 === \"d4\");\n//       done();\n//     });\n//   });\n\n//   it(\"should allow no header\", function (done) {\n//     var testData = __dirname + \"/data/noheadercsv\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(new Converter({ \n//       noheader: true,\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 5);\n//       assert(j.field1 === \"CC102-PDMI-001\");\n//       assert(j.field2 === \"eClass_5.1.3\");\n//       done();\n//     });\n//   });\n\n//   it(\"should allow customised header\", function (done) {\n//     var testData = __dirname + \"/data/noheadercsv\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(new Converter({\n//       noheader: true,\n//       headers: [\"a\", \"b\"],\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 5);\n//       assert(j.a === \"CC102-PDMI-001\");\n//       assert(j.b === \"eClass_5.1.3\");\n//       assert(j.field3 === \"10/3/2014\");\n//       done();\n//     });\n//   });\n\n//   it(\"should allow customised header to override existing header\", function (done) {\n//     var testData = __dirname + \"/data/complexJSONCSV\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(new Converter({\n//       headers: [],\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 2);\n//       assert(j.field1 === \"Food Factory\");\n//       assert(j.field2 === \"Oscar\");\n//       done();\n//     });\n//   });\n\n//   it(\"should handle when there is an empty string\", function (done) {\n//     var testData = __dirname + \"/data/dataWithEmptyString\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(new Converter({\n//       noheader: true,\n//       headers: [\"a\", \"b\", \"c\"],\n//       checkType: true,\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n\n//       // assert(res.length===2);\n//       assert(j.a === \"green\");\n//       assert(j.b === 40);\n//       assert.equal(j.c, \"\");\n//       done();\n//     });\n//   });\n\n//   it(\"should detect eol correctly when first chunk is smaller than header row length\", function (done) {\n//     var testData = __dirname + \"/data/dataNoTrimCRLF\";\n//     var rs = fs.createReadStream(testData, { highWaterMark: 3 });\n\n//     var st = rs.pipe(new Converter({\n//       trim: false,\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 2);\n//       assert(j.name === \"joe\");\n//       assert(j.age === \"20\");\n//       assert.equal(res[1].name, \"sam\");\n//       assert.equal(res[1].age, \"30\");\n//       done();\n//     });\n//   });\n\n//   it(\"should detect eol correctly when first chunk ends in middle of CRLF line break\", function (done) {\n//     var testData = __dirname + \"/data/dataNoTrimCRLF\";\n//     var rs = fs.createReadStream(testData, { highWaterMark: 9 });\n\n//     var st = rs.pipe(new Converter({\n//       trim: false,\n//       fork:true\n//     }));\n//     st.then(function (res) {\n//       var j = res[0];\n//       assert(res.length === 2);\n//       assert(j.name === \"joe\");\n//       assert(j.age === \"20\");\n//       assert.equal(res[1].name, \"sam\");\n//       assert.equal(res[1].age, \"30\");\n//       done();\n//     });\n//   });\n\n//   it(\"should emit eol event when line ending is detected as CRLF\", function (done) {\n//     var testData = __dirname + \"/data/dataNoTrimCRLF\";\n//     var rs = fs.createReadStream(testData);\n\n//     var st = rs.pipe(new Converter({\n//       fork:true\n//     }));\n//     var eolCallback = sandbox.spy(function (eol) {\n//       assert.equal(eol, \"\\r\\n\");\n//     });\n//     st.on(\"eol\", eolCallback);\n//     st.then(function () {\n//       assert.equal(eolCallback.callCount, 1, 'should emit eol event once');\n//       done();\n//     })\n//   });\n\n//   it(\"should emit eol event when line ending is detected as LF\", function (done) {\n//     var testData = __dirname + \"/data/columnArray\";\n//     var rs = fs.createReadStream(testData);\n\n//     var st = rs.pipe(new Converter({\n//       fork:true\n//     }));\n//     var eolCallback = sandbox.spy(function (eol) {\n//       assert.equal(eol, \"\\n\");\n//     });\n//     st.on(\"eol\", eolCallback);\n//     st.then(function () {\n//       assert.equal(eolCallback.callCount, 1, 'should emit eol event once');\n//       done();\n//     })\n//   });\n\n//   it(\"should remove the Byte Order Mark (BOM) from input\", function (done) {\n//     var testData = __dirname + \"/data/dataNoTrimBOM\";\n//     var rs = fs.createReadStream(testData);\n//     var st = rs.pipe(new Converter({\n//       trim: false,\n//       fork:true\n//     }));\n//     st.then( function (res) {\n//       var j = res[0];\n\n//       assert(res.length===2);\n//       assert(j.name === \"joe\");\n//       assert(j.age === \"20\");\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\",fork:true })\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//   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({fork:true}, { 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//   it(\"should parse #139\", function (done) {\n//     var rs = fs.createReadStream(__dirname + \"/data/data#139\");\n//     csv({fork:true})\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//       fork:true\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//         // console.log(j);\n//         assert(!j.TIMESTAMP);\n//         assert(idx >= 0);\n//       })\n//       .on(\"done\", function (err) {\n//         assert(!err);\n//         assert(headerEmitted);\n//         done();\n//       });\n//   });\n//   it(\"should include column\", function (done) {\n//     var rs = fs.createReadStream(__dirname + \"/data/dataWithQoutes\");\n//     csv({\n//       includeColumns: /TIMESTAMP/,\n//       fork:true\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//   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//       fork:true\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//       fork:true\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//   it(\"should accept pipe as quote\", function (done) {\n//     csv({\n//       quote: \"|\",\n//       output: \"csv\",\n//       \"fork\":true\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(\"should allow async subscribe function\", () => {\n//     return csv({ trim: true,fork: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 omit a column\", () => {\n//     return csv({\n//       colParser: {\n//         \"a\": \"omit\"\n//       },\n//       fork:true\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  \n// });\n"]}
|