CI Automation/windows10 aarch64

From MozillaWiki
Jump to: navigation, search


Since mid-January 2019 the CI-A team has been working to enable existing test harnesses, continuous integration tests and other tools to run on Windows 10 ARM64.

General Information


  • Make: Lenovo
  • Model: C630 YOGA
  • Processor: Qualcomm Snapdragon 850 3.0GHz
  • Cores: 8
  • Memory: 8GB
  • Disk: 128GB SSD


Currently an array of 9 machines are hosted at Bitbar in the United States.


Tests that are run against windows10-aarch64 execute using Taskcluster Generic-Worker. These are installed as a service on the Windows 10 ARM64 manually or via OpenCloudConfig.

A brief walkthrough of the steps to have Taskcluster Generic-Worker running on Windows 10 ARM64 will be provided.

Using only generic-worker

Follow this step to install Taskcluster Generic-Worker on the hardware, and have it launch as a service. After following these steps, the hardware should be ready to accept any tasks started on Taskcluster.

Instruction originally from 1522997.


  • disable Windows S mode
  • disable User Account Control
  • disable Windows Firewall
  • download NSSM to C:\nssm-2.24\
  • create "Remote Desktop Users" group:
net localgroup "Remote Desktop Users" /add
  • log in to Taskcluster
  • request scope `assume:project:taskcluster:generic-worker-tester`


  1. download the current 386 release of `generic-worker-windows-386.exe` from taskcluster generic-worker.
  2. download the latest 386 version of livelog.exe and taskcluster-proxy.exe.
  3. create new directory C:\generic-worker.
  4. move the three executable files under C:\generic-worker.
  5. rename generic-worker-windows-386.exe to generic-worker.exe.
  6. generate two signing keys:
generic-worker new-openpgp-keypair --file <unique_file_name>
generic-worker new-ed25519-keypair --file <unique_file_name>
  1. create generic-worker.config and include the following:
"accessToken":                "<access token tied to taskcluster>",
"clientId":                   "<client ID tied to taskcluster>",
"ed25519SigningKeyLocation":  "<file location you wrote ed25519 private key in step 6>",
"livelogSecret":              "<any text>",
"openpgpSigningKeyLocation":  "<file location you wrote gpg private key kn step 6>",
"provisionerId":              "test-provisioner",
"publicIP":                   "<ideally an IP address of one of your network interfaces>",
"rootURL":                    "",
"workerGroup":                "test-worker-group",
"workerId":                   "test-worker-id",
"workerType":                 "<a unique string that only you will use for your test worker(s)>"
  1. launch cmd.exe with Administrator rights.
  2. cd c:\generic-worker
  3. generic-worker.exe install service --config generic-worker.config --nssm c:\nssm-2.24\win32\nssm.exe
  4. reboot once installed.
  5. launch cmd.exe with Administrator rights.
  6. sc query "Generic Worker"

Using OpenCloudConfig

This is the method that is used in production.

Steps originally taken from 1520432.

  1. Invoke-Expression (New-Object Net.WebClient).DownloadString('')

Currently Running

Currently supported list of tests include:

  • awsy
  • mochitest (all flavors, including e10s)
  • web-platform-tests (all flavors)
  • reftests (including crashtest, jsreftest)
  • xpcshell

Supported, requires non-artifact build:

  • jittest
  • gtests
  • cppunittest

There is remaining work needed to get these test suites running:

  • talos
  • raptor
  • marionette

For an up-to-date list of tests, please refer to this file.

Run tests Locally

Theoretically, you can run tests locally with mach from a local build environment. However, since our aarch64 builds are usually cross-compiled in an x86 environment, you probably don't have a local build environment!

The recommended alternative is to use mozharness to download, install, and test a build from try or continuous integration. A handy script is provided as an attachment to bug 1520867 that greatly simplifies running tests from mozharness; let's call that script 'moztest'.

Run moztest from a MozillaBuild shell. You need only a few parameters:

  • The task-id of the Windows-aarch64 build that you want to test: Click on the aarch64 build in treeherder, and copy the "Task" shown in the treeherder detail pane; it might look like "Q-CE8DFvSAWmc08vw6bd6A".
  • The name of the test suite you want to run: one of (cppunit, gtest, xpcshell, mochitest, mochitest-chrome, mochitest-clipboard, mochitest-dt, mochitest-gpu, mochitest-media, crashtest, jsreftest, reftest, jittest, web-platform, web-platform-reftest, web-platform-wdspec, raptor-speedometer, raptor-tp6, talos-g5, talos-chromez)
  • Optionally, the test "chunk" number to run and the number of test chunks to split the suite into.

For example:

  • moztest Q-CE8DFvSAWmc08vw6bd6A cppunit
  • moztest Q-CE8DFvSAWmc08vw6bd6A xpcshell 1 3

Run tests on Try

This is probably what you came to the document for. How to run tests against the windows10-aarch64 hardware currently available. Note, the number of hardware is limited so please exercise caution when scheduling tests.


Follow these steps to be able to enable windows10-aarch64 tests for the try server. These steps are required as of 2019-02-25; it will become obsolete when windows10-aarch64 tests are released to the general public.


  • try access (commit access level 1)
  • up-to-date mozilla-central codebase


  1. open the file at taskcluster/ci/test/test-platforms.yml
  2. search for 'windows10-aarch64/opt'
  3. uncomment all or some of the items under 'test-sets'
  4. make changes to the local codebase that needs testing
  5. ./mach try fuzzy
  6. select tests that need to be run (e.g. 'windows10-aarch64 xpcshell')
  7. enter

Tests will appear in Treeherder under the heading windows10-aarch64 opt.

Greening tests

Since Windows on ARM64 is a new platform/architecture combination, failures unique to this combination is to be expected. It will be necessary to fix, correct or update the tests in order to obtain a green run.

Example 1

As part of 1525743, the timeout for mochitest-browser-chrome was extended to 4x the default value if the platform combination of Windows and ARM64 is detected.

See change:

This change greened the test that was previously failing due to a timeout.

Example 2

Some tests provide a manifest file in the form of <test_category>.ini, such as mochitest.ini.

For bug 1525665 it was determined to disable a certain a11y test while windows10-aarch64 a11y support was being investigated.

See change:

This change meant the failing test is now disabled for windows10-aarch64, and the test would have been green had it not been for another failure elsewhere.

Example 3

Another example of manipulating the manifest of a category of tests, this time with web-platform-tests.

For Bug 1533912 the manifest was modified to disable the test if it was running on aarch64 hardware.

See change:

Note that web-platform-tests use a slightly different format in order.


These are the top-level tracking bugs; the recommended view is tree (login required).

Full Query
ID Summary Priority Status
1520867 Investigate running tests on Windows / arm64 P1 RESOLVED
1523722 Run gtest using generic-worker on Windows/aarch64 P3 ASSIGNED
1524114 Run xpcshell-test using generic-worker on Windows/aarch64 P3 ASSIGNED
1524400 Run mochitest using generic-worker on windows/aarch64 P3 ASSIGNED
1524410 Run reftest suites using generic-worker on windows/aarch64 P3 ASSIGNED
1525118 [meta] Run taskcluster task from mach try on Bitbar -- RESOLVED
1525434 Run web-platform-test suite using generic-worker on windows/aarch64 P3 NEW
1526015 Run cppunit, jittest, marionette using generic-worker on Windows/aarch64 P3 NEW
1527177 Intermittent [taskcluster:error] [mounts] reading file in zip archive: file already exists: Z:\task_1549919043\mozharness\LICENSE P5 RESOLVED
1527469 Enable windows10-aarch64 build and tests on try server -- RESOLVED
1530737 unable to run talos/raptor on win/aarch64 builds in CI -- RESOLVED
1531876 run talos/raptor tests on windows10 aarch64 laptops -- ASSIGNED
1531878 [taskcluster:error] [mounts] reading file in zip archive: file already exists: C:\tasks\task_1551392763\mozharness\LICENSE P1 NEW
1531927 windows/aarch64 - skipped/disabled media tests P5 REOPENED
1533114 windows/aarch64 - skipped/disabled a11y tests P5 NEW
1533880 windows/aarch64 - skipped/disabled web-platform-tests P5 NEW
1534823 windows/aarch64 - skipped/disabled mochitest tests P5 NEW
1535467 windows/aarch64 - test screenshots sometimes show "Windows Defender Firewall has blocked some features of this app" P3 ASSIGNED
1536208 windows/aarch64 - skipped/disabled xpcshell tests P5 NEW
1536283 windows/aarch64 - skipped/disabled marionette tests P5 NEW
1536354 windows/aarch64 - skipped/disabled reftests P5 NEW

21 Total; 16 Open (76.19%); 5 Resolved (23.81%); 0 Verified (0%);