2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Setting Up Build Bots
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-29 23:14:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								We currently have 5 build bots that produce 9 browser builds:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **`buildbot-ubuntu-18.04` ** 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `firefox-ubuntu-18.04.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `webkit-ubuntu-18.04.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **`buildbot-ubuntu-20.04` ** 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `webkit-ubuntu-20.04.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **`buildbot-mac-10.14` ** 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `firefox-mac-10.14.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `webkit-mac-10.14.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **`buildbot-mac-10.15` ** 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `webkit-mac-10.15.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **`buildbot-windows` ** 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `firefox-win32.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `firefox-win64.zip` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  `webkit-win64.zip` 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This document describes setting up bots infrastructure to produce
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								browser builds.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Each bot configuration has 3 parts:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Setup toolchains to build browsers 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Setup bot-specific environment required for bot operations 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  `azure-cli` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  setting `AZ_ACCOUNT_KEY` , `AZ_ACCOUNT_NAME` , `TELEGRAM_BOT_KEY`  env variables
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Running relevant build script `//browser_patches/buildbots/buildbot-*.sh`  using host scheduling system (cron on Linux, launchctl on Mac, polling on Win). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Windows ](#windows ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Setting Up Browser Toolchains ](#setting-up-browser-toolchains )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Setting Bot Environment ](#setting-bot-environment )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Running Build Loop ](#running-build-loop )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Mac ](#mac ) 
						 
					
						
							
								
									
										
										
										
											2019-12-11 14:04:18 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -  [Setting Up Browser Toolchains ](#setting-up-browser-toolchains-1 )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Setting Bot Environment ](#setting-bot-environment-1 )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Running Build Loop ](#running-build-loop-1 )
							 
						 
					
						
							
								
									
										
										
										
											2019-12-17 11:09:49 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [Linux ](#linux ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Setting Up Browser Toolchains ](#setting-up-browser-toolchains-2 )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Setting Bot Environment ](#setting-bot-environment-2 )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  [Running Build Loop ](#running-build-loop-2 )
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Windows
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setting Up Browser Toolchains
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								We currently use MINGW environment that comes with Firefox to run our buildbot infrastructure on Windows.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Browser toolchains:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Firefox: Follow instructions on [Building Firefox for Windows ](https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Windows_Prerequisites ). Get the checkout with mercurial and run "./mach bootstrap" from mercurial root. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  WebKit: mostly follow instructions on [Building WebKit For Windows ](https://trac.webkit.org/wiki/BuildingCairoOnWindows ). Use chocolatey to install dependencies; we don't use clang to compile webkit on windows. (**NOTE**: we didn't need to install pywin32 with pip and just skipped that step). 
						 
					
						
							
								
									
										
										
										
											2020-06-22 12:49:30 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Our WebKit port requires libvpx. Install [vcpkg ](https://github.com/Microsoft/vcpkg ) and build libvpx from source. Run the following commands in Windows Terminal as Administrator(required for bootstrap-vcpkg.bat). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```bash
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cd c:\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								git clone https://github.com/microsoft/vcpkg.git
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cd vcpkg
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								.\bootstrap-vcpkg.bat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								.\vcpkg.exe install libvpx --triplet x64-windows
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 If you install vcpkg in a different location, cmake files should be pointed to the new location (see `-DLIBVPX_PACKAGE_PATH`  parameter in [`buildwin.bat` ](https://github.com/microsoft/playwright/blob/master/browser_patches/webkit/buildwin.bat )).
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								After this step, you should:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  have `c:\mozilla-build`  folder and `c:\mozilla-source`  folder with firefox checkout. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  being able to build webkit-cairo from `cmd.exe` .  
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setting Bot Environment
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### 1. Install azure-cli
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Install [azure-cli ](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli-windows?view=azure-cli-latest ) for windows using MS Installer
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### 2. Export "az" to the mingw world
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 14:08:54 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The easiest away to export "az" to mingw is to create `c:\mozilla-build\bin\az`  with the following content:
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 14:08:54 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								cmd.exe /c "\"C:\Program Files (x86)\Microsoft SDKs\Azure\CLI2\wbin\az.cmd\" $1 $2 $3 $4 $5 $6 $7 $8 $9 ${10} ${11} ${12} ${13} ${14} ${15} ${16}"
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### 3. Install node.js 
  
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Node.js: https://nodejs.org/en/download/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### 4. Set custom env variables to mingw env
  
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Edit `c:\mozilla-build\start-shell.bat`  and add the following lines in the beginning:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```bat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SET AZ_ACCOUNT_NAME=< account-name > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SET AZ_ACCOUNT_KEY=< account-key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SET TELEGRAM_BOT_KEY=< bot_key > 
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								SET WEBKIT_BUILD_PATH=< value  of  " PATH "  variable  from  cmd . exe > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SET DEVENV="C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\Common7\IDE\devenv.com"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-04-20 10:11:01 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  **NOTE:** mind different quotes position in DEVENV="..." than in PATH (and WEBKIT_BUILD_PATH). This is important.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								And right before the `REM Start shell.` , change `PATH`  to export locally-installed node.js:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```bat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SET "PATH=C:\Program Files\nodejs\;%PATH%"
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Remarks:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  the `WEBKIT_BUILD_PATH`  value is the value of `PATH`  variable. To get the value, run `cmd.exe`  and run `PATH`  command. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  the `DEVENV`  variable should point to VS2019 devenv executable. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  change `<account-name>`  and `<account-key>`  with relevant keys/names. 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  **NOTE:** No spaces or quotes are allowed here!
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### 5. Disable git autocrlf and enable longpaths
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Run `c:\mozilla-build\start-shell.bat`  and run:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `git config --global core.autocrlf false`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `git config --global core.longpaths true`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `core.longpaths`  is needed for webkit since it has some very long layout paths.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 18:17:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-16 16:56:11 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  **NOTE:** If git config fails, run shell as administrator!
  
						 
					
						
							
								
									
										
										
										
											2019-12-11 18:17:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-04 08:01:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### 6. Checkout Playwright to /c/
  
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-04 08:01:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Run `c:\mozilla-build\start-shell.bat`  and checkout Playwright repo to `/c/playwright` .
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-17 11:59:41 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### 7. Create a c:\WEBKIT_WIN64_LIBS\ directory with win64 dlls
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Create a new `c:\WEBKIT_WIN64_LIBS`  folder and copy the following libraries from `C:\Windows\System32`  into it:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `msvcp140.dll`  
						 
					
						
							
								
									
										
										
										
											2020-03-09 11:43:11 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `msvcp140_2.dll`  
						 
					
						
							
								
									
										
										
										
											2020-01-17 11:59:41 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `vcruntime140.dll`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `vcruntime140_1.dll`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  **NOTE**: these libraries are expected by `//browser_patches/webkit/archive.sh`. 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This is necessary since mingw is a 32-bit application and cannot access the `C:\Windows\System32`  folder due to [Windows FileSystem Redirector ](https://docs.microsoft.com/en-us/windows/win32/winprog64/file-system-redirector?redirectedfrom=MSDN ). ([StackOverflow question ](https://stackoverflow.com/questions/18982551/is-mingw-caching-windows-directory-contents )) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								## Running Build Loop
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Launch `c:\mozilla-build/start-shell.bat`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Run `/c/playwright/browser_patches/buildbots/buildbot-windows.sh`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Disable "QuickEdit" terminal mode to avoid [terminal freezing and postponing builds ](https://stackoverflow.com/questions/33883530/why-is-my-command-prompt-freezing-on-windows-10 ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Mac
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setting Up Browser Toolchains
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Install XCode from AppStore 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Run XCode once and install components, if it requires any. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Install XCode command-line tools: `xcode-select --install`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Install homebrew: https://brew.sh/ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Mac 10.14 builds both firefox and webkit, whereas we only build webkit on mac 10.15.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Browser Toolchains:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Building Firefox On Mac ](https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Mac_OS_X_Prerequisites ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Building WebKit On Mac ](https://webkit.org/building-webkit/ ) (though as of Dec, 2019 it does not require any additional steps) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setting Bot Environment
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Install [`azure-cli` ](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli-macos?view=azure-cli-latest ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Clone `https://github.com/microsoft/playwright`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Run `//browser_patches/prepare_checkout.sh`  for every browser you care about 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								4.  Make sure `//browser_patches/{webkit,firefox}/build.sh`  works and compiles browsers 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Running Build Loop
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								We use `launchctl`  on Mac instead of cron since launchctl lets us run daemons even for non-logged-in users.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Create a `/Library/LaunchDaemons/dev.playwright.plist`  with the contents below (will require `sudo`  access).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Make sure to change the following fields:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Set values for all keys in the `EnvironmentVariables`  dict. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Put a proper path to the `Program`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Make sure to put correct `UserName`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 14:06:41 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```xml
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								<?xml version="1.0" encoding="UTF-8"?>  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< plist  version = "1.0" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < dict > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > Label< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < string > dev.playwright< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > Program< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < string > /Users/aslushnikov/prog/cron/playwright/browser_patches/buildbots/buildbot-mac-10.14.sh< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > UserName< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < string > aslushnikov< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > EnvironmentVariables< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < dict > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < key > PATH< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < string > /usr/bin:/usr/sbin< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < key > TELEGRAM_BOT_KEY< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < string > < / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < key > AZ_ACCOUNT_NAME< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < string > < / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < key > AZ_ACCOUNT_KEY< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < string > < / string > 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-12 15:59:17 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < key > MOZ_NOSPAM< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      < string > 1< / string > 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-11 11:43:05 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    < / dict > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > StandardOutPath< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < string > /tmp/launchctl-playwright-buildbot.log< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > StandardErrorPath< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < string > /tmp/launchctl-playwright-buildbot.errorlog< / string > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < key > StartInterval< / key > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < integer > 300< / integer > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / dict > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / plist >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Next, you can either use `launchctl load`  command to load the daemon, or reboot bot to make sure it auto-starts.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-12 15:59:17 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  **NOTE**: mozbuild uses [terminal-notifier](https://github.com/julienXX/terminal-notifier) which hangs
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  in launchctl environment. The `MOZ_NOSPAM` env variable disables terminal notifications.
  
						 
					
						
							
								
									
										
										
										
											2019-12-16 11:56:09 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Finally, MacBooks tend to go to sleep no matter what their "energy settings" are. To disable sleep permanently on Macs ([source ](https://gist.github.com/pwnsdx/2ae98341e7e5e64d32b734b871614915 )):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sudo pmset -a sleep 0; sudo pmset -a hibernatemode 0; sudo pmset -a disablesleep 1;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-17 11:09:49 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Linux
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Setting Up Browser Toolchains
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Note: firefox binaries will crash randomly if compiled with clang 6. They do work when compiled with clang 9. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To install clang 9 on ubuntu and make it default:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ sudo apt-get install clang-9
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-9 100
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ sudo update-alternatives --install /usr/bin/clang clang /usr/bin/clang-9 100
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-09 17:05:08 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								2.  FFMPEG cross-compilation requires Docker. Install docker and add `$USER`  to docker for sudo-less docker access 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ sudo apt-get install -y docker.io # install docker
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ sudo usermod -aG docker $USER # add user to docker group
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ newgrp docker # activate group changes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-29 23:14:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  **NOTE**: Firefox build config can be checked official Firefox builds, navigating to `about:buildconfig` URL.
  
						 
					
						
							
								
									
										
										
										
											2019-12-17 11:09:49 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-29 23:14:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To document precisely my steps to bring up bots:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [July 22, 2020: Setting up Ubuntu 18.04 buildbot on Azure ](https://gist.github.com/aslushnikov/a4a3823b894888546e741899e69a1d8e ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [July 22, 2020: Setting up Ubuntu 20.04 buildbot on Azure ](https://gist.github.com/aslushnikov/a0bd658b575022e198443f856b5185e7 )