干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

本文为霍格沃兹测试学院测试大咖公开课《微信小程序自动化测试》图文整理精华版。

随着微信小程序的功能和生态日益完善,很多公司的产品业务形态逐渐从 App 延升到微信小程序、微信公众号等。小程序项目页面越来越多,业务逻辑也越来越复杂,全手工测试已无法满足快速增长的业务需求。

然而,由于小程序本身的一些特性,导致业界目前缺乏成熟完善的解决方案,总会出现各种问题(包括腾讯微信官方提供的自动化工具)。如何做好小程序的自动化测试就成为测试同学当下普遍面临的一个痛点难题。

本节课就主要分享下微信小程序自动化测试的一些最佳实践心得,包括微信小程序的基本测试技术和操作方法,以及如何利用 Appium 的 WebView 测试技术 + adb proxy 完成微信小程序的自动化测试(可能是目前最实用的小程序自动化测试技术),并附上 Python 版源码。

小程序运行环境

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

平台差异:尽管各运行环境是十分相似的,但是还是有些许区别:

JavaScript 语法和 API 支持不一致:语法上开发者可以通过开启 ES6 转 ES5 的功能来规避(详情);此外,小程序基础库内置了必要的Polyfill,来弥补API的差异。

WXSS 渲染表现不一致:尽管可以通过开启样式补全来规避大部分的问题,还是建议开发者需要在 iOS 和 Android 上分别检查小程序的真实表现。

微信小程序技术架构

微信小程序技术架构如下图所示:

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

使用 Chrome 调试小程序

用 Chrome 浏览器提供的 inspect 分析工具,在浏览器中输入如下地址:

chrome://inspect/#devices

使用 Chrome 浏览器查看手机上打开的 WebView 进程与基本信息:

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

可以使用 chrome inspect 分析微信小程序的控件结构与布局:

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

使用 console 执行自己的 JavaScript 代码:

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

小程序的性能测试

这里附一张小程序性能测试图:

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

微信小程序的自动化测试

干货 | 微信小程序自动化测试最佳实践(附 Python 源码)

微信小程序自动化测试的关键步骤

  1. Native 原生自动化方式。
  2. 使用 Appium 即可完成,缺点就是控件定位不够准确,无法深入小程序内部;
  3. Webview 自动化方式:可以获取更多小程序内部质量数据。
  4. 设置 chromedriver 正确版本
  5. 设置 chrome option 传递给 chromedriver
  6. 使用 adb proxy 解决 fix chromedriver 的 bug

为什么仍然有很多人搞不定?

  • 低版本的 chromedriver 在高版本的手机上有 bug
  • chromedriver 与微信定制的 chrome 内核对接实现上有问题

解决方案:如何 fix it?

  • chromedriver 没有使用 adb 命令,而是使用了 adb 协议
  • 参考课程中提到的 adb proxy 源代码

源码-微信小程序自动化测试 Python 版代码示例

class TestWXMicroWebView:    # 为了演示方便,未使用page object模式    def setup(self):        caps = {}        caps["platformName"] = "android"        caps["deviceName"] = "测试人社区 ceshiren.com"        caps["appPackage"] = "com.tencent.mm"        caps["appActivity"] = "com.tencent.mm.ui.LauncherUI"        caps["noReset"] = True        caps['unicodeKeyboard'] = True        caps['resetKeyboard'] = True        caps['chromedriverExecutable'] = \            '/Users/seveniruby/projects/chromedriver/chromedrivers/chromedriver_78.0.3904.11'        # options = ChromeOptions()        # options.add_experimental_option('androidProcess', 'com.tencent.mm:appbrand0')        caps['chromeOptions'] = {            'androidProcess': 'com.tencent.mm:appbrand0'        }        caps['adbPort'] = 5038        self.driver = webdriver.Remote("http://localhost:4723/wd/hub", caps)        self.driver.implicitly_wait(30)        self.driver.find_element(By.XPATH, "//*[@text='通讯录']")        self.driver.implicitly_wait(10)        self.enter_micro_program()        print(self.driver.contexts)    def enter_micro_program(self):        # 原生自动化测试        size = self.driver.get_window_size()        self.driver.swipe(size['width'] * 0.5, size['height'] * 0.4, size['width'] * 0.5, size['height'] * 0.9)        self.driver.find_element(By.CLASS_NAME, 'android.widget.EditText').click()        self.driver.find_element(By.XPATH, "//*[@text='取消']")        self.driver.find_element(By.CLASS_NAME, "android.widget.EditText").send_keys("雪球")        self.driver.find_element(By.CLASS_NAME, 'android.widget.Button')        self.driver.find_element(By.CLASS_NAME, 'android.widget.Button').click()        self.driver.find_element(By.XPATH, "//*[@text='自选']")    def find_top_window(self):        for window in self.driver.window_handles:            print(window)            if ":VISIBLE" in self.driver.title:                print(self.driver.title)            else:                self.driver.switch_to.window(window)    def test_search_webview(self):        # 进入webview        self.driver.switch_to.context('WEBVIEW_xweb')        self.driver.implicitly_wait(10)        self.find_top_window()        # css定位        self.driver.find_element(By.CSS_SELECTOR, "[src*=stock_add]").click()        # 等待新窗口        WebDriverWait(self.driver, 30).until(lambda x: len(self.driver.window_handles) > 2)        self.find_top_window()        self.driver.find_element(By.CSS_SELECTOR, "._input").click()        # 输入        self.driver.switch_to.context("NATIVE_APP")        ActionChains(self.driver).send_keys("alibaba").perform()        # 点击        self.driver.switch_to.context('WEBVIEW_xweb')        self.driver.find_element(By.CSS_SELECTOR, ".stock__item")        self.driver.find_element(By.CSS_SELECTOR, ".stock__item").click()

小程序自动化测试需要跨过的几个坎

  • WebView 开关 /x5 内核调试开关
  • ChromeOption 选项需要填写
  • WebView 版本和 ChromeDriver 版本对应问题
  • 低版本 ChromeDriver 需要修复 ps 命令的 bug
  • Context API 有一定的延迟需要等待

以上,更多内容(ChromeDriver 的资料与 WebView 自动化关键代码,Appium 配置,mapping.json,常见错误等),请点击阅读原文访问课程帖。
点击领取:自动化+侧开+性能+简历+面试核心教程资料
http://qrcode.testing-studio.com/f?from=jianshu&url=https://ceshiren.com/t/topic/3595

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352