-
Notifications
You must be signed in to change notification settings - Fork 12k
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
Angular 5: NPM Link - model/index.ts is not part of the compilation. #8284
Comments
I can report a similar issue.
Was previously working fine with Angular 4.4.6 and Angular CLI 1.4.7 I'll try to create a minimal repo to reproduce the issue once I get home. |
yes i m also faced this issue . |
me too |
Same here - without npm link, but with dependencies on typescript libraries in other git repositories |
I've been testing with several version combinations to flush this out and it seems like it's the CLI causing it. I'm running v1.5.0 with Angular on v5.0.0 final and a similar error shows. Rolling the CLI back to rc8 fixes it. Then I reverted 9b43a9c manually and the error subsides. |
I've found that I only get the problem with |
I can confirm what @diagramatics said about rolling back to rc8 working, but I didn't get the same joy from reverting 9b43a9c |
Hey all, this is a side effect of the stricter tsconfig as described in https://blog.angular.io/version-5-0-0-of-angular-now-available-37e414935ced#148d. The tsconfig file is what determines what TS files are compiled. The error you are getting means that the files mentioned are NOT being compiled. Before we used to compile all files, essentially ignoring what tsconfig listed. This was a bug, because if you don't include a file in the compilation then it should not be compiled. By default So for @thaoula's case, you probably want to add this the files in
You can read more about tsconfig files in https://github.com/Microsoft/TypeScript-Handbook/blob/master/pages/tsconfig.json.md. @rolaveric's case is slightly different. You have TS files in your The reason for this rule is that the TypeScript version your app isn't necessarily the same as the TS version your library uses. Different versions of TS can produce different output, and give different errors for the same input. They don't even support the same language features. So packaging libraries with TS sources will always break someone's project. So we don't really support using incorrectly packaged libraries with TS sources. It's something you do at your risk. That being said, maybe you can try adding it to the include array. But I can't guarantee that will work in the future because it's still an incorrectly packaged library. Regarding AOT: as far as I can tell, AOT is still incorrectly compiling TS that is not included in the tsconfig. I'll bring this up with the compiler team. (Edit: reported as angular/angular#20115) |
We have the same problem described by @thaoula , but for a file that is located inside the normal tree structure created by the angular-cli. The error occurs with angular 5.0.0 final and angular-cli 1.5. We can "ng serve" the app with angular 5.0.0 and angular-cli 1.4.4. The file that is not part of the compilation in our project is located at: We never included or excluded files using tsconfig.json so it doesn't seem that the problem comes from the stricker tsconfig usage describeb above. To make sure, I created an empty project using angular-cli 1.5.0 and replaced the tsconfig.json and tsconfig.app.json files in our project with the ones created by the new cli and it didn't solve the problem. Another thing we have in commun with @thaoula is that the file that is not included in the compilation only contains interface and class definitions. So there might be something with that. |
@MakesNine that sounds like a different issue altogether, and one that we thought was fixed. Could you give me a repro of that please? |
We are having a similar issue, as well, after upgrading. It is complaining about all of our library packages under node_modules with this same exact error (all packages are installed with NPM so no links). Are we going to have to "include" each package separately in the tsconfig file? This would be a nightmare if its true, now and for maintenance in the future. Is there another solution or something else we can do first before using this new version which obviously breaks us completely? |
@filipesilva I have been trying to reproduce the problem in a small project, but I haven't succeded so far. I will keep trying to isolate the problem to find the source of it. Here's the exact error I'm getting: ERROR in ./src/app/core/StateManagement/models/genericCourse.models.ts |
@MakesNine so if you try having a file with just interfaces it's still fine in a new project? Hm... I've heard of problems with casing. Are your imports perhaps using the wrong casing? Does it still happen if you add a non-interface export to that file? That seems to be a lazy route, perhaps it's related. Can you try making that route not lazy? @KevinFernandes this definitely shouldn't happen to all library packages, unless somehow you're just using packages that weren't packaged well. Can you give me examples of a couple of these packages? I can have a look. |
@filipesilva yest, I can build a new project and import a file with only interfaces from a lazy loaded module. I will double check the casing and try the original app with a non lazy route for the module where the error originates. |
@filipesilva I have added an import and exported a function from the file refusing to be part of the compilation and it didn't help. |
Thanks @filipesilva - that explains my issue. Thanks again to you and all the contributors for your hard work on Angular CLI - it's an excellent tool and very much appreciated. |
I was having the same issue after updating. Like some other people, the ts files were all part of the standard CLI structure tree. Turned out it was a case sensitivity issue for me. I had accidentally written something like...
|
I finally got my app to compile. It turned out that it was a casing issue indeed. And the solution is to change the related import to: Curiously, I have other files in that folder that were also imported with StateMangement in the path and the compiler didn't complain. Thansk for your input @filipesilva |
We got the same problem when importing the modules. |
Previously our shared libs did not have a dedicated dist folder where the compiled JS would go. This setup introduces problems down the road and is discouraged. See: angular/angular-cli#8284 (comment) This change migrates all shared libs to the new layout.
I have this issue....this issue sucks :( this is how I solved it for local development: https://stackoverflow.com/questions/48797135/missing-ts-files-due-to-npm-link/48798373#48798373 |
@filipesilva. I am facing the same issue Just to summarize, we have a large project. So 1 project is used as library and sits in the node_modules folder. When on Angular 4 it works fine but when upgraded it is throwing me this error: Module build failed: XXX file is missing in Typescript compilation. Please make sure it is in your tsconfig via the 'files' or 'include' property. I have read this whole ticket and specially implemented what you suggested of manually adding it in tsconfig.json. But when I do that it prompts me a different error: Unknown compiler option 'include' and 'exclude'. It would be great help if you could get me out of this issue. Thank you in advance. Just to reiterate I have read through the whole blog and tried different solutions it does not seem to work. Again Thank you in advance. |
@andi-wr Thank you for the solution but it still does not work. It gives me whole lot of errors. Saying cannot find name 'describe'; cannot find name 'beforeEach' etc in all the files. This is a huge list of errors. |
@filipesilva ERROR in ./node_modules/agm-direction/src/agm-direction.module.ts |
I don't know if people are still having this problem - here's how I fixed the issue. I have 2 tsconfig.json files, one at the root of the app, and the other inside the src folder (one level down from the root) named tsconfig.app.json that extends the main tsconfig.json. I explicitly added the package that I needed that wasn't being transpiled by Typescript in the "include" array, and like a lot of people here I was getting the *.spec.ts files included despite having them in "exclude" option, so I removed it from the tsconfig.json. The fix was adding the "exclude" option to the second (extended) tsconfig.app.json file. Doing that fixes the Typescript errors and lets me run ng serve without issue. Here is tsconfig.json: { And tsconfig.app.json: { For some reason adding the exclude in the extended tsconfig (tsconfig.app.json) file is the only way I was able to get it to not complain about the spec files. Based on the comments from @filipesilva this may still be a bug but it worked for me. Hopefully this helps anyone facing the same issue. |
@tapaz1 By following your instruction, I got it work. I added a section of
then build success. Thank you! |
The error also happens when you have the url of a main file wrong in the package.json in your library |
IMHO, the new behavior of failing when the compiler wasn't asked to compile a file it wasn't supposed to compile in the first place is also a bug.
So that TypeScript files are not included when I I realize that my situation may be more complicated than most. I've got an angular app and 3 independent NPM packages that I'm working on, where my app depends on all 3 packages, and one of the packages depends on the other two. Two days of googling, RTFMing, and trying every combination of In the end, I
all because of this paternalisticl error, that obstructs the use of In future, can this be warning instead of an error, or perhaps add a cli flag indicating that no error should be raised just because angular wasn't asked to compile every Workaround:This error is thrown when loading
then you can go to the line that threw the error, which is listed in the output from The downside to this workaround is that while your In short, the workaround sucks, but at least it doesn't prevent you from doing development on separate projects with separate dependencies and typings. |
(sinon erreur de compilation de typescript, même si on a mis les paths des npm linked shared modules dans la partie output de tsconfig.json) angular/angular-cli#8284 git-svn-id: https://github.com/kresiak/template.git/trunk@2 2c0367cd-f7dd-5941-2a14-ce57b7db7bff
add in tsconfig.app |
Hi all, This thread was opened a while ago. The tsconfig file is what determines what TS files are compiled. The error you are getting means that the files mentioned are not being compiled as explained in the following comment #8284 (comment). Having all the feedback in a single thread makes it hard to get meaningful reports, or to inform people of what versions the regressions that affect them were fixed. Having so many hidden comments makes it hard for people to find the information in anything but the latest comments. But on the other hand I don't think most people would go through all of the comments anyway. New users that see this thread mostly read the first and latest comments and lose things said in between. So for the reasons stated above (high volume of comments, hidden comments, hard to report and inform people) I'm also locking this issue to prevent this comment from being lost as new comments come in. If you are still experiencing an issue please open a new issue, provide a simple repository reproducing the problem, and describe the difference between the expected and current behavior. |
Bug Report or Feature Request (mark with an
x
)Versions.
Angular CLI: 1.5.0
Node: 8.7.0
OS: darwin x64
Angular: 5.0.0
Repro steps.
We have a the following folder structure in a git mono-repo
/api (Express Node App)
/model (NPM package using NPM Link, contains mostly typescript interfaces)
/web (Angular)
When using Angular 4.46 and Angular CLI 1.5.rc2 and we were able to make reference to the interfaces defined in the model folder using npm link and using the following example
import { entity } @app/model
We use ng serve to start the app.
After upgrading Angular to V5 and Angular CLI to 1.5.0 we now get the following error -
The log given by the failure.
Module build failed: Error: /Users/thaoula/Projects/platform/model/index.ts is not part of the compilation. Please make sure it is in your tsconfig via the 'files' or 'include' property.
The occurs for JIT and AOT builds.
Running TSC does not result in in errors.
Desired functionality.
Would like be able to build the app using Angular 5
Thanks,
Tarek
The text was updated successfully, but these errors were encountered: