Skip to content
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

wait-on perpetually returns ECONNREFUSED when using localhost, but works fine using 127.0.0.1 #109

Open
thepuzzlemaster opened this issue Dec 6, 2021 · 13 comments

Comments

@thepuzzlemaster
Copy link

I had been using the start-server-and-test module for kicking off my server, and then starting my tests, however I couldn't get it to work using http. I ended up creating a minimal repro here (note the wait-on-defect branch).

I realized that it does however, work fine if I switch my localhost to 127.0.0.1. I can curl the localhost fine in a terminal window and it returns the html string. I'm using next js as my server, which does run via webpack, so using http-get, but to no avail.

repro steps:

  • pull down minimal repro and checkout wait-on-defect branch
  • yarn install
  • yarn test:integration
@sebastiancarlsson
Copy link

+1 on this, I'm using vite's "preview" functionality to run my app. It works if I use 127.0.0.1 instead of localhost.

@nicarl
Copy link

nicarl commented Dec 15, 2021

We faced the error in https://github.com/opossum-tool/OpossumUI when upgrading to node 17. Replacing localhost by 127.0.0.1 works

@DasSkelett
Copy link

Most likely cause is nodejs/node#39987 (see also nodejs/node#40537).
You could update your apps/services to listen on IPv6 as well, or if they're hardcoded to 127.0.0.1, you need to hardcode it for wait-on as well, as already mentioned.

dangmai added a commit to dangmai/prettier-plugin-apex that referenced this issue Feb 3, 2022
@Saltallica
Copy link

+1 still a thing in node 18

hewhodevs added a commit to hewhodevs/electron-react-tailwindcss-boilerplate that referenced this issue Aug 10, 2022
- Using concurrently to launch electron once react is running
- "start-react" script launches react with BROWSER=none to prevent default opening of a browser tab at launch
- "start-electron" script launches electron once wait-on received http 200 status code from http://127.0.0.1:3000
- Had to use 127.0.0.1 instead of "localhost" in the wait-on url, as wait-on can hang trying to resolve localhost. see wait-on github issues for further details (jeffbski/wait-on#109)
- Updated start script in package.json
- running npm start now launches react with BROWSER=none using cross-env, then launches electron-start to launch electron after the wait-on is successful
pairing4good added a commit to pairing4good/tdd-react-18-template that referenced this issue Sep 27, 2022
Macil added a commit to Macil/react-typescript-electron-sample-with-create-react-app-and-electron-builder that referenced this issue Oct 13, 2022
"react-scripts start" launches a dev server on IPv4.
With Node 17+ on Windows, "wait-on http://localhost:3000" tries to connect over IPv6 and fails.
By changing the command to "wait-on http://127.0.0.1:3000", wait-on will make an IPv4 request and succeed, allowing electron to open.

Here's a related thread about other people running into this issue: jeffbski/wait-on#109
@JacobMuchow
Copy link

Experienced the same thing. It took me a few hours to track this down. I think it would be useful, if not important, for the project to handle this in some fashion since LTS is 18.12.0 and current Node version is 19.0.0.

Two solutions for me were to:

  • Downgrade to node 16 (16.18.0)
  • Use http://127.0.0.1:3000 instead of tcp:3000 or http://localhost:3000

@metcoder95
Copy link

Hey! This is not an issue from the library itself, but from this change previously mentioned: node#39987. As some times and depending on the OS is possible that it will return an ipv6 instead of ipv4, which on some machines the localhost host doesn't resolve to ipv6. Until the HappyEyeballs implementation is merged in Node, this will still be a problem if your host's config within your machine is set to resolve first the ipv6 over ipv4 and the service/tool doesn't listen to both IP versions.

The recommendation is to be careful and try to listen to verify if the tool/service listens to both IP versions, and if note, point directly to the one that is resolved first on your host config.

@sun0day
Copy link

sun0day commented Nov 8, 2022

localhost resolve behavior changed since node17. See nodejs/node#40702

@metcoder95
Copy link

Hi guys! It seems that sadly the project hasn't been active lately, and issues are just pilling up 🙁
In an effort to continue using the project, and of course, with all the respect to @jeffbski, I take my time to do a fork of the project, make improvements and fix some of the issues noted here and other issues within this project.

The effort is not to replace this great project but try to continue adding support to it in parallel. Hopefully, you'll find it helpful 🙂

It is important to notice that I made some refactors and improvements, for instance, the current version is 0.1.0, meaning that is possible to have slightly breaking changes within the current version before jumping into the first stable one 🙂

Hope you found it useful and am happy to help you through the issues section of the project. Looking forward to your feedback!

Link: https://github.com/metcoder95/wait-on

@lrNas
Copy link

lrNas commented Jan 10, 2023

Hello folks! It seems that in v18.12.1 the same is happening.

@metcoder95
Copy link

It happens because the happy eyeballs option is not enabled by default 🙁

raffaeu pushed a commit to raffaeu/aws-storage-explorer that referenced this issue Mar 11, 2024
"react-scripts start" launches a dev server on IPv4.
With Node 17+ on Windows, "wait-on http://localhost:3000" tries to connect over IPv6 and fails.
By changing the command to "wait-on http://127.0.0.1:3000", wait-on will make an IPv4 request and succeed, allowing electron to open.

Here's a related thread about other people running into this issue: jeffbski/wait-on#109
@janbrasna
Copy link

For anyone affected by this, according to #137 (comment) the defaults changed in Node 20 and this should work again out-of-the-box.

So for anyone running into this with Node 17, 18 or 19 — try upgrading to Node 20 to see if that makes any difference for your case.

@cfecherolle
Copy link

cfecherolle commented Jun 13, 2024

I tried this today with Node 20.10.0 and Vite 4.3.9, the only way I found to avoid wait-on hanging forever on 404 errors was to use tcp:3000.

http://localhost:3000 and http://127.0.0.1:3000 did not work for me ☹️

Edit: Actually, when I use tcp:3000, wait-on is satisfied after a few tries and goes on with my script (which is a launch of Cypress) but my page is not loading and the Cypress test times out after 60 seconds so I'm not sure if waiting on port 3000 with TCP is enough to make sure the Vite server is ready to go.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests