本文为霍格沃兹测试学院测试大咖公开课《微信小程序自动化测试》图文整理精华版。
随着微信小程序的功能和生态日益完善,不少公司的产品业务形态逐渐从 App 延升到微信小程序、微信公众号等。小程序项目页面愈来愈多,业务逻辑也愈来愈复杂,全手工测试已没法知足快速增加的业务需求。css
然而,因为小程序自己的一些特性,致使业界目前缺少成熟完善的解决方案,总会出现各类问题(包括腾讯微信官方提供的自动化工具)。如何作好小程序的自动化测试就成为测试同窗当下广泛面临的一个痛点难题。python
本节课就主要分享下微信小程序自动化测试的一些最佳实践心得,包括微信小程序的基本测试技术和操做方法,以及如何利用 Appium 的 WebView 测试技术 + adb proxy 完成微信小程序的自动化测试(多是目前最实用的小程序自动化测试技术),并附上 Python 版源码。android
平台差别:尽管各运行环境是十分类似的,可是仍是有些许区别:web
JavaScript 语法和 API 支持不一致:语法上开发者能够经过开启 ES6 转 ES5 的功能来规避(详情);此外,小程序基础库内置了必要的Polyfill,来弥补API的差别。chrome
WXSS 渲染表现不一致:尽管能够经过开启样式补全来规避大部分的问题,仍是建议开发者须要在 iOS 和 Android 上分别检查小程序的真实表现。json
chrome://inspect/#devices
为何仍然有不少人搞不定?小程序
解决方案:如何 fix it?微信小程序
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()
以上,更多内容(ChromeDriver 的资料与 WebView 自动化关键代码,Appium 配置,mapping.json,常见错误等),请点击下方连接入群获取。浏览器