zoukankan      html  css  js  c++  java
  • Selenium+java

    思路:

    1、将文件路径复制到剪切板

    2、用robot对象模拟键盘操作即可

    复制文件代码:

     public void setClipboardData(String data) {
            StringSelection stringSelection = new StringSelection(data);
            Toolkit.getDefaultToolkit().getSystemClipboard().setContents(stringSelection, null);
        }

    实现上传代码

    package com.brower.demo;
    
    import org.openqa.selenium.By;
    import org.openqa.selenium.WebDriver;
    import org.openqa.selenium.chrome.ChromeDriver;
    import org.testng.annotations.AfterClass;
    import org.testng.annotations.BeforeClass;
    import org.testng.annotations.Test;
    
    import java.awt.*;
    import java.awt.datatransfer.StringSelection;
    import java.awt.event.KeyEvent;
    import java.io.IOException;
    
    /**
     * @author rongrong
     */
    public class TestUploadByRobot {
        WebDriver driver;
    
        @BeforeClass
        public void beforeClass() {
            System.setProperty("webdriver.chrome.driver", "driver/chromedriver.exe");
            driver = new ChromeDriver();
        }
    
        @Test
        public void testUploadByRobot() throws AWTException {
            driver.get("file:///C:/Users/Administrator/Desktop/upload.html");
            driver.manage().window().maximize();
            //选择文件
            driver.findElement(By.id("upload")).click();
            setClipboardData("F:\robotium-solo-5.6.1.jar");
            Robot robot = new Robot();
            robot.keyPress(KeyEvent.VK_TAB);
            robot.delay(100);
            robot.keyRelease(KeyEvent.VK_TAB);
            robot.keyPress(KeyEvent.VK_TAB);
            robot.delay(100);
            robot.keyRelease(KeyEvent.VK_TAB);
            robot.keyPress(KeyEvent.VK_ENTER);
            robot.delay(100);
            robot.keyRelease(KeyEvent.VK_ENTER);
            robot.keyPress(KeyEvent.VK_CONTROL);
            robot.keyPress(KeyEvent.VK_V);
            robot.keyRelease(KeyEvent.VK_V);
            robot.keyRelease(KeyEvent.VK_CONTROL);
            robot.delay(100);
            robot.keyRelease(KeyEvent.VK_TAB);
            robot.keyPress(KeyEvent.VK_ENTER);
            robot.delay(100);
            robot.keyRelease(KeyEvent.VK_ENTER);
    
        }
    
        public void setClipboardData(String data) {
            StringSelection stringSelection = new StringSelection(data);
            Toolkit.getDefaultToolkit().getSystemClipboard().setContents(stringSelection, null);
        }
    
    
        @AfterClass
        public void afterClass() {
            //driver.quit();
        }
    
    }

    效果:

  • 相关阅读:
    css实现文字相对于图片垂直居中
    node能做的性能优化
    vue.config.js中vue的配置
    react/vue项目腾讯云/阿里云服务器linux部署
    taro项目结构分析和坑
    vscode自动编译less
    css彩色字体
    微信小程序文件上传
    小程序html解析
    小程序表单
  • 原文地址:https://www.cnblogs.com/longronglang/p/11312413.html
Copyright © 2011-2022 走看看