Python与Selenium:从文件系统拖放到webdriver?

时间:2017-04-13 02:12:28

标签: javascript python selenium drag-and-drop ui-automation

我必须自动化一个Web应用程序,它包含一个用于从本地文件系统上载文件的拖放区域。我的测试环境是使用Python开发的。对于自动化测试,我使用过Selenium,但是一旦上传区域是div标签,就无法从文件系统中拖动文件(没有输入标签 - 这种方式我知道这很容易)。

我阅读了很多不同的文章,但到目前为止我都没有。重要的是要强调我对使用AutoIT不感兴趣,只使用带有selenium的原生python。

我发现这个Selenium: Drag and Drop from file system to webdriver?看起来真的很有希望,但我不知道要适应Python。

提前多多谢谢你!

1 个答案:

答案 0 :(得分:1)

这是通过脚本输入注入的技巧的python版本。

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.onchange = function () {
      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;
"""

def drag_and_drop_file(drop_target, path):
    driver = drop_target.parent
    file_input = driver.execute_script(JS_DROP_FILE, drop_target, 0, 0)
    file_input.send_keys(path)