Selenium sendKeys 和 clear 不适用于 Safari 11 中的 Kendo 自动完成字段
Selenium sendKeys and clear doesn't work on Kendo Autocomplete field in Safari 11
在 Selenium 中编写自动化测试时-Ruby 当在 Safari 浏览器 11.0.1 中的自动完成文本字段 (Kendo UI) 上使用 sendKeys / clear 时,
测试代码:
actions.push(is_element_enabled?(PROF_IN_CHARGE,'PROF_IN_CHARGE'))
actions.push(is_element_displayed?(PROF_IN_CHARGE,'PROF_IN_CHARGE'))
actions.push(type(PROF_IN_CHARGE,first_name, 'PROF_IN_CHARGE'))
硒方法:
def is_element_enabled?(locator, name, raise_exception = true)
$logger.info "Verify whether #{name} is enabled."
highlight(web_driver.find_element(locator))
web_driver.find_element(locator).enabled?
$logger.info "Element enabled: #{name}"
def is_element_displayed?(locator, name, raise_exception = true, log_error = true)
$logger.info(__method__) { "Verifying element #{name}" }
$logger.debug(__method__) { locator }
web_driver.find_element(locator).displayed?
highlight(web_driver.find_element(locator), 0, "red")
return true
def type(locator, text, name, raise_exception = true)
$logger.info(__method__) { "Typing #{text} to #{name}" }
$logger.debug(__method__) { locator }
highlight(web_driver.find_element(locator), 0, "red")
#Clear existing text before typing
web_driver.find_element(locator).clear
web_driver.find_element(locator).send_keys(text)
显示以下错误:
# --- Caused by: ---
# Selenium::WebDriver::Error::ElementNotVisibleError:
# An element command could not be completed because the element is not visible on the page.
# /Users/admin/.rvm/gems/ruby-2.4.1/gems/selenium-webdriver-3.6.0/lib/selenium/webdriver/remote/response.rb:71:in `assert_ok'
这是日志:
I, [2017-12-11T15:19:00.611929 #5324] INFO -- : Verify whether PROF_IN_CHARGE is enabled.
I, [2017-12-11T15:19:00.635876 #5324] INFO -- : Element enabled: PROF_IN_CHARGE
I, [2017-12-11T15:19:00.635940 #5324] INFO -- is_element_displayed?: Verifying element PROF_IN_CHARGE
D, [2017-12-11T15:19:00.635964 #5324] DEBUG -- is_element_displayed?: {:id=>"fcCreateMainAssingee"}
I, [2017-12-11T15:19:00.647651 #5324] INFO -- is_element_displayed?: true
I, [2017-12-11T15:19:00.660760 #5324] INFO -- type: Typing Report to PROF_IN_CHARGE
D, [2017-12-11T15:19:00.660834 #5324] DEBUG -- type: {:id=>"fcCreateMainAssingee"}
E, [2017-12-11T15:19:00.685450 #5324] ERROR -- create_new_matter: failed.
I, [2017-12-11T15:19:00.725482 #5324] INFO -- screenshot: Screenshot saved in path: /Users/admin/PivotQA/screenshots/2017-12-11_1
5_18_15/MattersLib_create_new_matter_20171211_151900.png
E, [2017-12-11T15:19:00.725531 #5324] ERROR -- : An element command could not be completed because the element is not visible on t
he page.
即使在使用 selenium 成功检查该元素是否启用和可见后,也会发生这种情况?并显示?方法。
但是,这个问题在 chrome、IE 和 Edge 等其他浏览器上没有出现。
我已经使用 javascript("document.getElementById('fcCreateMainAssingee'.value='text')") 更改该文本字段的值并且工作正常,但未显示动态选项下拉列表,这就是问题所在。
那么,有没有人遇到过类似的问题并解决了呢?很高兴得到你的帮助。
此外,如果有任何其他方法可以实现此目的,请提出建议。
这是该自动完成字段的 DOM:
<input formcontrolname="fcCreateMainAssingee" id="fcCreateMainAssingee" type="text" class="ng-untouched ng-pristine ng-valid k-input" data-role="autocomplete" placeholder="Username" autocomplete="off" role="textbox" aria-haspopup="true" aria-disabled="false" aria-readonly="false" aria-owns="fcCreateMainAssingee_listbox" aria-autocomplete="list" style="width: 100%;">
谢谢!
在研究 Kendo 自动完成字段时,我偶然发现了 JavaScript 有助于解决此问题的代码。
以下是 selenium 函数的可靠替代方案,已经在 Safari、Chrome、IE 和 Edge 浏览器上进行了全面测试,并且运行良好。
希望这对过去几天与我处在同一条船上的人有所帮助!
这是 send_keys -
相当于 JS 的硒
"document.getElementById('<ID>').value='<search_string>'"
(无需清除search_string中的js类型的文本,删除现有的占位符字符串)
然后触发输入后发生的搜索,执行以下 js:
"$( #{locator[:id]} ).data('kendoAutoComplete').search();"
上面的js会触发搜索然后动态下拉打开。现在,只需使用 selenium 的 find_element 方法通过 xpath 找到该元素,然后使用 js 单击它(如下所示)
js_script = 'arguments[0].click();'
element = web_driver.find_element(locator)
web_driver.execute_script(js_script, element)
完整方法如下:
def kendo_auto_complete(locator, loc_name, full_name, raise_exception = true)
$logger.info(__method__) { 'begin' }
# Split full name ( Last_name, first_name) and get first_name
first_name = full_name.split(",").last.strip
# Type in the name using JS
$logger.info(__method__) { "Typing #{first_name} into #{loc_name}" }
web_driver.execute_script("document.getElementById('#{locator[:id]}').value='#{first_name}'")
short_delay
#Trigger search using JS
$logger.info(__method__) { "Starting search.." }
if BROWSER.upcase == 'IE'
web_driver.execute_script("$( '##{locator[:id]}' ).data('kendoAutoComplete').search();")
else
web_driver.execute_script("$( #{locator[:id]} ).data('kendoAutoComplete').search();")
end
# Select the name from results in dynamic dropdown
wait_for_element(create_dynamic_xpath(AUTO_CMP_OPTION[:xpath],full_name), full_name)
js_click(create_dynamic_xpath(AUTO_CMP_OPTION[:xpath],full_name), full_name)
$logger.info(__method__) { 'end' }
rescue StandardError => e
$logger.error "Value of Kendo autocomplete - #{name} could not be set."
raise e if raise_exception
false
end
但是,如果有人有更好的做事方式,请在这里发表评论。谢谢!
在 Selenium 中编写自动化测试时-Ruby 当在 Safari 浏览器 11.0.1 中的自动完成文本字段 (Kendo UI) 上使用 sendKeys / clear 时,
测试代码:
actions.push(is_element_enabled?(PROF_IN_CHARGE,'PROF_IN_CHARGE'))
actions.push(is_element_displayed?(PROF_IN_CHARGE,'PROF_IN_CHARGE'))
actions.push(type(PROF_IN_CHARGE,first_name, 'PROF_IN_CHARGE'))
硒方法:
def is_element_enabled?(locator, name, raise_exception = true)
$logger.info "Verify whether #{name} is enabled."
highlight(web_driver.find_element(locator))
web_driver.find_element(locator).enabled?
$logger.info "Element enabled: #{name}"
def is_element_displayed?(locator, name, raise_exception = true, log_error = true)
$logger.info(__method__) { "Verifying element #{name}" }
$logger.debug(__method__) { locator }
web_driver.find_element(locator).displayed?
highlight(web_driver.find_element(locator), 0, "red")
return true
def type(locator, text, name, raise_exception = true)
$logger.info(__method__) { "Typing #{text} to #{name}" }
$logger.debug(__method__) { locator }
highlight(web_driver.find_element(locator), 0, "red")
#Clear existing text before typing
web_driver.find_element(locator).clear
web_driver.find_element(locator).send_keys(text)
显示以下错误:
# --- Caused by: ---
# Selenium::WebDriver::Error::ElementNotVisibleError:
# An element command could not be completed because the element is not visible on the page.
# /Users/admin/.rvm/gems/ruby-2.4.1/gems/selenium-webdriver-3.6.0/lib/selenium/webdriver/remote/response.rb:71:in `assert_ok'
这是日志:
I, [2017-12-11T15:19:00.611929 #5324] INFO -- : Verify whether PROF_IN_CHARGE is enabled.
I, [2017-12-11T15:19:00.635876 #5324] INFO -- : Element enabled: PROF_IN_CHARGE
I, [2017-12-11T15:19:00.635940 #5324] INFO -- is_element_displayed?: Verifying element PROF_IN_CHARGE
D, [2017-12-11T15:19:00.635964 #5324] DEBUG -- is_element_displayed?: {:id=>"fcCreateMainAssingee"}
I, [2017-12-11T15:19:00.647651 #5324] INFO -- is_element_displayed?: true
I, [2017-12-11T15:19:00.660760 #5324] INFO -- type: Typing Report to PROF_IN_CHARGE
D, [2017-12-11T15:19:00.660834 #5324] DEBUG -- type: {:id=>"fcCreateMainAssingee"}
E, [2017-12-11T15:19:00.685450 #5324] ERROR -- create_new_matter: failed.
I, [2017-12-11T15:19:00.725482 #5324] INFO -- screenshot: Screenshot saved in path: /Users/admin/PivotQA/screenshots/2017-12-11_1
5_18_15/MattersLib_create_new_matter_20171211_151900.png
E, [2017-12-11T15:19:00.725531 #5324] ERROR -- : An element command could not be completed because the element is not visible on t
he page.
即使在使用 selenium 成功检查该元素是否启用和可见后,也会发生这种情况?并显示?方法。
但是,这个问题在 chrome、IE 和 Edge 等其他浏览器上没有出现。
我已经使用 javascript("document.getElementById('fcCreateMainAssingee'.value='text')") 更改该文本字段的值并且工作正常,但未显示动态选项下拉列表,这就是问题所在。
那么,有没有人遇到过类似的问题并解决了呢?很高兴得到你的帮助。
此外,如果有任何其他方法可以实现此目的,请提出建议。
这是该自动完成字段的 DOM:
<input formcontrolname="fcCreateMainAssingee" id="fcCreateMainAssingee" type="text" class="ng-untouched ng-pristine ng-valid k-input" data-role="autocomplete" placeholder="Username" autocomplete="off" role="textbox" aria-haspopup="true" aria-disabled="false" aria-readonly="false" aria-owns="fcCreateMainAssingee_listbox" aria-autocomplete="list" style="width: 100%;">
谢谢!
在研究 Kendo 自动完成字段时,我偶然发现了 JavaScript 有助于解决此问题的代码。
以下是 selenium 函数的可靠替代方案,已经在 Safari、Chrome、IE 和 Edge 浏览器上进行了全面测试,并且运行良好。
希望这对过去几天与我处在同一条船上的人有所帮助!
这是 send_keys -
相当于 JS 的硒"document.getElementById('<ID>').value='<search_string>'"
(无需清除search_string中的js类型的文本,删除现有的占位符字符串)
然后触发输入后发生的搜索,执行以下 js:
"$( #{locator[:id]} ).data('kendoAutoComplete').search();"
上面的js会触发搜索然后动态下拉打开。现在,只需使用 selenium 的 find_element 方法通过 xpath 找到该元素,然后使用 js 单击它(如下所示)
js_script = 'arguments[0].click();'
element = web_driver.find_element(locator)
web_driver.execute_script(js_script, element)
完整方法如下:
def kendo_auto_complete(locator, loc_name, full_name, raise_exception = true)
$logger.info(__method__) { 'begin' }
# Split full name ( Last_name, first_name) and get first_name
first_name = full_name.split(",").last.strip
# Type in the name using JS
$logger.info(__method__) { "Typing #{first_name} into #{loc_name}" }
web_driver.execute_script("document.getElementById('#{locator[:id]}').value='#{first_name}'")
short_delay
#Trigger search using JS
$logger.info(__method__) { "Starting search.." }
if BROWSER.upcase == 'IE'
web_driver.execute_script("$( '##{locator[:id]}' ).data('kendoAutoComplete').search();")
else
web_driver.execute_script("$( #{locator[:id]} ).data('kendoAutoComplete').search();")
end
# Select the name from results in dynamic dropdown
wait_for_element(create_dynamic_xpath(AUTO_CMP_OPTION[:xpath],full_name), full_name)
js_click(create_dynamic_xpath(AUTO_CMP_OPTION[:xpath],full_name), full_name)
$logger.info(__method__) { 'end' }
rescue StandardError => e
$logger.error "Value of Kendo autocomplete - #{name} could not be set."
raise e if raise_exception
false
end
但是,如果有人有更好的做事方式,请在这里发表评论。谢谢!