Open PhilippSonntagORGADATA opened 4 years ago
Can somebody help me here? This actively prevents me from using the cli. The $PATH environment variable is correctly set as it displays when I'm printing it out.
/Users/psn_local/.nvm/versions/node/v14.15.0/bin:
is in my path which contains the binaries of
ionic ionic-lab ng node_modules npx pnpx tsc webpack-cli ionic-cli-scripts ionic-v1 node npm pnpm preact tsserver webpack-dev-server
.
EDIT: Found the error, going to submit a PR.
It was an error in my project ionic.config.json. I switched from Windows to macOS and didn't notice the config used windows paths with backslashes. I think this error message is very misleading.
What exactly did you have in ionic.config.json
that caused this issue?
{
"defaultProject": "first-project",
"projects": {
"first-project": {
"name": "First Project",
"integrations": {},
"type": "angular",
"root": "projects\\first-project"
},
"second-project": {
"name": "Second Project",
"integrations": {},
"type": "angular",
"root": "projects\\second-project"
},
"third-project": {
"name": "Third Project",
"integrations": {},
"type": "angular",
"root": "projects\\third-project"
}
}
}
I had to change the names but this was exactly the structure. The paths in the root properties were made on windows which didn't work on macOS.
Ahh, so the ENOENT
was coming from a missing cwd
, I'm guessing.
I'm wondering if it might be better to validate the project directory exists before we even attempt to spin up the serve CLI. I looked at your PR and realized we'd have to handle the same error in the build CLI and anywhere else we use that project directory as the cwd of the subprocess.
Yeah exactly, sorry for missing out that information.
My first attempt was also to check the cwd, but I wasn't sure if other parameters could cause this error too, so I just ended up checking the existance of the cli command itself. I don't know if I can figure out all positions where this has to be fixed, but I could modify my changes if they are still needed.
I believe your PR will only realistically fix this specific issue: that the subprocess can emit an ENOENT
error because of a missing cwd
. Since that is the case, the logic may be simpler if we just check if that directory exists beforehand.
I thought about this a bit more and I think you were pretty close. We probably do want this check to exist when we attempt to serve/build/generate.
Here are some starting points:
I can take a look too, but it will be some time before I dig in. I'm mostly focused on Capacitor these days. Bugs in the Ionic CLI are rare, and this one looks like it will only affect devs who are using multiapp and make a typo in the project paths.
If you intend to continue with a fix, let me know if you have any questions! I'd be happy to answer them.
Hej there, finally found some time to investigate. To prevent any false configurations, I implemented a validation for integration and project roots. I think this will handle most of the possible errors. Thanks for the help :)
When the directory is not accessible, the CLI will throw an exception like this:
Description: Hello there, I'm currently trying to set up my dev environment on macOS Catalina 15.15.7. My problem is that the ionic cli seems to ignore the paths of my angular cli. Everytime I try to execute the
ionic serve
command, the cli wants me to install the angular cli because it can't find the ng command. When I try to install it it throws an exception as it can't find thenpm
command also.Steps to Reproduce:
npm install -g @angular/cli
ng --version
- Version 10.1.7npm install -g @ionic/cli
ionic --version
- Version 6.12.1npm install -r
ionic serve --project=<project-name>
ng
commandnpm
commandMy
ionic info
:Other Information: Things I already tried