Please read Build instructions first. This document focuses on testing related topics.
Are you a Google employee? See go/lacros-test instead.
Depends on which workflow you use, they support different test targets.
See Lacros: Test instructions(linux).
These tests are running on CI: linux-lacros-tester-rel and CQ: linux-lacros-rel.
See Lacros: Test instructions(DUT)
Same as above.
Unit tests should always be provided. We’re targeting per file unit test coverage of 70%.
This refers to the tests in the browser_tests target. If your test is primarily testing that your feature should work on Lacros, and your test will not cause Lacros to call mojo crosapi, you should add a Lacros browser tests. crosapi browser tests (lacros_chrome_browsertests) If you’re testing crosapi, you need to add your test to lacros_chrome_browsertests.
If your test is primarily testing Ash, but also requires Lacros to present, you should add ash browser tests. The main difference is that browser() call in the test will return an ash browser instance.
Note: if it’s fine to use lacros browser test or ash browser test, then please add lacros browser test. Lacros browser test only start Ash once, then create new Lacros for every test case.
However for ash browser test, for every test case it starts Ash as wayland server every time, and then starts an ash browser and a Lacros browser. So in theory, for the same test written in different approaches, Lacros browser test is faster and more stable.
If your feature is hard/impossible to test on Linux, you should provide a Tast test running on real cros devices or cros VM.
CI/CQ linux lacros builder runs unit tests, browser tests, version skew tests.
CI builder using official gn args and running some Tast tests on DUT.
Corresponding arm builder.
CI and optional tryjob for running lacros tests with dbg gn args.
And also various of ash builders like chromeos-eve-chrome. If your cl only changes ash, you can check ash builders which ensure your ash change doesn’t break lacros.