1.簡介
在使用appium寫app自動化的時候介紹toast的相關元素的定位,在Web UI測試過程中,也經常遇到一些toast,那麼這個toast我們這邊如何進行測試呢?今天巨集哥就分兩篇介紹一下。
2.什麼是toast?
3.定位toast
如何定位這種toast類的元素了,在我們一眨眼的瞬間,就消失不見了,不要著急聽巨集哥給你慢慢道來。
3.1第一種方法
1.怎麼定位呢?巨集哥給大家介紹一個小技巧。開啟chrome進入F12頁面進入到Sources,如下圖所示:
2.點選暫停,然後在通過Elements定位。如下圖所示:
3.點選“點選關注”按鈕後,然後再點選“下一步”按鈕,直到出現toast元素:“感謝關注:北京-巨集哥”。如下圖所示:
4.切換到“Elements”介面,通過正常定位來檢視元素,如下圖所示:
3.2第二種方法
1.怎麼定位呢?巨集哥給大家介紹一個小技巧。開啟chrome進入F12頁面進入到Sources,如下圖所示:
2.在JavaScript中找到讓toast元素消失的程式碼,點選程式碼行前邊,打一個斷點。如下圖所示:
3.點選“點選關注”按鈕後,程式碼執行到斷點處停止,然後出現toast元素:“感謝關注:北京-巨集哥”,不會消失。如下圖所示:
4.切換到“Elements”介面,通過正常定位來檢視元素,如下圖所示:
4.自動化專案實戰
巨集哥找了好久沒有找到,巨集哥就參照網上的toast原始碼修改給一個小demo,進行自動化測試。
4.1demo頁面的HTML程式碼
1.html程式碼:toast.html。如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <title>北京-巨集哥</title> </head> <style> #hongge { background-color: #f44336; border: none; color: white; padding: 15px 32px; text-align: center; text-decoration: none; display: inline-block; font-size: 28px; margin-bottom: 100px; text-decoration:none; color: white; } </style> <center> <body> <button id="hongge" onclick="clickme();">點選關注</but-ton> </body> </center> <script> function showToast(msg,duration){ duration=isNaN(duration)?3000:duration; var m = document.createElement('div'); m.innerHTML = msg; m.style.cssText="width:60%; min-width:180px; background:#000; opacity:0.6; height:auto;min-height: 30px; color:#fff; line-height:30px; text-align:center; border-radius:4px; position:fixed; top:30%; left:20%; z-index:999999;"; document.body.appendChild(m); setTimeout(function() { var d = 0.5; m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in'; m.style.opacity = '0'; setTimeout(function() { document.body.removeChild(m) }, d * 1000); }, duration); } function clickme(){ showToast("感謝關注:北京-巨集哥",3000); } </script> </html>
4.2程式碼設計
4.3參考程式碼
package lessons; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.WebElement; import org.openqa.selenium.chrome.ChromeDriver; /** * @author 北京-巨集哥 * * 《手把手教你》系列技巧篇(四十五)-java+ selenium自動化測試-web頁面定位toast-上篇(詳解教程) * * 2021年11月15日 */ public class TestToast { public static void main(String[] args) { System.setProperty("webdriver.gecko.driver", ".\\Tools\\chromedriver.exe"); WebDriver driver =null; try { driver =new ChromeDriver(); driver.get("file:///C:/Users/DELL/Desktop/test/toast.html"); driver.manage().window().maximize(); driver.findElement(By.id("anjing")).click(); WebElement elementText = driver.findElement(By.xpath("/html/body/div"));//(加粗字型根據實際定位的元素資訊進行填寫) Thread.sleep(1000); String info = elementText.getText(); System.out.println(info); Thread.sleep(3000); } catch (Exception e) { e.printStackTrace(); } finally{ System.out.println("執行結束,關閉瀏覽器"); driver.quit(); } } }
4.4執行程式碼
1.執行程式碼,右鍵Run AS->Java Appliance,控制檯輸出,如下圖所示:
2.執行程式碼後電腦端的瀏覽器的動作,如下小視訊所示:
5.小結
巨集哥個人感覺那個點選暫停和Chrome的debug除錯差不多,就是debug比較簡單,那個點選暫停的麻煩。會除錯看懂程式碼的就用debug,不會的就用點選暫停的方法。