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

Raise a more specific error if the websocket connection dies #86

Closed

Conversation

yjukaku
Copy link

@yjukaku yjukaku commented Dec 1, 2021

We're having an issue in our CI environment where our container is sporadically timing out, and we think it may be because the Chrome client is dying silently or disconnecting, and Apparition is not realizing it.

I'm able to reproduce the issue of Apparition hanging locally by starting some specs in one terminal window, and killing the Chrome process that is spawned via another terminal window using killall -m Chrome (careful if you are actually using Chrome at the time). Killing Chrome causes apparition to hang permanently - the only way to get the specs to stop is Ctrl+C (twice).

After looking into why that happens, I thought this issue might hold the answer faye/websocket-driver-ruby#61 . Apparently, it's possible that the Websocket Driver's connection fails without firing the :close event. In addition to listening for that event, we should also check the return value of #read and ensure it's not nil or an empty string.

Well, I tried just checking for nil and "", and it didn't seem to work. I was able to verify that the socket.read call was where apparition was hanging, and it seems the readpartial call is blocking, so I replaced it with read_nonblock. That method is, according to the docs, the exact same other than the blocking flag. Once I used the non-blocking form of read, and raised an error when the timeout occurs, I see the expected error output, but apparition continues to hang 😞 . This happens _even if I set the abort_on_exception flag to true on the @listener thread. 😕 I have no idea why.

I'm hoping you can help me build on this PR to properly address this issue.

@yjukaku yjukaku force-pushed the add-checks-for-ws-connection-errors branch 2 times, most recently from 1cdda23 to 83d1b3e Compare December 2, 2021 16:44
@yjukaku yjukaku force-pushed the add-checks-for-ws-connection-errors branch from 83d1b3e to b20f5bf Compare December 2, 2021 19:13
@yjukaku yjukaku closed this Apr 11, 2022
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

Successfully merging this pull request may close these issues.

1 participant