fix some parsing's issues

This commit is contained in:
Amaury 2021-02-14 15:00:33 +01:00
parent c5c2c1ad80
commit 8a6eb338ef
4 changed files with 58 additions and 50 deletions

View File

@ -1,14 +1,14 @@
export default class ListenerRSSInfos {
export class ListenerRSSInfos {
_name: string = ""; // name of the listener
_address: string = ""; // feed's address
_timeloop: number | undefined = 5 * 60; // update time RSS feed
_customfields: string[][] | undefined = []; // rss fields custom
_customfields: [string, string | [string, string]][] | undefined = undefined; // rss fields custom
constructor(
name: string,
address: string,
timeloop?: number,
customfields?: string[][]
customfields?: [string, string | [string, string]][]
) {
if (name !== undefined && address !== undefined) {
this._name = name;

View File

@ -1,8 +1,2 @@
import ListenerRss from "./listener-rss";
import ListenerRSSInfo from "./Models/ListenerRSSInfos";
// TODO J'ai des erreurs sur les imports, que je ne comprend pas trop
module.exports = {
ListenerRss: ListenerRss,
ListenerRSSInfo: ListenerRSSInfo,
};
export { ListenerRss } from "./listener-rss";
export { ListenerRSSInfos } from "./Models/ListenerRSSInfos";

View File

@ -1,13 +1,13 @@
import Parser from "rss-parser";
import ListenerInfo from "./Models/ListenerRSSInfos";
import * as Parser from "rss-parser/index";
import { ListenerRSSInfos as ListenerInfo } from "./Models/ListenerRSSInfos";
const DEFAULT_TIMELOOP = 5 * 60; // default timeloop is 5 min
const DEFAULT_TIMELOOP: number = 5 * 60; // default timeloop is 5 min
export default class ListenerRss {
name = "";
address = "";
timeloop = DEFAULT_TIMELOOP; // time in seconds
customfields = [];
export class ListenerRss {
name: string = "";
address: string = "";
timeloop: number = DEFAULT_TIMELOOP; // time in seconds
customfields: [string, string | [string, string]][] | undefined = undefined;
// private fields
parser: Parser | undefined = undefined;
@ -17,9 +17,9 @@ export default class ListenerRss {
name: string | ListenerInfo,
address?: string,
timeloop?: number,
customfields?: string[][]
customfields?: [string, string | [string, string]][]
) {
if (name !== undefined && name instanceof ListenerInfo) {
if (name instanceof ListenerInfo) {
// constructor with 1 arg
this.setData(name);
} else if (address !== undefined) {
@ -51,7 +51,7 @@ export default class ListenerRss {
this.timeloop =
infos._timeloop === undefined ? DEFAULT_TIMELOOP : infos._timeloop;
this.customfields =
infos._customfields === undefined ? [] : infos._customfields;
infos._customfields === undefined ? undefined : infos._customfields;
}
fetchRSS(): any {

View File

@ -1,18 +1,20 @@
// external lib
import Parser from "rss-parser";
import * as Parser from "rss-parser";
// tested class
import {
ListenerRSSInfos as ListenerRRSInfo,
ListenerRss as Listeners,
ListenerRSSInfo as ListenerRRSInfo,
} from "/src/index"; // TODO import bloque ?? not found
} from "./../src/index";
// Unit test
import chai from "chai";
import sinon from "ts-sinon";
import sinon_chai from "sinon-chai";
import { SinonSpy } from "sinon";
chai.use(sinon_chai);
import * as chai from "chai";
import * as sinon from "ts-sinon";
//import sinonChai from "sinon-chai";
const sinonChai = require("sinon-chai");
chai.use(sinonChai);
const expect = chai.expect;
@ -30,7 +32,7 @@ describe("test class RSS: jsonfile", function () {
);
// parseURL tests
let stubParser: sinon.SinonStub;
let stubParser: sinon.StubbedInstance<Parser>;
const mockedRSSOutput: any = {
// TODO any = pas bien
items: [
@ -72,11 +74,14 @@ describe("test class RSS: jsonfile", function () {
beforeEach(function () {
// stubs
stubParser = sinon.stub(Parser.prototype, "parseURL");
stubParser.withArgs(infosListener.address).resolves(mockedRSSOutput);
stubParser
stubParser = sinon.stubObject<Parser>(Parser.prototype, ["parseURL"]);
stubParser.parseURL
.withArgs(infosListener.address)
.resolves(mockedRSSOutput);
stubParser.parseURL
.withArgs("bad.rss.service")
.resolves(new Error("connect ECONNREFUSED 127.0.0.1:80"));
.rejects(new Error("connect ECONNREFUSED 127.0.0.1:80"));
// constructor
myListener = undefined;
@ -84,7 +89,6 @@ describe("test class RSS: jsonfile", function () {
afterEach(function () {
// restore stubs
stubParser.restore();
});
describe("Building Ytb listener", function () {
@ -100,10 +104,11 @@ describe("test class RSS: jsonfile", function () {
["description", ["media:group", "media:description"]],
["icon", ["media:group", "media:thumbnail"]],
]);
/* // TODO test des champs dans l'objet parser
expect(myListener.parser.options.customFields).to.eql({
feed: [],
item: ["media:group", "media:group"],
});
});*/
});
it("The build without issues (raw infos : 4 params)", function () {
myListener = new Listeners("my-test-service", "fake.rss.service", 15, [
@ -120,10 +125,11 @@ describe("test class RSS: jsonfile", function () {
["description", ["media:group", "media:description"]],
["icon", ["media:group", "media:thumbnail"]],
]);
/*
expect(myListener.parser.options.customFields).to.eql({
feed: [],
item: ["media:group", "media:group"],
});
});*/
});
it("The build without issues (raw infos : just 2 params)", function () {
myListener = new Listeners("my-test-service", "fake.rss.service");
@ -133,11 +139,12 @@ describe("test class RSS: jsonfile", function () {
expect(myListener.timeloop).to.eql(5 * 60);
expect(myListener.name).to.eql("my-test-service");
expect(myListener.address).to.eql("fake.rss.service");
expect(myListener.customfields).to.eql([]);
expect(myListener.customfields).to.eql(undefined);
/*
expect(myListener.parser.options.customFields).to.eql({
feed: [],
item: [],
});
});*/
});
it("The build without issues (raw infos : just 3 params (no custom fields))", function () {
myListener = new Listeners("my-test-service", "fake.rss.service", 15);
@ -147,11 +154,12 @@ describe("test class RSS: jsonfile", function () {
expect(myListener.timeloop).to.eql(15);
expect(myListener.name).to.eql("my-test-service");
expect(myListener.address).to.eql("fake.rss.service");
expect(myListener.customfields).to.eql([]);
expect(myListener.customfields).to.eql(undefined);
/*
expect(myListener.parser.options.customFields).to.eql({
feed: [],
item: [],
});
});*/
});
it("The build without issues (raw infos : just 3 params (no timeloop))", function () {
myListener = new Listeners(
@ -173,10 +181,11 @@ describe("test class RSS: jsonfile", function () {
["description", ["media:group", "media:description"]],
["icon", ["media:group", "media:thumbnail"]],
]);
/*
expect(myListener.parser.options.customFields).to.eql({
feed: [],
item: ["media:group", "media:group"],
});
});*/
});
});
@ -184,13 +193,17 @@ describe("test class RSS: jsonfile", function () {
it("fetch without issues", function () {
// classic build
myListener = new Listeners(infosListener);
myListener.parser = stubParser; // replace the parser by my fake parser
// fetch
let res = myListener.fetchRSS();
//assertion
// calls
expect(stubParser).to.have.been.calledOnce;
expect(stubParser).to.have.been.calledWith(infosListener._address);
expect(stubParser.parseURL).to.have.been.calledOnce;
expect(stubParser.parseURL).to.have.been.calledWith(
infosListener._address
);
// Promise
//await expect(Promise.resolve(res)).to.be.eql(mockedRSSOutput);
res.then((obj: any, err: Error) => {
@ -210,13 +223,14 @@ describe("test class RSS: jsonfile", function () {
["icon", ["media:group", "media:thumbnail"]],
]
);
myListener.parser = stubParser; // replace the parser by my fake parser
// fetch
let res = myListener.fetchRSS();
//assertion
// calls
expect(stubParser).to.have.been.calledOnce;
expect(stubParser).to.have.been.calledWith("bad.rss.service");
expect(stubParser.parseURL).to.have.been.calledOnce;
expect(stubParser.parseURL).to.have.been.calledWith("bad.rss.service");
// Promise
res.then((obj: any, err: Error) => {
expect(obj).to.be.undefined;
@ -225,7 +239,7 @@ describe("test class RSS: jsonfile", function () {
});
});
describe("start", function () {
describe.skip("start", function () {
it("Let's start the timer", async function () {
//custom timeout
this.timeout(15000);
@ -237,7 +251,7 @@ describe("test class RSS: jsonfile", function () {
]);
//spy
const fun_spy: SinonSpy = sinon.spy();
const fun_spy: sinon.default.SinonSpy = sinon.default.spy();
// start timer
myListener.start(fun_spy);
@ -263,7 +277,7 @@ describe("test class RSS: jsonfile", function () {
]);
//spy
const fun_spy: SinonSpy = sinon.spy();
const fun_spy: sinon.default.SinonSpy = sinon.default.spy();
// start timer
myListener.start(fun_spy);