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

fixed race condition #45

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open

fixed race condition #45

wants to merge 3 commits into from

Conversation

mbway
Copy link

@mbway mbway commented May 14, 2021

fixes #30 and fixes #36

I ran into a very rare intermittent failure in a test which starts a Qt application and connects to a virtual framebuffer constructed with xvfb. The cause was the race condition between xvfb creating the framebuffer and the Qt application starting.
Under normal circumstances the error is quite rare (happening in 1/2500 runs or so) but the same situation can be emulated with:

Xvfb.SLEEP_TIME_BEFORE_START = 0
while True:
    with Xvfb():
        app = QApplication([])
        app.exit()

which crashes almost immediately with

qt.qpa.xcb: could not connect to display :12345
qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found.
This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, vnc, wayland-egl, wayland, wayland-xcomposite-egl, wayland-xcomposite-glx, webgl, xcb.


Process finished with exit code 134 (interrupted by signal 6: SIGABRT)

I have replaced the fixed timeout with a loop which waits for the Unix domain socket for the display to exist (which I assume means the display is ready). With this change the above snippet no longer crashes.

An added benefit is that the startup is also much faster (taking only about 5ms on average on my machine).

I know the chances of getting this pull request merged is slim as the project seems abandoned, but this might be useful for other people who run into this problem.

@mbway mbway changed the title fixed race condition (#30) fixed race condition May 14, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
1 participant