import os import infra.basetest GLXINFO_TIMEOUT = 120 class TestGlxinfo(infra.basetest.BRTest): config = \ """ BR2_x86_core2=y BR2_TOOLCHAIN_EXTERNAL=y BR2_TOOLCHAIN_EXTERNAL_CUSTOM=y BR2_TOOLCHAIN_EXTERNAL_DOWNLOAD=y BR2_TOOLCHAIN_EXTERNAL_URL="http://toolchains.bootlin.com/downloads/releases/toolchains/x86-core2/tarballs/x86-core2--glibc--bleeding-edge-2018.11-1.tar.bz2" BR2_TOOLCHAIN_EXTERNAL_GCC_8=y BR2_TOOLCHAIN_EXTERNAL_HEADERS_4_14=y BR2_TOOLCHAIN_EXTERNAL_CXX=y BR2_TOOLCHAIN_EXTERNAL_HAS_SSP=y BR2_TOOLCHAIN_EXTERNAL_CUSTOM_GLIBC=y BR2_LINUX_KERNEL=y BR2_LINUX_KERNEL_CUSTOM_VERSION=y BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE="4.16.7" BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="board/qemu/x86/linux.config" BR2_PACKAGE_MESA3D_DEMOS=y BR2_PACKAGE_MESA3D=y BR2_PACKAGE_MESA3D_DRI_DRIVER_SWRAST=y BR2_PACKAGE_MESA3D_OPENGL_GLX=y BR2_PACKAGE_XORG7=y BR2_PACKAGE_XSERVER_XORG_SERVER=y BR2_TARGET_GENERIC_GETTY_PORT="ttyS0" BR2_TARGET_ROOTFS_EXT2=y # BR2_TARGET_ROOTFS_TAR is not set """ def wait_for_xserver(self): # xserver takes some time to start up # The test case fail here if for some reason xserver is not properly installed _, _ = self.emulator.run('while [ ! -e /var/run/xorg.pid ]; do sleep 1; done', 120) def login(self): img = os.path.join(self.builddir, "images", "rootfs.ext2") kern = os.path.join(self.builddir, "images", "bzImage") # glxinfo overallocate memory and the minimum that seemed to work was 512MB self.emulator.boot(arch="i386", kernel=kern, kernel_cmdline=["root=/dev/vda console=ttyS0"], options=["-M", "pc", "-m", "512", "-drive", "file={},if=virtio,format=raw".format(img)]) self.emulator.login() def test_run(self): self.login() self.wait_for_xserver() # The test case verifies that the xserver with GLX is working cmd = "glxinfo -B -display :0" output, exit_code = self.emulator.run(cmd, GLXINFO_TIMEOUT) self.assertEqual(exit_code, 0) for line in output: self.assertNotIn("Error", line) # Error case: "Error: couldn't find RGB GLX visual or fbconfig"