Selenium+Java – 結合sikuliX操作Flash網頁
- 2019 年 10 月 3 日
- 筆記
前言
Sikuli-IDE用起來方便,但是用到實際項目中還是有局限性的,Sikuli提供了Sikuli-Script的jar包,在Sikuli-X的安裝目錄下,這樣就可以在Idea中使用JAVA編寫代碼了,並用Sikuli-Script和selenium完美結合使用。
模擬場景
- 打開百度地圖
- 切換城市到北京
- 使用測距工具
- 測量 奧林匹克森林公園 —— 北京南苑機場 的距離
安裝配置
- 首先下載sikuliX的jar包:https://launchpad.net/sikuli/sikulix/1.1.0
- 導入jar包:sikulixsetup-1.1.0.jar
- 雙擊java -jar sikulixsetup-1.1.0.jar,則會出現如下圖,選擇相應選項後,啟動會下載sikulixapi.jar。不然會報錯:libs to export not found on above classpath: /sikulixlibs/mac/libs64
- 啟動成功後會出現如下提示
- 截取起點位置和終點位置的圖片
sikuli操作Flash網頁
具體示例代碼如下;
import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.chrome.ChromeDriver; import java.util.concurrent.TimeUnit; import org.sikuli.script.FindFailed; import org.sikuli.script.Pattern; import org.sikuli.script.Screen; import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; /** * @rongrong
* Selenium結合sikuliX操作Flash網頁案例 */ public class TestSikuli { WebDriver driver; @BeforeClass public void beforeClass() { System.setProperty("webdriver.chrome.driver", "driver/chromedriver.exe"); driver = new ChromeDriver(); } @Test public void testBaiDuMap() { driver.manage().window().maximize(); driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); driver.manage().timeouts().pageLoadTimeout(10, TimeUnit.SECONDS); driver.get("http://map.baidu.com/"); //打開城市下拉框 driver.findElement(By.cssSelector(".ui3-city-change-inner")).click(); //選擇北京 driver.findElement(By.cssSelector("[citycode='131']")).click();; // 打開工具下拉框 driver.findElement(By.cssSelector("[map-on-click='box'] em")).click(); // 選擇測距 driver.findElement(By.cssSelector("[map-on-click='measure'] i")).click(); Screen screen = new Screen(); String start = "D:\picture\奧林匹克森林公園.png"; String end = "D:\picture\北京南苑機場.png"; Pattern from = new Pattern(start); Pattern to = new Pattern(end); try { if (screen.find(from) != null) { screen.click(from); } if (screen.find(to) != null) { screen.click(to); } screen.doubleClick(); } catch (FindFailed e) { e.printStackTrace(); } } }
運行效果如下: