W
Wasp•2y ago
IamIconLiving

Optional node_modules installs

I dunno why but for some reason I thought that Wasp detects npm installs and keeps track of them. Maybe cus of this file installedFullStackNpmDependencies.json but would it make sense for Wasp to track chances in package.json file and if there are any - only then do a npm install or have some sort of flag to disable the modules installation I was playing around yesterday with deployment to Railway, and I needed to do a few small changes in the source code (not .wasp folder) and build the codebase frequently afterwards and node_modules were installed every single time, whereas I think there might be a different way to do it. Like keep a ref to the dependencies and track any chances in there on each build command. If any detected - reinstall them entirely. If none - just delete everything apart from node_modules folder. Alternative approach, add a CLI flag to disable installs manually (might be easier and preferred way)
9 Replies
MEE6
MEE6•2y ago
Wohooo @IamIconLiving 🎄, you just became a Waspeteer level 3!
IamIconLiving
IamIconLivingOP•2y ago
keep getting levelling up :godfatherboi:
Vinny (@Wasp)
Vinny (@Wasp)•2y ago
ah interesting. I'll have to defer to one of the devs on this one, but I'm curious why you were building so frequently?
IamIconLiving
IamIconLivingOP•2y ago
ofc, good question. so I decided to upload my todo app from the documentation to the railway, but a small type error in my codebase that I didn't notice, so linting screamed at me. I fixed the type error and did wasp build but the .wasp/out folder was not reflecting my changes. I thought it's very weird and started digging and doing multiple wasp build, expecting my fix to come into this folder later then I realise that the folder is wrong - I should have look at .wasp/build folder (a bit confusing why those 2 co-exist at the same time) but then again, my changes were not reflecting there either for some reason. so I had to manually change some conflicting bits in the /build to be able to deploy to Railway but this morning /build folder was refreshed correctly on each wasp build, so chances are - I did some stupid thing due to end of the day 😄 the point is - that's the journey, I did a ton of wasp build yesterday and it was too slow aaand, I am already thinking that for an app I wanted to do, I need to do wasp build quite frequently too, to then upload the app onto a platform, so building will be a second nature
Vinny (@Wasp)
Vinny (@Wasp)•2y ago
Oh cool. This is really great info! I'm glad to see someone really stress testing Wasp 💪
IamIconLiving
IamIconLivingOP•2y ago
oh yeah, I have few short term goals for Wasp: - deploy on Railway - done - make sure if google auth on Railway works - TBD - port LSP from VSCode to neovim plugins so guys in terminals can enjoy their time writing Wasp files - this is not a short term goal, but a long one, cus I have never done such things before, so it's dark area but exciting - start my app with Wasp - and this will be a real stress test
Vinny (@Wasp)
Vinny (@Wasp)•2y ago
oh great! I'm really curious if Railway has solved the issue with their proxy servers and OAuth2.
martinsos
martinsos•2y ago
Ok let's see what happened here! Difference between out/ and build/ -> ah yes, well that is somewhat typical in the tools today, usually you have one place where you generate artefacts during development, and then a clean place to do it when building for production. I don't think we could combine these things together easily, it would probably get quite messy, as some things are done different during wasp build , which uses .wasp/build, compared to wasp start, which uses .wasp/out. If I got it correctly, what you found troublesome is that on each wasp build you have to wait for node_modules to get reinstalled, completely from scratch, which is a PITA. Here is the offending line: https://github.com/wasp-lang/wasp/blob/main/waspc/cli/src/Wasp/Cli/Command/Build.hs#L47 -> we delete the whole .wasp/build dir when creating new build. The idea behind this is to make sure we have clean start, that nothing from the previous build is by accident left over. But yup this cleans up node_modules also! Hmmm, so we could, as you suggested, potentially remove everything but node_modules. What if some redundant stuff is left in them from before? Well I think it doesn't matter, they are anyway not getting deployed, it is instead expected that when you deploy you do npm build (it is what we do in our Docker container for deploying server). There is another thing I wonder here though -> why do we even need node_modules here? We are just producing code that is to be deployed -> Docker container is anyway building node_modules on its own from what I see, and doing prisma generation and stuff. I think we let it install node_modules because we normally do that after generating code, but it might actually be redundant in this case, and we could possibly just remove it! I will create a GH issue with all this info and propose that we look into skipping installation of node_modules for wasp build, or if that can't be done, then we at least try to re-use them. Created an issue here: https://github.com/wasp-lang/wasp/issues/1152 . The more I dig into it, the more it seems like we don't even need that npm install heh :D. Now I investigated it so much that I should probably implement it - I had other plans for today but I might give it a go anyway, will let you know if I do so.
IamIconLiving
IamIconLivingOP•2y ago
wow thanks so much for this detailed response, much appreciated! yeah that's what I thought, that modules folder is being cleaned up and each run, hence reinstallation was "needed" haha as long as you think it's worth your time and money right now, that'd be awesome, but it's not a pressing issue! as long as you can still build with actually installing new dependencies when required, meaning when new ones were added (I don't have an insight how deps are installed internally), then yeah, this could be very good addition to the tooling

Did you find this page helpful?