diff --git a/src/optionsUtils.js b/src/optionsUtils.js index ecad8e2..d441e42 100644 --- a/src/optionsUtils.js +++ b/src/optionsUtils.js @@ -32,7 +32,7 @@ const optionsSchema = object({ }); const defaultOptions = { - filter: /(^.*[/\\]node_modules[/\\]((?:@[^/\\]+[/\\])?(?:[^/\\]+)))/, + filter: /(^.*[/\\]node_modules[/\\]((?:@[^/\\]+[/\\])?(?:[^@/\\][^/\\]*)))/, allow: "(Apache-2.0 OR BSD-2-Clause OR BSD-3-Clause OR MIT)", ignore: [], override: {}, diff --git a/src/optionsUtils.spec.js b/src/optionsUtils.spec.js index 979748f..eae2112 100644 --- a/src/optionsUtils.spec.js +++ b/src/optionsUtils.spec.js @@ -47,3 +47,42 @@ describe("getOptions", () => { ); }); }); + +describe("defaults behaviour", () => { + const { filter } = getOptions(); + + test.each([ + // Modules are things under node_modules + ["/base/node_modules/a-proj/dist/index.js", ["/base/node_modules/a-proj", "a-proj"]], + ["/base/node_modules/a-proj/dist", ["/base/node_modules/a-proj", "a-proj"]], + ["/base/node_modules/a-proj", ["/base/node_modules/a-proj", "a-proj"]], + ["/base/node_modules", null], + ["/base", null], + ["/", null], + // Scoped names have two parts + ["/base/node_modules/@babel/runtime/", ["/base/node_modules/@babel/runtime", "@babel/runtime"]], + ["/base/node_modules/@babel", null], + // Modules can be nested and deepest is retrieved + [ + "/base/node_modules/a-proj/node_modules/b-proj/index.js", + ["/base/node_modules/a-proj/node_modules/b-proj", "b-proj"] + ], + [ + "/base/node_modules/@a/proj/node_modules/b-proj/index.js", + ["/base/node_modules/@a/proj/node_modules/b-proj", "b-proj"] + ], + [ + "/base/node_modules/@a/proj/node_modules/@b/proj/src/index.mjs", + ["/base/node_modules/@a/proj/node_modules/@b/proj", "@b/proj"] + ], + [ + "/base/node_modules/a-proj/node_modules/@b/proj/src/index.mjs", + ["/base/node_modules/a-proj/node_modules/@b/proj", "@b/proj"] + ], + // Backslashes are allowed as separators + ["C:\\No\\node_modules\\a-proj\\dist\\index.js", ["C:\\No\\node_modules\\a-proj", "a-proj"]] + ])("filter %#", (path, expected) => { + const result = filter.exec(path); + expect(result ? result.slice(1) : result).toEqual(expected); + }); +});