- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Webdriver.io是一个自动化测试库。
在 Chrome 和 Safari 中,我可以使用 setValue或addValue使用xpaths在自动化测试期间填写文本输入并提交表单。
但是在 Edge/FireFox 中我不能,这些命令不起作用。
环顾四周,我发现了一个涉及 browser.addCommand
和 browser.execute
的解决方法,我在下面使用了它们,它将直观地填充 redux-form。然而,该表单并没有检测到该表单实际上已被填写:(因此,如果单击自动提交按钮,则该按钮将不会继续。
browser.addCommand('setInputValue', function(element, value) {
const webBrowser = browser.capabilities.browserName.toLowerCase();
if (webBrowser === ‘microsoftedge’ || webBrowser === ‘firefox’) {
browser.execute((el, val) => {
const regex = /\'(.*)\'/; // pulls name out of xpath
const extractedName = el.match(regex)[1];
document.getElementsByName(extractedName)[0].focus();
document.getElementsByName(extractedName)[0].value = val;
}, element, value);
}
else {
$(element).setValue(value);
}
});
使用方法:
setFirstName: value => {
const xpath = "//input[@name='firstName']";
browser.setInputValue(xpath, value);
// $(xpath).setValue(value); // <- normal webdriver method which doesn't work
}
From this example ,但同样的问题。
if (webBrowser === 'microsoftedge' || webBrowser === 'firefox') {
browser.execute((el, val) => {
const regex = /\'(.*)\'/; // pulls name out of xpath
const extractedName = el.match(regex)[1];
// https://github.com/facebook/react/issues/10135#issuecomment-500929024
const input = document.getElementsByName(extractedName)[0];
input.value = val;
input.dispatchEvent(new Event('change', { bubbles: true }));
// document.getElementsByName(extractedName)[0].focus();
// document.getElementsByName(extractedName)[0].value = val;
}, element, value);
}
你们中有人在使用 Webdriver 在 FireFox 或 Edge 上进行自动化测试时遇到过这个问题吗?
最佳答案
https://github.com/facebook/react/issues/10135#issuecomment-314441175
您需要在 react 中触发更改事件,或者您可以使用上述解决方法(设置 native 值)
typescript 中的示例代码,但不推荐使用,因为它不模拟实际的用户输入。
browser.addCommand(
"setNativeValue",
function(this: any, value: string) {
browser.execute(
function(element, val) {
try {
const valueSetter = Object.getOwnPropertyDescriptor(element, "value");
const prototype = Object.getPrototypeOf(element);
const prototypeValueSetter = Object.getOwnPropertyDescriptor(prototype, "value");
if (valueSetter && valueSetter !== prototypeValueSetter) {
prototypeValueSetter!.set!.call(element, val);
} else {
valueSetter!.set!.call(element, val);
}
const event = document.createEvent("Event");
event.initEvent("input", true, true);
element.dispatchEvent(event);
} catch {
element.value = val;
}
},
this,
value,
);
},
true,
);
关于javascript - 如何通过 Webdriver 自动化测试在 FireFox/Edge 中填写 redux-form 输入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58860806/
我想在 Watir webdriver 中使用 selenium webdriver Actions。这可能吗? 也可以在 watir webdriver 中使用 java 代码。请帮忙。 我浏览了很
我正在使用 watir-webdriver 浏览我的网站并在不同的浏览器中抓取屏幕截图。 有时在 IE 中截取的屏幕截图大小合适,但颜色完全是黑色。同时运行的 Firefox 测试看起来很好。 bro
我已经编写了 driver.findElement(By.id("kfiDocumentLink")).click(); 用于单击“KFI 文档”按钮的代码。 请找到HTML代码。 Download
我有一个包含以下内容的 html 页面: This is Login page. Please click below link
我想获得页面加载异常,但仍然没有结果。 我使用implicitlyWait 设置计时器以抛出异常。 WebDriver driver = new FirefoxDriver(); driver.man
我正在使用具有 IE 特定应用程序的 Selenium Webdriver。我知道我们可以截取执行的截图。同样,是否有任何选项可以将 selenium 执行记录为视频? 最佳答案 WebDriver
Selenium WebDriver 如何克服同源策略? Selenium RC 中存在同源策略问题 最佳答案 First of all “Same Origin Policy” is introdu
我将如何从输入文件中提取文本?我尝试使用 XPath/CSSSelector 但我得到一个空文本,因为它是一个输入字段。 这是我的 html 代码: 结果:195 行中的 1 到 50
如何使用 WebDriver 自动验证码? 是否有其他方法可以使用 Webdriver 自动执行验证码? 最佳答案 您只能使用“alt”属性中的显示验证码值来自动化验证码。 在 WebElement
最近我开始学习 WebDriver,因为我工作的客户计划使用 WebDriver 来自动化 Web 应用程序。 我怀疑 WebDriver 如何在网页上定位其 ID 动态变化的元素(比如每次登录应用程
我发现 watir-webdriver 在一个非常大的页面上通过正则表达式定位元素非常慢,至少在 FF 8.0.1 中对我来说是这样。航类搜索结果页面示例(包含大约 50 个搜索结果,每个都是 htm
我有一个动态更改其文本的字段。我需要一种方法来等待文本被更改。我不知道会出现什么文本,但我知道当前那里有什么文本。所以我想等待它在元素中消失。有办法吗? 最佳答案 你可以试试ExpectedCondi
自从我使用 Firefox 升级到 3.0 beta 后,我就有了这个异常(exception)。 Exception in thread "main" java.lang.IllegalStateE
任何人都可以帮助我使用 Selenium webdriver 截取整页屏幕截图。我正在使用 c#/Nunit。我正在使用的当前方法不是完整的浏览器页面。 我正在使用下面的代码截取屏幕截图。 publi
我通过 WebDriver (Chrome) 从网页下载图像 // STEP 1 $driver->get($link); // STEP 2 $els=$driver->findElements(W
Selenium WebDriver 的默认隐式等待值是什么? selenium 文档说它是“0”,但是当我在一个全新的项目上调用 .findElement 时,DOM 上不存在元素,它似乎在一段时间
我正在使用 Webdriver 测试 Web 应用程序,大致如下所述。当测试通过时,一切都很好。但是,当其中一个测试失败时,我注意到以下 2 个问题。 a) 如果一个测试失败,则套件中的其余测试将超时
我正在使用 Selenium WebDriver 并遇到问题。 在 UI 中,WebDriver 可以看到元素,但无法执行任何操作,例如单击、键入、选择等。元素由 selenium 找到并作为 web
我在 Java 中使用 Web 驱动程序处理 UntrustedSSLcertificates 时陷入困境。 我创建了 Firefox 配置文件,如: FirefoxProfile profile =
选择的编程语言是 Java。我已经用 Java 编写了一个方法,我将 WebDriver 作为参数传递给它... public boolean myMethod(WebDriver webDriver
我是一名优秀的程序员,十分优秀!