我在 Java 中运行 Selenium 测试时寻求一些帮助,其中页面上有 SVG Highcharts 图像。我遇到的问题是,我无法让 Selenium 识别 Highcharts 上的每个元素,然后单击它们来触发另一个事件。
我在下面附上了一张屏幕截图,我希望它能突出显示我正在尝试做的事情
我认为屏幕截图上的 HTML 代码段不够清晰,因此我在下面概述了这一点:
<div id="status-action-counts" class="two-by-two-chart" data-highcharts-chart="0">
<div id="highcharts-0" class="highcharts-container" style="position: relative; overflow: hidden; width: 588px; height: 300px; text-align: left; line-height: normal; z-index: 0; font-family: "Lucida Grande","Lucida Sans Unicode",Verdana,Arial,Helvetica,sans-serif; font-size: 12px; left: 0.133331px; top: 0.916672px;">
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="588" height="300">
<desc>Created with Highcharts 3.0.4</desc>
<defs>
<rect rx="5" ry="5" fill="#FFFFFF" x="0" y="0" width="588" height="300">
<g class="highcharts-grid" zIndex="1">
<g class="highcharts-grid" zIndex="1">
<g class="highcharts-axis" zIndex="2">
<g class="highcharts-axis" zIndex="2">
<g class="highcharts-series-group" zIndex="3">
<g class="highcharts-series highcharts-tracker" visibility="visible" zIndex="0.1" transform="translate(62,51) scale(1 1)" style="cursor:pointer;" clip-path="url(#highcharts-1)">
<rect fill="#ECB631" x="26.5" y="52.5" width="49" height="121" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
<rect fill="#ECB631" x="130.5" y="150.5" width="49" height="23" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
<rect fill="#ECB631" x="233.5" y="168.5" width="49" height="5" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
<rect fill="#ECB631" x="336.5" y="162.5" width="49" height="11" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
<rect fill="#ECB631" x="439.5" y="17.5" width="49" height="156" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
</g>
<g class="highcharts-markers" visibility="visible" zIndex="0.1" transform="translate(62,51) scale(1 1)">
</g>
本质上,我想单击“指示代理” Highcharts ,然后它将触发一个事件并允许我继续测试。如果有人可以提供一些帮助让我走上正轨,我将不胜感激。
代码片段
public static void terminatedReportCompletedBarGraphSelect(InternetExplorerDriver driver)
{
WebElement parent = driver.findElement(By.className("highcharts-series-group"));
List<WebElement> children = parent.findElements(By.tagName("rect"));
children[0].Click();
}
更新 - 2014 年 11 月 25 日 您好,我希望您能够帮助解决我遇到的下一个问题。感谢您的帮助,我现在能够选择条形图。然后,它会打开另一个条形图,我想单击其中的一个元素。问题是 className 是“Highcharts-series-group”,与我之前使用的元素定位器相同。我在下面附上了我尝试选择的选项的屏幕截图(即右侧的图表)
这里是 HTML 片段,以防万一它不可见:
<div id="controller-breakdown" class="two-by-two-chart" style="display: block;" data-highcharts-chart="1">
<div id="highcharts-2" class="highcharts-container" style="position: relative; overflow: hidden; width: 588px; height: 300px; text-align: left; line-height: normal; z-index: 0; font-family: "Lucida Grande","Lucida Sans Unicode",Verdana,Arial,Helvetica,sans-serif; font-size: 12px; left: 0.083313px; top: 0.916672px;">
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="588" height="300">
<desc>Created with Highcharts 3.0.4</desc>
<defs>
<rect rx="5" ry="5" fill="#FFFFFF" x="0" y="0" width="588" height="300">
<g class="highcharts-grid" zIndex="1">
<g class="highcharts-grid" zIndex="1">
<g class="highcharts-axis" zIndex="2">
<g class="highcharts-axis" zIndex="2">
<g class="highcharts-series-group" zIndex="3">
<g class="highcharts-series highcharts-tracker" visibility="visible" zIndex="0.1" transform="translate(61,51) scale(1 1)" style="cursor:pointer;" clip-path="url(#highcharts-3)">
<rect fill="#ECB631" x="67.5" y="32.5" width="124" height="183" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
<rect fill="#ECB631" x="325.5" y="118.5" width="124" height="97" stroke="#FFFFFF" stroke-width="1" rx="0" ry="0">
</g>
<g class="highcharts-markers" visibility="visible" zIndex="0.1" transform="translate(61,51) scale(1 1)">
</g>
我希望通过编写下面的代码,我可以从右侧的图表中选择一个条形。我的想法是,我需要以某种方式使用 'div id="controller-breakdown' 元素来标识我试图访问的代码块,因为这是唯一的。
public static void relationalBarChartSelector(InternetExplorerDriver driver)
{
WebElement parent = driver.findElement(By.id("controller-breakdown"));
List<WebElement> children = parent.findElements(By.tagName("rect"));
children.get(1).click();
}
你有什么想法?
最佳答案
这对我有用(恐怕是c#)。没有一种简单的方法可以识别哪些数据位于哪个矩形中,因此除非您已经知道该系列的顺序,否则这可能是一个问题:
IList<IWebElement> bars = MyWebDriver.Driver.FindElements(By.TagName("rect"));
foreach (var bar in bars)
{
Thread.Sleep(500);
try
{
bar.Click();
}
catch (Exception e)
{
}
}
关于java - 将 highchart SVG 图像与 Selenium 结合使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27102131/