From f2a86201799af5842e1339c22950abbb3db00f51 Mon Sep 17 00:00:00 2001 From: Alexander Fenster Date: Mon, 21 Aug 2023 10:31:54 -0700 Subject: [PATCH] fix: possible infinite loop when parsing option (#1923) --- bench/prof.js | 4 ++-- cli/lib/tsd-jsdoc/publish.js | 2 +- src/converter.js | 4 ++-- src/parse.js | 5 ++++- tests/cli.js | 4 +--- tests/comp_options-parse.js | 5 +++++ 6 files changed, 15 insertions(+), 9 deletions(-) diff --git a/bench/prof.js b/bench/prof.js index 4c3497a6d..d81915b3c 100644 --- a/bench/prof.js +++ b/bench/prof.js @@ -86,14 +86,14 @@ function setupBrowser() { switch (process.argv[2]) { case "encode-browser": setupBrowser(); - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough case "encode": for (var i = 0; i < count; ++i) Test.encode(data).finish(); break; case "decode-browser": setupBrowser(); - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough case "decode": var buf = Test.encode(data).finish(); for (var j = 0; j < count; ++j) diff --git a/cli/lib/tsd-jsdoc/publish.js b/cli/lib/tsd-jsdoc/publish.js index 3846a992e..f6dab9982 100644 --- a/cli/lib/tsd-jsdoc/publish.js +++ b/cli/lib/tsd-jsdoc/publish.js @@ -438,7 +438,7 @@ function handleElement(element, parent) { handleEnum(element, parent); break; } - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough case "namespace": handleNamespace(element, parent); break; diff --git a/src/converter.js b/src/converter.js index c9e68b5be..086e00307 100644 --- a/src/converter.js +++ b/src/converter.js @@ -62,7 +62,7 @@ function genValuePartial_fromObject(gen, field, fieldIndex, prop) { break; case "uint64": isUnsigned = true; - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough case "int64": case "sint64": case "fixed64": @@ -176,7 +176,7 @@ function genValuePartial_toObject(gen, field, fieldIndex, prop) { break; case "uint64": isUnsigned = true; - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough case "int64": case "sint64": case "fixed64": diff --git a/src/parse.js b/src/parse.js index ebb8b9c42..739f3265e 100644 --- a/src/parse.js +++ b/src/parse.js @@ -227,7 +227,7 @@ function parse(source, root, options) { break; case "public": next(); - // eslint-disable-line no-fallthrough + // eslint-disable-next-line no-fallthrough default: whichImports = imports || (imports = []); break; @@ -621,6 +621,9 @@ function parse(source, root, options) { if (!nameRe.test(token = next())) { throw illegal(token, "name"); } + if (token === null) { + throw illegal(token, "end of input"); + } var value; var propName = token; diff --git a/tests/cli.js b/tests/cli.js index 11f32a0f1..4e27dfc80 100644 --- a/tests/cli.js +++ b/tests/cli.js @@ -192,8 +192,6 @@ tape.test("pbjs generates static code with message filter", function (test) { var $protobuf = protobuf; eval(jsCode); - console.log(protobuf.roots); - var NeedMessage1 = protobuf.roots.default.filtertest.NeedMessage1; var NeedMessage2 = protobuf.roots.default.filtertest.NeedMessage2; var DependentMessage1 = protobuf.roots.default.filtertest.DependentMessage1; @@ -201,7 +199,7 @@ tape.test("pbjs generates static code with message filter", function (test) { var NotNeedMessageInRootFile = protobuf.roots.default.filtertest.NotNeedMessageInRootFile; var NotNeedMessageInImportFile = protobuf.roots.default.NotNeedMessageInImportFile; - + test.ok(NeedMessage1, "NeedMessage1 is loaded"); test.ok(NeedMessage2, "NeedMessage2 is loaded"); test.ok(DependentMessage1, "DependentMessage1 is loaded"); diff --git a/tests/comp_options-parse.js b/tests/comp_options-parse.js index 18690a424..ed4a00572 100644 --- a/tests/comp_options-parse.js +++ b/tests/comp_options-parse.js @@ -157,5 +157,10 @@ tape.test("Options", function (test) { test.end(); }); + test.test(test.name + " - invalid option", function (test) { + test.throws(() => { protobuf.parse("option (foo).whatever = {")}); + test.end(); + }); + test.end(); });