-
Notifications
You must be signed in to change notification settings - Fork 27
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
Unhandled rejection Error: no response timeout #26
Comments
@mwittig Hi Marcus, Happy New Year! I've updated all my node/homebridge/milight/alexa components and am getting this error Unhandled rejection Error: no response timeout Is this resolved by supporting the keepalive function @markg85 references has been implemented here: https://github.com/JasperG/bilight/blob/master/bilight/src/main/java/com/jaspergoes/bilight/milight/Controller.java#L774 ? I use the homebridge-milight plugin to control my 8 zones of RGB-CCT lights with my Amazon Echo Dot via the homebridge-alexa plugin. I'm running the Echo Dot with version 597465220 of their echo dot software. |
@pauleec Happy new year! The "no response timeout" error is not related and it is not resolved by implementing the keep-alive generally. Regarding the state of homebrige integration see dotsam/homebridge-milight#39 |
Any updates on this bug? Seems this pops up when you send a few commands in quick succession to the same zone. The execution just hangs and if you kill the process and start again, it doesnt help either. Only after passage of certain amount of time, the script works again. This is the code which I am using for turning off the lights. The turnOn code is similar:
Please let me know if I am doing something wrong which is causing this error. |
Well, yes and no. Yes, as I analyzed the "unhandled rejection" and found this is design glitch rather than a bug. The problem is that different to earlier the sendCommands() function now returns a promise which needs to be handled. No, as the underlying problem is not fully analysed. As you say the problem occurs in particular if commands are send in quick succession to the same zone. That's also what I noticed. I am not sure yet, however, what is causing the problem. It might be network congestion (UDP packets simply dropped on the network). To verify this I need to create more packet captures. I'll also check your code snippet as I did notice the code "hanging". Do you at which point it hangs? Is it light.ready()? A recovery strategy might be to create a new session in case. |
Hi Markus, In my case, this happened because I was not handling the promises correctly in wrapper script which I have written around milight-promise. This caused the node processes to hang which in turn probably left the connections to the ibox open. Once I cleaned up my code and each call to my wrapper script exited correctly, I did not have this problem anymore. The wrapper that I have written is an adapter for the ha-bridge which I plan to publish soon as well. Thanks for the info. |
I am seeing this too. I have only one routine talking to the controller and all calls are wrapped in a What I'm seeing is
Does this help at all? Incidentally, is there any way to get the current state from the controller? |
The code is part of a private repository. I've posted the relevant module (the only one that calls milight) to a gist. Is that sufficient? It's in coffeescript. Let me know if you need the javascript version. [Edit] Actually, it probably isn't enough because you need to see that each promise has a |
Thanks you very much for providing me with code samples and your efforts in investigating the problem! Minor update: I spent some time to further analyze the problem around the "unhandled exception" and have a solution for it which I'll push later. This solves the "unhandled exception", however, it does not solve the "request timeout problem". This occurs when the WiFi controller did not ack a command after it had been resent three times. It might be a congestion issue if you have multiple MilightController instance s, for example, doing commands at the same time (note, however, it is possible to enable full synchronization between all those instances!). However, some users reported it also occurs in a single instance uses case and I have also sporadically seen this. |
@CliffS Thanks again for your efforts in investigating the "unhandled exception" problem and your code work to fix the problem. I'll write a summary of the changes in more detail asap. |
@mwittig I think you are right in saying that the problem seems to be congestion related. I have stitched Alexa up with your scripts and ha-bridge in between. In Alexa I have defined some scenes and each scene triggers multiple zones in parallel. For example, the scene "Good night" turns off all the zones. Whenever I trigger this scene, 4 node instances are started and every now and then at least one of these instances gets stuck with the "no response timeout" error.
Addition
|
@mwittig Gibt es für das Problem schon eine Lösung? Bei mir hilft auch nur den Router neu zu starten, dann ist das Antwortverhalten wieder eine Zeit lang ok. Mit dem Problem ist es so gut wie unmöglich einen Slider zu implementieren, da durch die Verzögerungen die Farbe ständig "nachläuft". |
I have this error too, latest version of the homebridge plugin, only since I have a new v6 base station. Funny thing is that no light was switched when this error occurred:
|
Hi @mwittig. Did you get any further with this? The issue seems to be that the pattern you are using in A better way to do it would probably be to use Is this something you think you will get to in the near future? Cliff. |
OK, I think I have fixed this by in my PR. #67 At least it's now working for me. |
@CliffS Thanks for your PR. I'll look into this asap. |
@mwittig I think I have finally got to the bottom of this. My PR fails because of a race condition: it is possible for the In any case, as far as I can see, the effect of the If you're happy with this solution, I will update my PR to reflect it. Cliff. |
The text was updated successfully, but these errors were encountered: