Author: Zeng Xia, wechat client test development

Commercial reprint please contact Tencent WeTest for authorization, non-commercial reprint please indicate the source.

The original link: wetest.qq.com/lab/view/30…


In April 2017, Penguin Smart Cool released the latest wechat Users & Ecology Research Report 2017. Data from the report shows that as of December 2016, wechat has 889 million monthly active users worldwide, and the emerging public account platform has 10 million. Wechat has directly driven information consumption of 174.25 billion yuan this year, equivalent to 4.54% of China’s total information consumption in 2016.

(//blog-10039692.file.myqcloud.com/1493294279807_7062_1493294279733.jpg)

With such a large number of users, it also means that a small problem with wechat will affect a large number of user experience. Based on this, wechat pays great attention to quality.

At present, many domestic hardware manufacturers, for Android version, deeply customize their ROM, system version, such as Xiaomi MIUI, Huawei EMUI, Lenovo VIBEUI, etc.. This is N vendors multiplied by M versions, resulting in an explosion in the number of versions, resulting in various adaptation problems.

It took a lot of effort and time to adapt the wechat app to so many devices. In this environment, the wechat team is relying on automated testing, hoping to put more testing links in the cloud to run automatically.

I. Quality issues that wechat pays most attention to

Compatibility test covers a large number of links, and wechat preferentially selects the core links for testing. And to test the link as far as possible to automate, cloud – oriented way to achieve. So, which issues are high priority?

1. The installation and startup fail

Installation and startup problems are among the most serious bugs. This kind of problem is relatively rare, but when it does appear, it is a big problem. The failure of installation and startup may result in insufficient monitoring data of wechat team. Sometimes, the team cannot actively find problems, and finally can only perceive such errors through user feedback. At this point, it may have had a significant impact on users.

For example, it was found that getDrawable API of some huawei and Samsung models was suspended, which caused some users of these two models to fail to start wechat. Although the number of users was not large, it was very serious. Installation and startup failures are the most basic requirements of compatibility testing.

2, Crash

Crash rate is an important criterion for wechat team to measure whether a version is stable, especially for new crashes. When the gray scale of the test package goes out, if the Crash rate is high or the proportion of new crashes is high, the wechat team will generally take measures of packet replacement and packet withdrawal. This will have a knock-on effect

1. Poor user experience

2. Additional work for development and testing

3. Caused a series of losses caused by the release delay

Therefore, the newly emerged Crash must be one of the quality standards wechat pays most attention to.

Two, the right medicine, find the problem in advance

Any of the compatibility issues mentioned above are extremely serious. Wechat team according to the accumulation and historical experience of peers, for different problems, do different tests.

1. For installation and startup issues — override installation tests

Overwrite installation, as the name implies, overwrites the old version with the new version of the application.

The test flow for an overridden installation is as follows:

As installation and startup problems are the most serious problems, the wechat team currently does coverage installation tests before release. The package to be released, after the successful installation and startup to ensure the normal operation of the basic functions of wechat. Each official version of wechat will basically modify the version number of the configuration, and Android will judge whether the App has been updated according to the version number. After the override is installed, the App has a special code to handle the update and ensure data compatibility. This value is used by third-party stores to check for software updates.

The process of covering the installation test is simple and simulates the scenario of real users upgrading the installation as much as possible. After the overwrite installation, when the user starts wechat, the background issues an upgrade instruction, which is mainly to confirm whether the data of the old version can be used in the new version. Finally, the smoke test is used to test whether the core functions of wechat (covering the main database) can pass normally. The wechat team attaches great importance to the coverage installation testing. In addition to monitoring some data compatibility problems, we also need to detect whether there are problems with the new packages. In addition, Tinker’s patch package also needs to undergo similar tests to ensure the success of patch and basic core functions.

The coverage installation test is only done before the release, because wechat is continuous integration development, and the packages on the distribution branch are always updated, so only the packages to be released will be done, and the external release will be carried out after passing.

2. Crash problem — stability test

The test corresponding to the Crash problem is the stability test. For app stability testing, the official test tool is Monkey. The Monkey generates a series of random events (the proportion can be configured) to test whether the target APP crashes.

Limitations of Monkey tests

The wechat team found that the Monkey did not detect the controls on the interface, so the resulting events were too random to meet wechat’s testing requirements. Therefore, wechat developed a control-based custom Monkey for stability testing.

To develop a custom Monkey based on controls, you first need to get all the views for your Activity.

Select the framework to modify the Monkey script

At the beginning, Robotium framework was adopted, but wechat itself is a multi-process App. For example, when opening album or webview, it is in a Tools process, while Robotium is only for a single process, so it needs to change the framework source code to support multi-process wechat App, which is cumbersome to implement. Therefore, the wechat team began to use the official framework UIAutomator later.

Using frames to get controls (Views)

Google doesn’t provide a public interface to get all the controls. Using selector is slow, because Google uses a lot of waiting in order to automate UI execution, and monkey tests require quick clicks. By referring to UIAutomator source code implementation, wechat team decided to use Java reflection principle to get AccessibilityNodeInfo, remove unnecessary waiting or reduce waiting events and increase retry times. AccessibilityNodeInfo has a one-to-one relationship to a View, which in UIAutomator corresponds to a UiObject. At present, many of the red envelope grabbing plug-ins also use AccessibilityService to get AccessibilityNodeInfo to do recognition and click.

The birth of the custom Monkey

With reflection, the speed of retrieving the current activity can be guaranteed to complete in the tens of milliseconds. Once you’ve got all the controls, you’re ready to explore them randomly!

In order to better traverse as many activities as possible, the wechat team adopted the modified deep traverse algorithm. We call this the “custom Monkey.” The logic for customizing the Monkey is simple, including special handling such as checking for pop-ups when returning, checking for pop-ups when opening the WebView (location), and checking for logins when running. At present, the effect of the transformation has been improved to a certain extent than the original effect. The following are the test results of the single machine:

As you can see from the figure above, there is approximately an 80% improvement in row coverage and approximately a 200% improvement in activity coverage compared to the native Monkey. As can be seen from the curve, both the row coverage and activity coverage of the two monkeys improved significantly within one hour after login, and slowly within one or two hours, and then very slowly after two hours.

Every day, the wechat team will take the apK package of the latest code for stability test, collect the Crash, and submit the bug of the new Crash to the corresponding development.

3. Model coverage — cloud-based testing

Compatibility testing is basically covering all models, and the wechat team is working on some automation solutions to run on multiple machines in parallel. The wechat team used a smaller number of machines for automation. The covered install tests and custom Monkey tests mentioned above may only run on a typical 6 to 10 models.

Now the compatibility test is migrated to the WeTest platform, which is based on the private cloud platform built by WeTest for wechat, and the public cloud model is used as a supplement.

At this point, wechat team has realized the cloud model management, equipment coverage has also been substantially improved.

Every day, the wechat team applied for hundreds of mobile phones to run several rounds of customized Monkey tests on the test platform, and recorded more than a dozen crashes on an average day. The peak period of some new features being launched was sometimes up to 40/50.

Other key quality issues — new function adaptation

In addition to the above problems, when the new function goes online, the wechat team will be very concerned about whether there will be new adaptation problems. For example, font truncation problems, keyboard problems and so on. More than a year ago, wechat released the small video function, and found that the video direction was wrong, black screen, playback failure and other problems caused by ROM customization by multiple manufacturers, which seriously affected the user experience.

Each version has functional compatibility issues, and each version is tested differently. The current approach is still relatively low-level, mainly relying on manpower to carry out compatibility tests and mass tests on mainstream models.

The variation between versions is so great that automation is in trouble

Functional testing is generally targeted at a specific version, so the automation script is basically only applicable to a specific version. The reusability is weak, and automation cannot bring good benefits. At the same time, the functional test path is sometimes more special, the automation script is difficult to write, verification trouble. For example, in the small video function test, the automatic script cannot determine whether there is a black screen or a broken screen, but it must be judged by human eyes.

Some features can be automated: semi-automated testing

Some features can be automated or semi-automated. For example, the H5 test is mainly to check whether the page has UI problems when opened on different phones. Semi-automated test scheme: generate test reports with a series of screenshots on key pages by scripting UI operations and Webview operations. Check the screenshot with naked eye afterwards to judge whether the test passed or not.

At present, we do not have a general solution to the functional compatibility problem, but make use of the current resources to do the best possible test according to different needs.

Functional automated tests migrate to the WeTest platform

For functional compatibility test, the wechat team also migrated H5 compatibility test and some high-priority automation cases to WeTest platform.

● Establishment of wechat private cloud: On the private cloud, wechat team continuously submits automated scripts for 24-hour testing. When the private cloud lacks a specific model, WeTest the model on the public cloud as a supplementary test.

● connection between wechat quality system and private cloud: WeTest opens some interfaces to wechat, and wechat uses these interfaces to build its own cloud quality management platform to intuitively and conveniently conduct test management, greatly improving efficiency.

Effect of four,

Through automated and cloud-based testing, the wechat team has more than doubled its efficiency in compatibility and function testing, and solved problems more quickly and accurately. Thousands of problems have been discovered and solved, covering hundreds of millions of users, providing a smooth and stable experience environment.

In the future, we expect cloud-based and automated testing to cover more test links in depth, so that the test process and test results become more smooth and visual. Through the power of technology, continue to improve the quality of products!


Enter the “expert compatibility test” interface immediately, find Tencent testing expert team to help you check the quality of mobile applications! Click on the link to use expert compatibility testing services: wetest.qq.com/product/exp…

Coinciding with WeTest’s great new season, there are mobile game experts compatible luxury package! Extra large discount not to be missed: wetest.qq.com/activities/…

You can contact Wetest assistant to understand the details of the discount first, consulting appointment (QQ: 800024531)


Dear readers, in order to provide better website content, we hope you fill in our questionnaire, we will randomly draw readers feedback 20Q coins to show our gratitude! Entrance: wj.qq.com/s/1221194/2…