Relecture du script de tests du parseur CSV.

This commit is contained in:
Fabrice PENHOËT 2021-10-04 16:10:54 +02:00
parent b13be8afeb
commit d7d9885b2b

View File

@ -3,37 +3,15 @@ import { RemoteSource } from "../src/freeDatas2HTMLInterfaces";
import { ParserForCSV as Parser } from "../src/freeDatas2HTMLParserForCSV"; import { ParserForCSV as Parser } from "../src/freeDatas2HTMLParserForCSV";
const errors=require("../src/errors.js"); const errors=require("../src/errors.js");
// Pas de test de Papa Parse, car module externe // Pas de test de Papa Parse lui-même, car il s'agit d'un module externe.
// Mais tests d'instanciation et configuration de la classe l'utilisant // Mais tests de la classe l'utilisant.
describe("Tests du parseur de CSV", () => describe("Tests du parseur de CSV", () =>
{ {
let parser: Parser; let parser: Parser;
let papaParseOptions: {};
beforeEach( () => beforeEach( () =>
{ {
parser=new Parser(); parser=new Parser();
papaParseOptions =
{
delimiter: "",
newline: "",
quoteChar: '"',
escapeChar: '"',
header: true,
transformHeader: function(field: string, index: number): string { return field.trim() },
preview: 0,
comments: "",
complete: function(results :any)
{
console.log(results);// peut importe cette partie pour les tests
},
download: undefined,
downloadRequestHeaders: undefined,
skipEmptyLines:"greedy",
fastMode: undefined,
withCredentials: undefined,
transform: undefined,
}
}); });
it("Doit avoir créé une instance du Parser", () => it("Doit avoir créé une instance du Parser", () =>
@ -77,7 +55,7 @@ describe("Tests du parseur de CSV", () =>
it("Si les données sont directement fournies, cela doit être pris en compte dans les options passées à Papa Parse.", () => it("Si les données sont directement fournies, cela doit être pris en compte dans les options passées à Papa Parse.", () =>
{ {
// Idéalement il faudrait tester les paramètres passés à PapaParse // Idéalement il faudrait tester les paramètres passés à PapaParse
// Mais semble impossible à cause des fonctions callback ? // Mais semble impossible à cause des fonctions callback ?!
spyOn(Papa, "parse"); spyOn(Papa, "parse");
parser.datas2Parse="datas"; parser.datas2Parse="datas";
parser.parse(); parser.parse();
@ -125,10 +103,12 @@ describe("Tests du parseur de CSV", () =>
parser.datasRemoteSource={ url:"http://localhost:9876/datas/datas1.csv" }; parser.datasRemoteSource={ url:"http://localhost:9876/datas/datas1.csv" };
await parser.parse(); await parser.parse();
expect(parser.parseResults).not.toBeUndefined(); expect(parser.parseResults).not.toBeUndefined();
// Y compris si données fournies bidon : // Y compris si les données fournies sont bidon :
parser=new Parser(); parser=new Parser();
parser.datas2Parse="datas"; parser.datas2Parse="datas";
await parser.parse(); await parser.parse();
expect(parser.parseResults).not.toBeUndefined(); expect(parser.parseResults).not.toBeUndefined();
// Mais dans ce cas, des erreurs doivent être reportées :
expect(parser.parseResults.errors.length).not.toEqual(0);
}); });
}); });