使用Selenium webdriver从文件系统中拖放文件

时间:2012-06-26 14:10:46

标签: java selenium drag-and-drop webdriver

我正在测试Web应用程序,其中一个方案是能够从文件系统中拖动文件并将其放到组件上。

与此类似:

http://s3u.github.com/har-view/

http://html5demos.com/dnd-upload

有没有办法模拟从文件系统中删除文件 使用网络驱动程序的元素?

2 个答案:

答案 0 :(得分:1)

没有。不幸的是,WebDriver仅驱动浏览器,无法触及其外的任何内容。如果您想拖放内容,则必须使用Robot或任何其他工具(there might be a library for this)。

答案 1 :(得分:0)

唯一帮助我的是运行我在Selenium: Drag and Drop from file system to webdriver?

中找到的JS代码

只需将整个内容粘贴到您的项目中即可。

请参阅:  static void DropFile(IWebElement target,string filePath,int offsetX = 0,int offsetY = 0)         {

        if (String.IsNullOrWhiteSpace(filePath))
        {
            throw new ArgumentNullException("filePath");
        }

        if (!File.Exists(filePath))
        {
            throw new FileNotFoundException(filePath);
        }



        IWebDriver driver = ((RemoteWebElement)target).WrappedDriver;
        IJavaScriptExecutor jse = (IJavaScriptExecutor)driver;
        WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(30));


        string JS_DROP_FILE = @"
    var target = arguments[0],
        offsetX = arguments[1],
        offsetY = arguments[2],
        document = target.ownerDocument || document,
        window = document.defaultView || window;

    var input = document.createElement('INPUT');
    input.type = 'file';
    input.style.display = 'none';
    input.onchange = function () {
      target.scrollIntoView(true);

      var rect = target.getBoundingClientRect(),
          x = rect.left + (offsetX || (rect.width >> 1)),
          y = rect.top + (offsetY || (rect.height >> 1)),
          dataTransfer = { files: this.files };

      ['dragenter', 'dragover', 'drop'].forEach(function (name) {
        var evt = document.createEvent('MouseEvent');
        evt.initMouseEvent(name, !0, !0, window, 0, 0, 0, x, y, !1, !1, !1, !1, 0, null);
        evt.dataTransfer = dataTransfer;
        target.dispatchEvent(evt);
      });

      setTimeout(function () { document.body.removeChild(input); }, 25);
    };
    document.body.appendChild(input);
    return input;
    ";

        IWebElement input = (IWebElement)jse.ExecuteScript(JS_DROP_FILE, target, offsetX, offsetY);
        input.SendKeys(filePath);
        wait.Until(ExpectedConditions.StalenessOf(input));