Jest to możliwe przy użyciu samego Selenu, ale nie jest to proste. Wymaga wstrzyknięcia nowego elementu INPUT
na stronie, aby odebrać plik przez SendKeys
. Następnie skrypt musi zasymulować spadek, wysyłając zdarzenia do docelowego obszaru.
IWebElement droparea = driver.FindElement(By.Id("droparea"));
DropFile(droparea, @"C:\...\image.png");
static void DropFile(IWebElement target, string filePath, int offsetX = 0, int offsetY = 0) {
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() {
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('DragEvent');
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));
}
Odpowiedź Florenta B z jakiegoś powodu nie zadziałała - AutoIt wykonał sztuczkę https://stackoverflow.com/a/38513989/1141876 – fiat