-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weβll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support Not applying strict* checks to node_modules / imported libraries. #44205
Comments
This is very likely the same as #31035. |
This is much more narrow in scope than #31035. Although, solving #31035 would indeed solve this issue. The main differences:
The aim is that these limitations narrow the scope enough for the feature to be implementable. A minimal proposed configuration would be a new compiler option: Any additional configuration beyond this is out of scope. As I am unaware of the internals of typescript, I omitted the following possible improvements from consideration:
|
The problem I have with this, above and beyond the concerns/limitations described in #31035, is that this is ultimately (at least for now) a pure configuration error. You might be able to flag your way out of some of the problems here but there isn't a solution that would, for example, stop tsc from trying to emit The most straightforward escape hatch for this misconfiguration is something more like an option to say "all files outside my If you have folders that are separate compilation units that aren't external code (i.e. I don't think we should do work to enable a scenario like this that's ultimately doomed to be unacceptably suboptimal. |
@RyanCavanaugh Is there -any- work-around, good-or-hack, that you can think of to allow us to enable Now, none of our projects can enable The published packages are 100% TypeScript; the Issues in the third-party packages seem mostly minor, such as:
There are seemingly hundreds of errors emitted against third-party libraries when |
@icywolfy I don't know what to tell you; this is only one of many ways that a dependency that doesn't want to configure itself properly could cause downstream damage (e.g. they could also be doing something bad at runtime; this is out of everyone's control). If these are public packages I can try talking to them? |
I've done a bunch of cleanup of my code so that I could enable strict mode, only to find out that 1 library in node_modules ships as .ts instead of .d.ts, and does not compile in strict mode. Had I known in advance that this would be a problem, I might've found another library, but by now, it's already integrated into the project and has "poisoned the well", so to speak. Makes me sad that now I can't enable strict mode for just my own code. |
having been in a similar situation, i seriously considered adding a postinstall script which patches the libraries inside node_modules... |
What are the criteria for "unacceptably" here? It feels to me like this is at high risk of allowing the quest for perfection to become the enemy of the good. It's a lot better to be able to disable See also #40426 (comment) |
I came here through a web search, and I think this is what I am running into. It seems I have stricter configuration options enabled than some dependencies of mine (both direct dependencies or transitive ones). TypeScript seems to want to apply my rules to code it finds in I would rather not loosen my configuration to accommodate for code that is not mine, nor do I have any singular influence to tell every project that happens to end up a dependency of mine to develop to my standard. I imagine these projects have their own configurations that their code adheres to, so suspending technical feasibility for a moment would it be a decent idea to only apply the nearest configuration to any given TypeScript file? I bring it up because the other options seem to be trying to strong-arm library developers into doing X or Y, and regardless of right or wrong in my experience no one takes kindly to trying to be strong-armed. Meanwhile, people who are just trying to work on their own TypeScript projects end up blocked or reducing their own standards due to some dependency that got pulled in somewhere along the way - unless they can fully track down where it came from and search for alternative libraries whose entire dependency tree adheres to the "rules". That latter bit seems like an unfair request to make of people who just want to use TypeScript in their project. For me, this is a show-stopper as many of these errors come from transitive dependencies whose "ground zero" is a primary technology choice of mine. I am unwilling to just give up my tech choice over this issue, so my options are to shelve the project until resolution or to remove TypeScript from the project. Neither seem all that appealing, but a product built without TypeScript does seem marginally better than no product at all. |
π Search Terms
node_modules
exclude
alwaysStrict
β Viability Checklist
My suggestion meets these guidelines:
β Suggestion
Allow compiler options that enable strict checking to only apply to project files only, and not imported modules.
[Edit 3] It is ideal if this can be expanded to suppress linter checks on node_modules, as well a strict checks.
[Edit 2]
A implementation proposal:
Provide a new configuration option
--noStrictCheckOnNodeModule
. This flag will prevent errors emitting on files referenced via**/node_modules/**
. This may be further restricted to if the real-path of fire either within**/node_modules/**
or outside the Project Root. Project Root may defined as the location of package.json. No additional configuration is possible. All strict mode checks are suppressed for these files.π Motivating Example
A project imports a npm package, that contains .ts files.
Project compiles, and types are coherent.
Attempting to enable
noImplictReturns
, finds errors in thenode_modules/
in an included project, and fails to compile.The typing in the third-party library is correct:
public static getTrigger(): undefined | "load" => { if (check()) return "load"; }
Though, the method has an implicit return.
I see no reason why the project should fail to compile, especially in this case, where the difference between
return undefined
and/* implicit return undefined */
is effectively a style issue with no impact on typing or behaviour. Doubly so, in that the errors are found in a third-party library, in code that is otherwise unused.The above is a trivial example, but highlights the issue.
π» Use Cases
The primary use case, is to include strict type checking within a project.
The project in question is a library, and not an application.
The project was originally written with all strict checks enabled.
Over time, as more libraries publish only raw
ts
files (1), our project had to disable strict checks one by one, in order to compile.At this point in time, the project is unable to enable any strict type checking, or linter checks at all, lest
tsc
report errors within thenode_modules
directory.The main shortcomings, is that
tsc
can no longer be used to enforce strict adherence to guidelines, due to changes in third-party libraries. This has immediate impact on code quality. In particular, being unable to enablestrictNullChecks
on our library due to third-party library code, has negatively impacted code quality over time.Currently, no workarounds have been found.
The best effort currently, is to check out a PR; enable all strict typings; sift through pages of reported errors, and attempt to find those not in
node_modules
. And then approve or deny based on whether any "real errors" were found. This leaves much room for error, and not all developers or reviewers may be diligent in finding a "real error". Whereas, it would be ideal for these sorts of errors to be reported at develop time, or on the build server.(1) Against guidelines, an increasing number of libraries only publishing raw ts files, without providing any
.js
files. In these libraries,package.json
refer to.ts
files directly.(2) This appears to be a common request on stack overflow, and elsewhere:
Change History:
noImplicitReturn
was in a different category thanStrict Checks
.The text was updated successfully, but these errors were encountered: