The Window Subsystem for Linux is very powerful.
After exploring it for a bit, I wanted to push it even further.
WSL2, zsh, and docker. Linux through Windows.
Nicky Meuleman ・ Jun 15 '19 ・ 11 min read
Wouldn't it be cool to run GUIs natively inside of Linux, on your computer running Windows? 🤯
Nicky Meuleman@nmeulemanJust ran the @Cypress_io kitchen sink tests in their GUI. Natively on Linux, on my Windows machine. #WSL2
My mood right now:
[gif alt: Kristen Bell trying to swear in amazement. (in The Good Place)]15:26 PM - 16 Sep 2019
Prerequisites
Let's get the obvious one out of the way first.
WSL2. I wrote a guide detailing how to take it from 0 to awesome in a short time.
Now, it's time to turn that dial to 11.
For good measure, update that linux install
sudo apt update
sudo apt upgrade
VcXsrv
You can use something called an X-server to display what is going on in the Linux side of the computer.
For this I used the free program VcXsrc.
The first time you run that program, allow "Public networks, such as those in airports and coffee shops" when the Windows firewall pops up.
To display programs that launch on the WSL side of the machine as seperate windows. I chose the options "Multiple windows" and "Start no client".
On the page that lets you enable extra settings, be sure to disable access control.
By default it only allows the local IP 127.0.0.1.
Since WSL has its own IP address, which changes often, allow connections from all clients.
Cypress
You can replace this with whatever GUI you would like to run.
In my case, it was Cypress, so I made sure to set it up.
After installing Cypress in a project, I added a way to launch it in package.json
.
{
"scripts": {
"cy:open": "cypress open"
}
}
There were a bunch of errors greeting me when I tried to run cy:open
Luckily, it was a helpful error message that points to a docs page with the solution.
sudo apt install libgtk-3-dev libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2
After installing those packages, trying to run cy:open
doesn't error anymore.
It doesn't do anything else either, only show the Opening Cypress
message forever.
Bash config
The DISPLAY
variable
In order for Linux GUI apps to connect to our X-server, a DISPLAY
environment variable has to be set.
In your .bashrc
(or .zshrc
if you are using ZSH)
# set DISPLAY variable to the IP automatically assigned to WSL2
export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk '{print $2; exit;}'):0.0
When you start WSL2, it gets its own IP address.
That long command will evaluate to the IP that WSL2 set.
The DISPLAY
variable has the format <host>:<display>.<screen>
.
Both <display>
and <screen>
are set to 0 here so that line will evaluate to something like export DISPLAY=172.17.224.1:0.0
, with the <host>
changing to the correct IP.
To confirm this worked, print out the variable you just set in the terminal.
echo $DISPLAY
# 172.17.224.1:0.0
Automatically start dbus
A lot of GUI apps use D-Bus to internally communicate.
In .bashrc
(or zshrc
), under to previous line, add
sudo /etc/init.d/dbus start &> /dev/null
This file can be reloaded by running
source ~/.bashrc
(orsource ~/.zshrc
) in your terminal.
Grant passwordless access for dbus
We need a soduers
file to grant our linux user access to dbus
without a password.
To accomplish this, use the visido
command.
This best practice will ensure you don't lock yourself out of the system. The sudoers
file doesn't play around, like the README
in /etc/sudoers.d/README
will tell you.
sudo visudo -f /etc/sudoers.d/dbus
A Nano editor will launch. Enter the following line, where <your_username>
is replaced by -🥁drumroll please🥁- your username.
If you aren't sure what the name of your linux user is, running whoami
in the terminal will tell you.
<your_username> ALL = (root) NOPASSWD: /etc/init.d/dbus
Writing a file in the Nano editor is almost as hard as quitting VIM.
Press CTRL+O
to save, then press Enter
to confirm. Finally, press CTRL+X
to close the editor.
Launch your GUI app
Close your terminal and open up a new one in the location you want to open the GUI app.
Open the VcXsrv program in Windows (called XLaunch).
Be sure to disable access control.
Launch the program in Linux.
# in the directory I installed Cypress and set up the command to launch it
yarn run cy:open
BOOM, a window opens running a Linux app, on Windows 🎉
Top comments (20)
Hey Nicky, thanks for this article, this has helped me a lot! Running Cypress for the first time on WSL, that's amazing!
What I've noticed is that it opens cypress but doesn't run the tests. Is there a way to automatically already execute the tests? I've tried doing
to run a specific spec for example but it doesn't run the actual test, it just opens the GUI. Any suggestions how to actually run through the tests automatically on cypress launch?
Glad it helped!
If you would like the tests to automatically start, use
cypress run
instead ofcypress open
. By default it runs in headless mode, so if you want to see the GUI you have to pass--headed
as command line argument.The docs to the CLI will tell you more details.
Sometimes the solution is so darn simple, makes you wonder how you didn't see it lol!
Thanks so much! I'm super excited to finally using Cypress in real-world scenarios, appreciate your help!
Hi Nicky!
Thanks for this article! I've done everything, but I'm getting an error. The following errors:
Do I have to install anything from Node or something on Windows? XLounch is running. Another problem I have is that D-Bus is not found when I run it from .bashrc. Later I will search for a solution, for now I start it manually.
I don't have node installed on the Windows side on the machine I tried this on.
The only dev-related software that is installed on the Windows side here is
git
.As for the error, I don't have a deep linux knowledge and am going off what I found by googling that error message. It seems to be related to electron and aparently it's often helped by disabling a feature.
github.com/cypress-io/cypress/issu...
The only advice I can give is to pay close attention to when the error happens, and then googling it
Hope you get it working!
Hi Nick, thanks for the article.
I'm trying to run cypress inside wsl 2, but the command
yarn run cy:open
always display an error message saying this: (Cypress:23887): Gtk-WARNING *: 17:08:53.243: cannot open display: 172.22.208.1:0.0 Done in 40.56s.*The
$DISPLAY
environment variable is already set, and VcXsrv is up and running.Any idea what is causing that?
Hi Nick, Thank you for the article, I'm so grad that it easy to follow and successfully bring it up.
I got the same issue about 'cannot open display'. Finally, I got solution, I just need to change firewall policy for the VcXsrv to able to working in Public even I am in the home (Private network). Then after that, everything work well.
Open the Control Panel as following
Control Panel\System and Security\Windows Defender Firewall\Allowed apps
and Enable VcXsrv in Public.
I also follow this script but it seem not related to this issue.
github.com/microsoft/WSL/issues/47...
Just leave the detail in case someone may experience the same.
Hey!
Apparently, in some distros you have to enable the option called
X11Forwarding
manually first.superuser.com/questions/310197/how...
Hope it helps, I had no idea what could cause it so I googled the error.
edit: this link also seems helpful: thegeekstuff.com/2010/06/xhost-can...
I have to go say, that it totally worked for me 🎊 With that said I think there may have been some debugging with
dbus
, or maybe I just had to restart my machine.Either way it is up and running now 🏃♂️
The next step is to go ahead and load those browsers on to your WSL distro 😅
Otherwise you can only debug in Electron 🤷♂️
It's working for me (most of the time, not sure why).
Maybe it's got to do with this printed message I get all the time while running the test:
I'm new in the project but this is the configuration (the npm script) of running cypress in the package.json that might give a clue about the message printed:
I have the same messages when a run
./node_modules/.bin/cypress open
, so I don't think the message it related to the npm script of your project.I had to run the command like 3 times to see cypress UI opening. But hey it's cool, it kinda work :D
If anybody reading this have a solution to fix the error message and make it work everytime, please share it !!
It dont work here for me
Thanks for the article, Nick. Up and running in minutes.
In case anyone is looking for solutions to their errors in comments,
try RESTARTING ones.
From cmd/PowerShell
wsl --shutdown
and reopen the Ubuntu Terminal.Hi ,It doesn't work for me when I try to add dependences :
It throws this error :
dpkg: error processing package libatk1.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libatspi2.0-dev:amd64:
libatspi2.0-dev:amd64 depends on libglib2.0-dev (>= 2.4.1-2); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libatspi2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libgtk-3-dev:amd64:
libgtk-3-dev:amd64 depends on libatk1.0-dev (>= 2.15.1); however:
Package libatk1.0-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libcairo2-dev (>= 1.14.0); however:
Package libcairo2-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libglib2.0-dev (>= 2.57.2); however:
Package libglib2.0-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libpango1.0-dev (>= 1.41); however:
Package libpango1.0-dev:amd64 is not configured yet.
dpkg: error processing package libgtk-3-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libharfbuzz-dev:amd64:
libharfbuzz-dev:amd64 depends on libglib2.0-dev (>= 2.19.1); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libharfbuzz-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libnotify-dev:amd64:
libnotify-dev:amd64 depends on libglib2.0-dev (>= 2.26); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libnotify-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libatk-bridge2.0-dev:amd64:
libatk-bridge2.0-dev:amd64 depends on libglib2.0-dev (>= 2.4.1-2); however:
Package libglib2.0-dev:amd64 is not configured yet.
libatk-bridge2.0-dev:amd64 depends on libatspi2.0-dev; however:
Package libatspi2.0-dev:amd64 is not configured yet.
dpkg: error processing package libatk-bridge2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libgdk-pixbuf2.0-dev:amd64:
libgdk-pixbuf2.0-dev:amd64 depends on libglib2.0-dev (>= 2.37.6); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libgdk-pixbuf2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
Errors were encountered while processing:
libpcre16-3:amd64
libpcre3-dev:amd64
libglib2.0-dev:amd64
libpango1.0-dev:amd64
libcairo2-dev:amd64
libatk1.0-dev:amd64
libatspi2.0-dev:amd64
libgtk-3-dev:amd64
libharfbuzz-dev:amd64
libnotify-dev:amd64
libatk-bridge2.0-dev:amd64
libgdk-pixbuf2.0-dev:amd64
E: Sub-process /usr/bin/dpkg returned an error code (1)
karimh@DESKTOP-DQ0GO0K:/mnt/c/Users/karim/Desktop/Cypress/Cypress_E2E_Automation$ export DISPLAY=localhost:127.0.0.1:0.0
karimh@DESKTOP-DQ0GO0K:/mnt/c/Users/karim/Desktop/Cypress/Cypress_E2E_Automation$ DISPLAY=localhost:127.0.0.1:0.0 npx cypress openIt looks like this is your first time using Cypress: 4.12.1
✖ Verifying Cypress can run /home/karimh/.cache/Cypress/4.12.1/Cypress
→ Cypress Version: 4.12.1
Cypress failed to start.
This is usually caused by a missing library or dependency.
The error below should indicate which dependency is missing.
on.cypress.io/required-dependencies
If you are using Docker, we provide containers with all required dependencies installed.
(Cypress:4411): Gtk-WARNING **: 13:30:41.821: cannot open display: localhost:127.0.0.1:0.0
Platform: linux (Ubuntu - 20.04)
Cypress Version: 4.12.1
karimh@DESKTOP-DQ0GO0K:/mnt/c/Users/karim/Desktop/Cypress/Cypress_E2E_Automation$ sudo apt install libgtk-3-dev libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2
Reading package lists... Done
Building dependency tree
Reading state information... Done
libnotify-dev is already the newest version (0.7.9-1ubuntu2).
libxss1 is already the newest version (1:1.2.3-1).
libgconf-2-4 is already the newest version (3.2.6-6ubuntu1).
libasound2 is already the newest version (1.2.2-2.1ubuntu1).
libgtk-3-dev is already the newest version (3.24.20-0ubuntu1).
libnss3 is already the newest version (2:3.49.1-1ubuntu1.4).
0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
12 not fully installed or removed.
Need to get 0 B/150 kB of archives.
After this operation, 0 B of additional disk space will be used.
Do you want to continue? [Y/n] y
dpkg: error processing package libpcre16-3:amd64 (--configure):
package is in a very bad inconsistent state; you should
reinstall it before attempting configuration
dpkg: dependency problems prevent configuration of libpcre3-dev:amd64:
libpcre3-dev:amd64 depends on libpcre16-3 (= 2:8.39-12build1); however:
Package libpcre16-3:amd64 is not configured yet.
dpkg: error processing package libpcre3-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libglib2.0-dev:amd64:
libglib2.0-dev:amd64 depends on libpcre3-dev (>= 1:8.31); however:
Package libpcre3-dev:amd64 is not configured yet.
dpkg: error processing package libglib2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libpango1.0-dev:amd64:
libpango1.0-dev:amd64 depends on libglib2.0-dev (>= 2.59.2); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libpango1.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prNo apport report written because the error message indicates its a followup error from a previous failure.
No apport report written because the error message indicates its a followup error from a previous failure.
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
event configuration of libcairo2-dev:amd64:
libcairo2-dev:amd64 depends on libglib2.0-dev; however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libcairo2-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libatk1.0-dev:amd64:
libatk1.0-dev:amd64 depends on libglib2.0-dev (>= 2.31.2); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libatk1.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libatspi2.0-dev:amd64:
libatspi2.0-dev:amd64 depends on libglib2.0-dev (>= 2.4.1-2); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libatspi2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libgtk-3-dev:amd64:
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
No apport report written because MaxReports is reached already
libgtk-3-dev:amd64 depends on libatk1.0-dev (>= 2.15.1); however:
Package libatk1.0-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libcairo2-dev (>= 1.14.0); however:
Package libcairo2-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libglib2.0-dev (>= 2.57.2); however:
Package libglib2.0-dev:amd64 is not configured yet.
libgtk-3-dev:amd64 depends on libpango1.0-dev (>= 1.41); however:
Package libpango1.0-dev:amd64 is not configured yet.
dpkg: error processing package libgtk-3-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libharfbuzz-dev:amd64:
libharfbuzz-dev:amd64 depends on libglib2.0-dev (>= 2.19.1); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libharfbuzz-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libnotify-dev:amd64:
libnotify-dev:amd64 depends on libglib2.0-dev (>= 2.26); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libnotify-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libatk-bridge2.0-dev:amd64:
libatk-bridge2.0-dev:amd64 depends on libglib2.0-dev (>= 2.4.1-2); however:
Package libglib2.0-dev:amd64 is not configured yet.
libatk-bridge2.0-dev:amd64 depends on libatspi2.0-dev; however:
Package libatspi2.0-dev:amd64 is not configured yet.
dpkg: error processing package libatk-bridge2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
dpkg: dependency problems prevent configuration of libgdk-pixbuf2.0-dev:amd64:
libgdk-pixbuf2.0-dev:amd64 depends on libglib2.0-dev (>= 2.37.6); however:
Package libglib2.0-dev:amd64 is not configured yet.
dpkg: error processing package libgdk-pixbuf2.0-dev:amd64 (--configure):
dependency problems - leaving unconfigured
Errors were encountered while processing:
libpcre16-3:amd64
libpcre3-dev:amd64
libglib2.0-dev:amd64
libpango1.0-dev:amd64
libcairo2-dev:amd64
libatk1.0-dev:amd64
libatspi2.0-dev:amd64
libgtk-3-dev:amd64
libharfbuzz-dev:amd64
libnotify-dev:amd64
libatk-bridge2.0-dev:amd64
libgdk-pixbuf2.0-dev:amd64
E: Sub-process /usr/bin/dpkg returned an error code (1)
Hi Nicky, thanks for the post.
I have one question. How can I revert that changes? Recently was arrived Windows 11 and this problem was solved with the new windows update.
When I try to open cypress without opening the "xserver", wsl is attempting to open with that way and then after some seconds open with native feature of windows 11.
How can revert this changes to open apps directly with windows 11 native feature?
Works like a charm!
It's amazing that we can do this with WSL. Microsoft did a very good work. And you did a good work too with this post, thank you!
No more necessary if you have WSL2 updated and Win11 (but also Win10 updated). You can install browser .deb pkg and after launch cypress --browser name-expected
Wow, what a service to the world for getting this all organized. Thank you for writing this, I was convinced that it was a no-go getting cypress to work on Windows 10 + WSL!
Works great for me, thank you very much!