RosWeb.Endpoint module not available after compiling

compiler
phoenix
troubleshooting
#1

I’m not sure how to best describe this issue, but I’ve started to notice this recently and I don’t know what changed that started to trigger it. Basically, anytime I save a controller or any .ex file (something that triggers the compiler it seems), I get the following error when the live reloader reloads the page:

[error] #PID<0.661.0> running RosWeb.Endpoint (connection #PID<0.660.0>, stream id 1) terminated
Server: localhost:4000 (http)
Request: GET /live/websocket?vsn=2.0.0
** (exit) an exception was raised:
    ** (UndefinedFunctionError) function RosWeb.Endpoint.__handler__/2 is undefined (module RosWeb.Endpoint is not available)
        (ros) RosWeb.Endpoint.__handler__(%Plug.Conn{} ...) # Edited out the two args
        (phoenix) lib/phoenix/endpoint/cowboy2_handler.ex:17: Phoenix.Endpoint.Cowboy2Handler.init/2
        (cowboy) /ros/deps/cowboy/src/cowboy_handler.erl:41: :cowboy_handler.execute/2
        (cowboy) /ros/deps/cowboy/src/cowboy_stream_h.erl:296: :cowboy_stream_h.execute/3
        (cowboy) /ros/deps/cowboy/src/cowboy_stream_h.erl:274: :cowboy_stream_h.request_process/3
        (stdlib) proc_lib.erl:249: :proc_lib.init_p_do_apply/3


[error] #PID<0.669.0> running RosWeb.Endpoint (connection #PID<0.668.0>, stream id 1) terminated
Server: localhost:4000 (http)
Request: GET /phoenix/live_reload/socket/websocket?vsn=2.0.0
** (exit) an exception was raised:
    ** (UndefinedFunctionError) function RosWeb.Endpoint.__handler__/2 is undefined (module RosWeb.Endpoint is not available)
        (ros) RosWeb.Endpoint.__handler__(%Plug.Conn{} ...) # Edited out the two args
        (phoenix) lib/phoenix/endpoint/cowboy2_handler.ex:17: Phoenix.Endpoint.Cowboy2Handler.init/2
        (cowboy) ros/deps/cowboy/src/cowboy_handler.erl:41: :cowboy_handler.execute/2
        (cowboy) ros/deps/cowboy/src/cowboy_stream_h.erl:296: :cowboy_stream_h.execute/3
        (cowboy) ros/deps/cowboy/src/cowboy_stream_h.erl:274: :cowboy_stream_h.request_process/3
        (stdlib) proc_lib.erl:249: :proc_lib.init_p_do_apply/3

I’m using Phoenix LiveView, but this happens outside of LiveView files as well. The websocket errors out a bunch of times before it recovers and it reloads the page just fine. It seems that this only happens in development, and only with live reloading enabled.

I’m really at a loss and don’t even know where to begin to debug this, but this throws a TON of errors in my logs while developing and is quite frustrating.

Is anyone interested in helping me figure out what’s going on? I’m happy to share code examples, but as I said, I’m having a hard time knowing what I could share that would lead to a clue to what’s going on.

Any help would be greatly appreciated. Thank you.

#2

There might be a compilation error occurring (the error message would be printed before those errors), and as the module cannot be compiled, it will lead to those errors. At least that’s what it usually is for me.

1 Like
#3

Thanks for the reply, @Nicd!

Unfortunately, there’s no other error that is displayed before the one I posted. That error I shared is triggered like 3-4 times, then the page reloads just as expected. It’s really quite strange.

Any other ideas?

#4

New development in this bug:

Going to localhost:4000 triggers the module Endpoint is not available error, but if I expose my localhost using ngrok and visit mysubdomain.ngrok.io then the problem seems to go away. This is quite strange, but I’m guessing it has something to do with the domain.

#5

Hey! I’m getting the same behavior. Even on fresh generated app!

Did you found any solution apart from Ngrok? (ngrok trick works as well)

#6

Unfortunately not. I still get the same error and I’m no closer to finding out why. I’m currently ignoring it, but it’s a huge distraction. You’re the first person I’ve heard having the same issue.

I don’t even know where to begin, but maybe we can help each other debug it. I work on my project on an almost daily basis and would love to get this resolved. I haven’t been able to reproduce it in a newly generated app.

#7

I’ve been experiencing this same issue as well, and it finally annoyed me enough to start digging into it more. (I’m not using LiveView, but a regular Phoenix project.) Sometimes it seems like changes I make trigger 4-5 recompiles, and then I get lots of error messages while everything recompiles and the live reload WS endpoint can’t be reached.

I’m looking into it more and will post if I find anything.

2 Likes
#8

Good luck! I’ve spent hours trying to figure it out myself, but just haven’t been able to dig too deep due to time constraints. I’ve noticed the same thing as you too. If you look at the web console you’ll see the WS endpoint can’t be reached a bunch of times before the page reloads.

I wonder if it has to do with phoneix live reload?