專案思想:關鍵字+資料驅動混合測試
- 基於Android-微信小程式自動化的關鍵是:webview的切換
對於微信App來說如何從NATIVE切換到webview的過程 - 測試版本資訊
1.微信版本:7.0.21
2.Android:7.0
3.appium引入依賴:6.1.0
4.testng引入依賴:6.14.3 - 初始化例項配置資訊
1.配置引數如下:
其中涉及到微信內建webview版本與chromedriver一致性設定,檢視流程如下:
第一步:檢視微信webview版本資訊,這裡通過uc-devtools工具檢視
uc-devtools工具獲取連結:
連結:https://pan.baidu.com/s/1GA3EPDz0GD3IyXUsgU8Z3g
提取碼:3lpg
scrcpy真機工具獲取連結:
連結:https://pan.baidu.com/s/1If7q_empeZgXWVXU0v8rIw
提取碼:3hi9
下載後開啟,同時通過真機連線工具scrcpy開啟微信,此時即可顯示微信的chromedriver版本號:
從上圖可以看到chromedriver,去chromedriver官網下載對於的版本去驅動
點選下載對應版本的chromedriver版本
下載後放到resources目錄下,見上圖的配置路徑。
第二部就可以正常使用web的元素檢視了:
2.setCapability引數配置如下(入坑-需要先檢視下自己微信小程式上下文切換的context,通過下面的方法可以檢視):
其中最關鍵是的: options.setExperimentalOption("androidProcess", "com.tencent.mm:appbrand0");
通過driver.getContextHandles()方法獲取從微信app切換到小程式後的所有控制程式碼,配置到啟動引數中。
把需要切換的context,配置到setExperimentalOption中即可。具體配置詳情如下:
//引用配置引數
DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability("platformName", platformName);
capabilities.setCapability("appPackage", appPackage);
capabilities.setCapability("appActivity", appActivity);
capabilities.setCapability("automationName", automationName);
capabilities.setCapability("deviceName",deviceName);
capabilities.setCapability("chromedriverExecutable", chromePath);
capabilities.setCapability("platformVersion","7.0");
capabilities.setCapability("unicodeKeyboard",true);
capabilities.setCapability("noReset",true);
// 不重新簽名apk
capabilities.setCapability("resetKeyboard", true);
// 支援X5核心應用自動化配置
capabilities.setCapability("recreateChromeDriverSessions", true);
/**
* ChromeOptions使用來定製啟動選項,因為在appium中切換context識別webview的時候,
* 把com.tencent.mm:toolsmp的webview識別成com.tencent.mm的webview.
* 所以為了避免這個問題,加上androidProcess: com.tencent.mm:toolsmp
* */
ChromeOptions options = new ChromeOptions();
/**
* 這裡很關鍵>>
* ChromeOptions使用來定製啟動選項,因為在appium中切換context識別webview的時候,把com.tencent.mm:toolsmp的webview識別成com.tencent.mm的webview.
* 所以為了避免這個問題,加上androidProcess名:通過driver.getContextHandles()獲取所有的上下文,我這裡獲取的是com.tencent.mm:appbrand0
* */
options.setExperimentalOption("androidProcess", "com.tencent.mm:appbrand0");
capabilities.setCapability(ChromeOptions.CAPABILITY, options);
// 初始化會預設將chrome瀏覽器開啟,需要將Browser置為空
capabilities.setBrowserName("");
// 每次啟動時覆蓋session,否則第二次後執行會報錯不能新建session
capabilities.setCapability("sessionOverride", true);
URL url = null;
try {
url = new URL("http://127.0.0.1:4723/wd/hub");
} catch (MalformedURLException e) {
e.printStackTrace();
}
driver = new AndroidDriver(url, capabilities);
- 關鍵實現邏輯
1.查了一下網上很多說是需要在微信app內的搜搜功能進入小程式,但對於體驗版的小程式這裡肯定搜尋不到的。所以進入被測體驗版小程式最簡單的方法是:下拉微信框+點選小程式座標進入最直接。
首次進入小程式後都會在小程式列表展示,最新的位置都是第一個。
1.通過開啟手機設定內建的【指標位置】來定位小程式的座標
其中通過座標點選方法如下:
public void taptest(AndroidDriver driver,int x, int y){
/**設定顯示等待時間10s driver=baseAndroidDriver.getDriver(baseConfig)
特注:顯示等待與隱式等待相對,顯示等待必須在每一個需要等待的元素前面進行宣告,如果在規定的時間內找到元素,則直接執行,即找到元素就執行相關操作
*/
wait = new WebDriverWait(driver,20);
//tap點選座標,輸入座標,然後再release()釋放座標點,用perform()去執行一系列action操作
action = new TouchAction(driver).tap(PointOption.point(x,y)).release().perform();
}
2.實現程式碼-webview切換成功後就可以正常使用顯示等待時間解決元素載入問題。
//進入微信下拉滑動
swipeToDown(driver);
//點選被測小程式,通過座標點選
taptest(driver,190,673);
//allure截圖存留
// SaveFailureScreenUtil.saveFailureScreenShot(driver);
//切換webview頁面
// 獲取到所有的contexts,並在啟動引數裡配置
System.out.println("所有的contexts:" + driver.getContextHandles());
// 切換到小程式webview對應的context中
driver.context("WEBVIEW_com.tencent.mm:appbrand0");
System.out.println("切換context成功!");
// 獲取到所有的handles
Set<String> windowHandles = driver.getWindowHandles();
System.out.println("所有的windowsHandles" + windowHandles);
for (String handle :windowHandles){
System.out.println("切換到對應的windowHandle:" + handle);
driver.switchTo().window(handle);
String strTip = "IT網際網路熱門課程";
if(driver.getPageSource().contains(strTip)){
//找到了對應的視窗,退出迴圈
break;
}else {
System.out.println("查詢的:"+strTip+"頁面可能不包含該文字資訊");
}
}
//下拉滑動操作
swipeToUp(driver);
//進入正常的web元素定位操作
//點選模擬試卷
UIElementUtil.clickButton("騰訊課堂","分類",driver);
-
xml維護的元素定位資訊
-
通過日誌可以看到已經切換到webview並定位元素點選成功了
所有的contexts:[NATIVE_APP, WEBVIEW_com.tencent.mm:appbrand0, WEBVIEW_com.tencent.mm:appbrand2]
切換context成功!
所有的windowsHandles[CDwindow-ABCE2F2B94ED5F6A2BF2153F6CFEFF21, CDwindow-FA78683E0B1150082058BBC8EFF73001]
切換到對應的windowHandle:CDwindow-ABCE2F2B94ED5F6A2BF2153F6CFEFF21
查詢的:IT網際網路熱門課程頁面可能不包含該文字資訊
切換到對應的windowHandle:CDwindow-FA78683E0B1150082058BBC8EFF73001
INFO 2020-12-14 10:24:22 [main] com.iappium.utils.UIElementUtil.clickButton(UIElementUtil.java:186) - [分類]該點選事件耗時:445ms
- 最後-更多工具和技術請關注:Coding測試
其中UIElementUtil工具類是封裝的關鍵字工具欄,通過xml維護定位元素(等同於ui的自動化測試的關鍵字),由於UIElementUtil使用的是dom4j解析的xml檔案,內容較多,需要看的話可以移步至專案原始碼中檢視iappium4j專案app+小程式自動化測試-原始碼
更多測試技術分享、學習資源以及一些其他福利可關注公眾號:【Coding測試】獲取: