From 33058f2b292b3a581333bdfb21b8f671898c5060 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Tue, 8 Dec 2020 14:40:17 -0500 Subject: initial commit --- .../gaia_performance_tests/index.html | 109 ++++++++++++++++++ .../automated_testing/gaia_unit_tests/index.html | 113 +++++++++++++++++++ .../archive/b2g_os/automated_testing/index.html | 124 +++++++++++++++++++++ 3 files changed, 346 insertions(+) create mode 100644 files/zh-cn/archive/b2g_os/automated_testing/gaia_performance_tests/index.html create mode 100644 files/zh-cn/archive/b2g_os/automated_testing/gaia_unit_tests/index.html create mode 100644 files/zh-cn/archive/b2g_os/automated_testing/index.html (limited to 'files/zh-cn/archive/b2g_os/automated_testing') diff --git a/files/zh-cn/archive/b2g_os/automated_testing/gaia_performance_tests/index.html b/files/zh-cn/archive/b2g_os/automated_testing/gaia_performance_tests/index.html new file mode 100644 index 0000000000..12c0633e43 --- /dev/null +++ b/files/zh-cn/archive/b2g_os/automated_testing/gaia_performance_tests/index.html @@ -0,0 +1,109 @@ +--- +title: Gaia 性能测试 +slug: Archive/B2G_OS/Automated_testing/Gaia_performance_tests +translation_of: Archive/B2G_OS/Automated_testing/Gaia_performance_tests +--- +
+

本文主要讲述了有关在 Gaia 上运行性能测试以及如何创建新的测试。

+
+

运行测试

+

The tests are run on a regular basis on Datazilla; however, you can also run them yourself. To do so, you'll need an engineer build with Marionette enabled and remote debugging disabled. See Gaia Build System Primer, Customizing the preferences for more information on how doing this.

+

测试需求

+

Since bug 915156 landed on December 6th 2013, make test-perf requires Node.js on the host to run the tests. The relevant modules should be installed automatically with npm.

+

Prior to running the test, you need to configure a runner host. The runner host is a module that will either run the test in B2G desktop or on a device (real or virtual — like an emulator). By default it runs in B2G desktop, which is not very relevant for performance. To configure the runner just edit the file local.mk in the Gaia top level directory (create it if it doesn't already exist) and put the following line:

+
MARIONETTE_RUNNER_HOST=marionette-device-host
+

This will use the device host runner. The default value is marionette-b2gdesktop-host.

+

The alternative to this is to do:

+
MARIONETTE_RUNNER_HOST=marionette-device-host make test-perf 
+
+

Note: only one device at a time is supported, either an emulator or real device. Make sure you have an up-to-date Gaia version running on it.

+
+

输出

+

By default the test output the data in JSON format. By default it is output to stdout and might be mixed with error message from other commands like npm. This is not a very good idea for automation. So you can redirect this JSON output to a file. Just define MOZPERFOUT for the host runner, either on the command line as an option or in the local.mk file as shown above.

+
MOZPERFOUT=myfile.json
+

There is a "spec" reporter that allow reporting the output in a more human readable format. To use it, set the environment as follow:

+
REPORTER=ConsoleMozPerf
+

This will make the test output something easier to read. Not easier to parse. There is no real syntax.

+

For now, any other value will use the JSON reporter.

+
+

Note: MOZPERFOUT will be honoured whichever reporter you select.

+
+

对所有 app 运行测试

+

In general you can run these test on 1.4 and up from Gaia master. 1.3 might no longer be able to have the tests runs. There is an exception for 1.3t (Tarako). since bug 1006064 landed, if you want to run the tests against Tarako (1.3t), you should run it from the Gaia 1.3t.

+

From 2.0 and onwards, we consider that you should run the test from the same Gaia tree.

+
make test-perf
+

对指定的 app 运行测试

+
APP=browser make test-perf
+

对多个 app 运行测试

+
APPS="browser communications/contacts" make test-perf
+

Setting the number of runs

+

By default, each test is run five times. You can change that by setting the value of RUNS before running the tests. For example, to run each test three times you'd use this option:

+
RUNS=3 make test-perf
+

已知问题

+

When running test on Buri/Hamachi (Alcatel one touch fire), you get:

+
Not enough fields given the number of keys.
+

You can safely ignore the warning. It is just that b2g-info on the device is too old as it comes from 1.2 and we only change Gecko and Gaia on these.

+

Writing new tests

+

With the details of running the test suite out the way, let's now look at how you can write your own performance tests for Gaia.

+

Startup event tests

+

We have setup a standard for app startup events. If you want to test the app startup, please follow the responsiveness guidelines. The startup_event_test.js test will drive it. Make sure to whitelist your app in /tests/performance/startup_events_test.js, by adding it to the list specified by whitelistedApps. Also as a transition measure, you should add it to  whitelistedUnifiedApps which list the apps that use that new method. Once all the apps will be migrated, then we this will disappear - if you can't find it that mean it is not needed anymore.

+
+

Note: this is only implemented in 2.0 and later. If you code use startup-path-done events then it is using the old style and should be updated.

+
+

If you want to measure intermediate launch stages that are not part of the reponsiveness standard, you can dispatch these using the method described below. Dispatching performance events is all you need, they will be collected automatically.

+

其他的 event 基础测试

+

Now if you want to test specific features in your app you can do so by sending events. The test will be in two part. The instrumentation part that lives in the app itself, and the control part that will use marionette to control the app to perform actions.

+

Instrumentation

+

To record the events, all you have to do is dispatch them.

+

First, include our helper in your app:

+
<script defer src='/shared/js/performance_testing_helper.js'></script>
+
+
+

Note: If you use a module loader like RequireJS or Alameda, you might prefer to use that, which is perfectly fine.

+
+

You need to be cautious and make sure you adjust the unit tests so that the PerformaceTestingHelper is either loaded or shimmed. A simple shim is to put this in the unit test source file:

+
var PerformanceTestingHelper = {
+  dispatch: function() { }
+};
+
+

The Travis CI jobs we run out of Github will error if you don't do that properly.

+

Having done that, you can use the helper to dispatch events when it seems appropriate to do so. First you should dispatch a start event. It is important as the 'start' event is sent when we register the listeners, so for your feature you likely want to do this much later. So choose where the feature start and add the proper event dispatch.

+
PerformanceTestingHelper.dispatch('my-feature-start');
+
+

When you're ready to stop collecting data and to report the numbers, you need to send the my-feature-done event, also called the last event, to tell the helper to finish:

+
PerformanceTestingHelper.dispatch('my-feature-done');
+

Also you might want to send intermediate events as appropriate.

+
+

Note: Here we use "my-feature-" as a prefix for the performance event. This is just an example. Please use an obvious name and try to use it consistently.

+
+

Controlling the app

+

The second part is writing a JavaScript to the test framework to perform the test. The filename must end with _test.js and live in apps/<myapp>/test/performance/.

+

It is a lot like a marionette integration test (based on mocha), but with a few twists: in the setup() function you must inject the helper atom that is being used to collect the performance events.

+
PerformanceHelper.injectHelperAtom(client);
+

You must pass a lastEvent parameter to the PerformanceHelper constructor. This will be the last event on which to wait to test your feature.

+

When calling performanceHelper.reportRunDurations() toward the end you must pass the name of the start event you dispatched, otherwise the measurement will be from the start, ie when we inject the helper atom. An easy to figure out the error is if you see the start event in the results. And in that case you'll the the startup events as well as these will be dispatched too.

+
+

Note: you may want to look at existing test to get a better idea.

+
+

Collecting memory statistics

+

You can collect the memory usage for both the b2g process and the current app. Just do

+
var memUsage = performanceHelper.getMemoryUsage(app);
+

app is the application object. memusage will contain several objects enumerating the memory statistics.

+

Running tests from a non-engineering device

+

If you don't have an engineering build on your phone you'll have to do some additional steps:

+
    +
  1. Clone B2G, and build with ./config.sh DEVICE-NAME (e.g. ./config.sh keon)
  2. +
  3. Build the Gecko part via ./build.sh gecko
  4. +
  5. Connect the phone and flash gecko via ./flash.sh gecko
  6. +
  7. Clone Gaia, and create a file build/custom-prefs.js with content user_pref("marionette.defaultPrefs.enabled", true);
  8. +
  9. Enable Remote Debugging on the phone and run make reset-gaia to reset the phone (or make install-gaia if you trust yourself)
  10. +
  11. Disable Remote Debugging and verify that everything is OK by running adb devices. The device should show up.
  12. +
  13. Now running a perf test should work. Verify via RUNS=1 APP=browser make test-perf
  14. +
+

提交 bug

+

Please file bugs in Bugzilla, product "Firefox OS", component "Gaia::PerformanceTest".

+

参考

+ diff --git a/files/zh-cn/archive/b2g_os/automated_testing/gaia_unit_tests/index.html b/files/zh-cn/archive/b2g_os/automated_testing/gaia_unit_tests/index.html new file mode 100644 index 0000000000..f5d1fb609c --- /dev/null +++ b/files/zh-cn/archive/b2g_os/automated_testing/gaia_unit_tests/index.html @@ -0,0 +1,113 @@ +--- +title: Gaia 单元测试 +slug: Archive/B2G_OS/Automated_testing/Gaia_unit_tests +tags: + - B2G + - Firefox OS + - Gaia + - Mobile + - tests + - 单元测试 + - 构建文档 + - 自动化 +translation_of: Archive/B2G_OS/Automated_testing/Gaia_unit_tests +--- +
+

作为 Gaia/B2G 源码的一部分,我们已经创建了多个可运行的单元测试,来测试 Gaia 和 B2G 的不同方面。本文则讲述了如何来访问它们。

+
+
+

注意: 本文假设您已经完全理解 Gaia 和 B2G 是如何工作的。可参考 Hacking Gaia 来开始学习 Gaia。

+
+

运行单元测试

+

您可以在  B2G desktop 或 Firefox Nightly 上运行单元测试。您也需要最新的 Gaia 仓库。为了能够执行绝大部分功能,您必须要安装 Node.js 和 NPM

+
+

注意: 当在安装 test-agent 依赖时,如果下面的命令会因为一种神秘的错误而失败,可能是由于您的 Node.js/NPM 版本太老了。请阅读 通过包管理器来安装 Node.js 以安装最新的版本,并且将 /tools/test-agent/node_modules 文件夹删掉。

+
+

在 Gaia 仓库中有一个 bin/gaia-test 脚本文件, 可以帮助我们以简单的方式运行测试。

+
+

小心: this script will generate a profile suited for unit tests in profile-debug. If you already have another profile in this directory it will be overwritten. Bug 980496 aims to make this configurable.

+
+

在 Firefox 中启动 test runner

+

This will run the test server and launch your default Firefox as found in the path:

+
bin/gaia-test
+

选择 Firefox 二进制

+

You can export the FIREFOX environment variable to your firefox binary. For example, on MacOS X:

+
export FIREFOX=/Applications/FirefoxNightly.app/Contents/MacOS/firefox
+

Alternatively, you can pass it as argument to bin/gaia-test:

+
bin/gaia-test <gaia directory> <firefox path>
+

使用 B2G Desktop 启动 test runner

+

This will download and launch B2G Desktop:

+
bin/gaia-test -d
+

Run the tests from the Web Interface

+

You can simply click on specific tests and then the Execute button.

+

Run the tests from the command line

+

With the WebSocket server running, and the Test Agent app running in B2G Desktop/Firefox Nightly, run the following command:

+
make test-agent-test
+
+

If you only want to run one app's tests you can specify which via the APP env variable:

+
make test-agent-test APP=calendar
+
+

You can also optionally provide a reporter to format the test output:

+
make REPORTER=List test-agent-test
+
+
+ Note: Not all reporters work, since we currently do not support Doc.
+

Run the tests as you save

+

When the server is running, the tests for a file are run automatically when a file is saved or even just touched:

+ +
+

Note: It watches only existing files so if you create a new file, you have to restart the agent.

+
+

Running tests like TBPL does

+

Gaia unit tests in TBPL are run using a separate runner; this explains how to use it.  Please consult the virtualenv docs if you're not familiar with using a Python virtualenv.

+
virtualenv venv
+source venv/bin/activate
+cd $GAIA/tests/python/gaia-unit-tests
+python setup.py develop
+cd gaia_unit_test
+python main.py --binary /path/to/b2g/desktop/build --profile /path/to/gaia/profile
+
+
+

Note: When specifying the path to the B2G desktop build, you should specify the path to b2g-bin, if it exists, otherwise use b2g.

+
+

The Gaia profile must be made using the following:

+
NO_LOCK_SCREEN=1 DEBUG=1 DESKTOP=0 make
+

By default, this profile will be generated in $GAIA/profile-debug. bin/gaia-test generates the same profile so you don't need to regenerate it if you already run gaia-test.

+

Disabling a gaia unit test in TBPL

+

TBPL uses a blacklist to exclude certain gaia unit tests from being run.  To prevent a test from running in TBPL, add its path to https://github.com/mozilla-b2g/gaia/blob/master/tests/python/gaia-unit-tests/gaia_unit_test/disabled.json.

+

设置您的 Gaia 应用

+

Although this guide should help make things easier, the best way to learn how to write, set up, and run tests is currently still to look at the source code; in particular, take a look at the gallery tests.

+

Using mocks

+

TBD

+

进阶: 脚本在做什么?

+

产生一个 profile

+

You need a profile that is generated by this command:

+
NO_LOCK_SCREEN=1 DEBUG=1 DESKTOP=0 make
+
+

This generates a debug profile in gaia/profile-debug, overriding a previous profile if you already have one.

+ +

启动 WebSocket 服务器

+

Test agent (the test runner) ships with a built in WebSocket server that lets you remotely message the browser or device to queue a test run. Often you will want to develop with time saving features like a file watcher that will run your tests when a test file or implementation changes. To take advantage of these features you need to start the server:

+
make test-agent-server
+
+

Using the WebSocket server provides other tools such as a command line reporter for test results (watch the terminal you ran the command from), a Growl reporter, syntax error notifications, and more.

+

The agent also watches for modifications in files, and automatically runs the associated tests. It runs when you save the test or if you save the tested file (we use the convention where the test filename is the tested filename with _test appended, see below for more examples). It watches only existing files so if you create a new file, you have to restart the agent.

+

在 Firefox OS Nightly 运行单元测试

+

You can launch Gaia in Firefox Nightly with the following commands:

+
cd <path to gaia>
+<path to nightly>/firefox --no-remote -profile <path to gaia>/profile-debug/ http://test-agent.gaiamobile.org:8080/
+
+

Note: In Mac OSX, The profile path should be absolute path

+
+

You can use Firebug or the integrated debugger to debug the tests; use the debugger keyword to break in the debugger.

+

使用 B2G Desktop 运行单元测试

+

Launch Gaia and start the "Test Agent" app. From the Test gent app you can select tests to run from the UI.

+

进阶: test-agent 如何工作?

+

The Test Agent lives in its own Github repository. You can have look there to understand how it works under the hood.

diff --git a/files/zh-cn/archive/b2g_os/automated_testing/index.html b/files/zh-cn/archive/b2g_os/automated_testing/index.html new file mode 100644 index 0000000000..a5c2c58f11 --- /dev/null +++ b/files/zh-cn/archive/b2g_os/automated_testing/index.html @@ -0,0 +1,124 @@ +--- +title: Firefox OS 自动化测试 +slug: Archive/B2G_OS/Automated_testing +tags: + - B2G + - QA + - 测试 + - 自动化测试 +translation_of: Archive/B2G_OS/Automated_testing +--- +

+
+

Firefox OS 仍然处在开发中,在可预见的未来中则会对新的硬件加以支持,如何对其进行测试则显得非常重要。 该页面提供的文档主要是对 Firefox OS 多方面进行测试的信息,包括运行不同的测试,自动化,获取报告以及跟踪等。 

+
+

入门

+
+
+ Firefox OS 中运行测试: 开发者指南
+
+ 这是一个运行测试时入门级的快速开发指南。如果您对 Mozilla 测试和自动化系统没有什么接触,则需要从此处开始。有经验者,则可能对如何运行及怎么运行感兴趣,可以跳过该指南,去学习下面更具体的细节知识。
+
+

Gaia 测试

+

这些文章涵盖了主要的 Gaia 测试套件。

+
+
+ Gaia UI 测试
+
+ 主要针对 Gaia UI 交互和特性的 Python 测试。
+
+ Gaia 集成测试
+
+  基于 Marionette, 针对 Gaia 的 JavaScript 的集成测试。
+
+ Gaia 单元测试
+
+ 无 UI 交互的 Gaia 单元测试; 使用 JavaScript 实现,并不基于Marionette。
+
+ Gaia 性能测试
+
+ 基于内部仪器来测量 Gaia app 性能,是树状的测试框架。
+
+

B2G 测试

+

下面的指南涵盖了多个不同的测试框架,用于测试 B2G 功能的各个方面。

+
+
+ Mochitests
+
+ Gecko 功能和API 测试;基于 HTML & JS。没有与 Gaia 交互。
+
+ Reftests
+
+ Gecko 渲染正确性测试。
+
+ WebAPI tests
+
+ Gecko 基于 JS WebAPI 测试;绝大多数需要一个模拟器。
+
+ xpcshell tests
+
+ Gecko XPCOM APIs 无头绪测试
+
+ B2GPerf
+
+ 基于内部仪器来测量 Gaia app 性能。
+
+ Eideticker
+
+ 提供了基于视频捕捉的 Firefox OS 性能测量。
+
+ 耐久性测试
+
+ 长期运行的重复性测试,用于发现内存泄漏和稳定性问题。
+
+ MTBF 测试
+
+ 这是一个基于 non-restart gaia-ui-test 的测试框架。它会试图找到阻碍长时间运行测试的各种问题点。(当前,它由台湾团队来完成,仍然是一个开发中的测试框架)
+
+ 内存测试 — 即将推出
+
+ Repetitive tests run per-commit to mozilla-central, reporting to https://areweslimyet.com/, designed to find problems with memory usage.
+
+

辅助文档

+

This section provides links to some of the supporting technologies that underpin Mozilla's tests, which you may want to find more information about.

+
+
+ Marionette
+
+ 基于 Selenium WebDriver 的远程测试驱动程序。
+
+ Marionette JavaScript tests
+
+ A node.js-based runner for Marionette.
+
+ Marionette Python tests
+
+ A Python runner for Marionette.
+
+
+

Note: If you want to run Marionette against a production build (to run gaia integration tests, gaia-ui-tests, etc.), you can install Marionette as an extension (this currently only works for 1.3 builds, but more support will be added soon.)

+
+

持续性集成测试和结果报告

+

The following articles cover the continuous integration and result reporting mechanisms Mozilla uses to store and intepret test data.

+
+
+ TBPL
+
+ Understand the tests and builds that run on TBPL.
+
+ Jenkins
+
+ Understand the tests that are run on real devices via Jenkins.
+
+ Datazilla
+
+ Understand which performance tests are reporting to the Datazilla dashboard, and what those tests measure.
+
+ Test execution chart
+
+ A chart showing which tests are being run — on what devices and where — and which platforms are supported for each test.
+
+
+
+  
+
-- cgit v1.2.3-54-g00ecf