Manage headless displays with Xvfb (X virtual framebuffer)
Project description
xvfbwrapper
Manage headless displays with Xvfb (X virtual framebuffer)
- Copyright (c) 2012-2025 Corey Goldberg
- Development: GitHub
- Releases: PyPI
- License: MIT
About
xvfbwrapper is a python module for controlling X11 virtual displays with Xvfb.
What is Xvfb?
Xvfb (X virtual framebuffer) is a display server implementing the X11
display server protocol. It runs in memory and does not require a physical
display or input devices. Only a network layer is necessary.
Xvfb is useful for programs that run on a headless servers, but require X Windows.
Installation
pip install xvfbwrapper
System Requirements
- Python 3.9+
- X Window System
- Xvfb (
sudo apt-get install xvfb,yum install xorg-x11-server-Xvfb, etc) - File locking with
fcntl
Examples
Basic Usage:
from xvfbwrapper import Xvfb
xvfb = Xvfb()
xvfb.start()
try:
# launch stuff inside virtual display here
finally:
# always either wrap your usage of Xvfb() with try/finally, or
# alternatively use Xvfb() as a context manager. If you don't,
# you'll probably end up with a bunch of junk in /tmp
xvfb.stop()
Specifying display geometry:
from xvfbwrapper import Xvfb
xvfb = Xvfb(width=1280, height=740)
xvfb.start()
try:
# launch stuff inside virtual display here
finally:
xvfb.stop()
Specifying display number:
from xvfbwrapper import Xvfb
xvfb = Xvfb(display=23)
xvfb.start()
# Xvfb is started with display :23
# see vdisplay.new_display
try:
# launch stuff inside virtual display here
finally:
xvfb.stop()
Usage as a context manager:
from xvfbwrapper import Xvfb
with Xvfb() as xvfb:
# launch stuff inside virtual display here
# Xvfb will stop when this block completes
Multithreaded execution:
To run several Xvfb displays at the same time, you can use the environ
keyword when starting the Xvfb instances. This provides isolation between
threads. Be sure to use the environment dictionary you initialize Xvfb with
in your subsequent calls. Also, if you wish to inherit your current
environment, you must use the copy method of os.environ and not simply
assign a new variable to os.environ:
import os
from xvfbwrapper import Xvfb
isolated_environment1 = os.environ.copy()
xvfb1 = Xvfb(environ=isolated_environment1)
xvfb1.start()
isolated_environment2 = os.environ.copy()
xvfb2 = Xvfb(environ=isolated_environment2)
xvfb2.start()
try:
# launch stuff inside virtual displays here
finally:
xvfb1.stop()
xvfb2.stop()
Usage in testing - headless Selenium WebDriver tests:
This is a test using selenium and xvfbwrapper to run tests
on Chrome with a headless display. (see: selenium docs)
import os
import unittest
from selenium import webdriver
from xvfbwrapper import Xvfb
# force X11 in case we are running on a Wayland system
os.environ["XDG_SESSION_TYPE"] = "x11"
class TestPages(unittest.TestCase):
def setUp(self):
xvfb = Xvfb()
self.addCleanup(xvfb.stop)
xvfb.start()
self.driver = webdriver.Chrome()
self.addCleanup(self.driver.quit)
def test_selenium_homepage(self):
self.driver.get("https://www.selenium.dev")
self.assertIn("Selenium", self.driver.title)
if __name__ == "__main__":
unittest.main()
- virtual display is launched
- browser launches inside virtual display (headless)
- browser quits during cleanup
- virtual display stops during cleanup
xvfbwrapper Development
Clone the repo:
git clone https://github.com/cgoldberg/xvfbwrapper.git
cd xvfbwrapper
Create a virtual env and install required testing packages:
python -m venv venv
source ./venv/bin/activate
pip install -r requirements_test.txt
Run all unit tests in the default Python environment:
pytest
Run all unit tests, linting, and type checking across all supported/installed Python environments:
tox
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xvfbwrapper-0.2.11.tar.gz.
File metadata
- Download URL: xvfbwrapper-0.2.11.tar.gz
- Upload date:
- Size: 5.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
675dd836cc5db56b8253c750c8becd6e0c0dac2904f56948f63a0393423bb259
|
|
| MD5 |
a03f95e5ffb61546f358d7fdaf520f08
|
|
| BLAKE2b-256 |
a43a5edd94e7e70acd66abef9d6b305ebfb93a0b18fae394c5e4db7a12fc4083
|
File details
Details for the file xvfbwrapper-0.2.11-py3-none-any.whl.
File metadata
- Download URL: xvfbwrapper-0.2.11-py3-none-any.whl
- Upload date:
- Size: 6.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e045b41e234f0676ad72b9d4742a327e0ec98f496985a624f52481853504420f
|
|
| MD5 |
6ec71d58a91ec796cd42ba23dbf10092
|
|
| BLAKE2b-256 |
61595e155901a938d364d184702dc554e1780c0eebee0b3389045c3f4fb6234f
|