在css选择器中使用带有表中多个元素的元素

时间:2017-09-07 06:09:09

标签: java selenium css-selectors ui-automation selenide

我正在使用Selenide / Selenium编写我的java自动化脚本,最近我遇到了一个问题。我想从我比较第二个元素的同一行中获取一个元素。 Html示例代码:

<tr ng-repeat="testing" class="ng-scope" style="">
    <td class="ng-binding">Style</td>
    <td ng-if="testing2" class="ng-binding ng-scope">1</td>
    <td class="ng-binding">5%</td>
</tr>
<tr ng-repeat="testing" class="ng-scope" style="">
    <td class="ng-binding">Mask</td>
    <td ng-if="testing2" class="ng-binding ng-scope">2</td>
    <td class="ng-binding">8%</td>
</tr>
...

让我们想象一下会有更多这样的东西。最重要的是这些可以随机化。每一次。它们取决于最后一页我选择的内容和方式。

所以基本上我想搜索测试,它有8%。

我尝试过但我不知道该怎么做。它将所有元素存储在列表中。我之前使用Chrome驱动程序信息获取css选择器。我可以把它取消,但我认为有更好的解决方案:

List<WebElement> list = getWebDriver().findElements(By.cssSelector("[ng-
repeat='hyvitisLiik in vm.taotluseHyvitised'] > [class='ng-binding']"));
for(int i = 0; i < list.size(); i++){
  logger.info(list.get(1));
}

我还尝试使用此代码获取元素:

int counter = $$(By.cssSelector("tr > [class='ng-binding']")).size();
for (int i = 0; i < counter; i++) {
SelenideElement word= $$(By.cssSelector(lokaator)).get(counter);
word.getText();
}

此代码采用“Mask”和“8%”元素。 但我真正想要的是测试getText给定值是否为“Mask”,取百分比值并进行比较。 例如:在网络上搜索单词“Mask”,取百分比值(在这种情况下为8%)并通过断言验证它正好是8%。

有没有办法用索引设置CSS选择器,比如

tr[1] > [class='ng-binding']

将选择第二个tr类?找到我想要的其他建议吗?

修改 是否有可能使用css选择器只使用一行,如xpath选项所示,回答@Jy写的内容:

WebElementelement=getWebDriver().findElement(By.xpath("//td[text()='Mask']/followingsibling::td[2]"));
element.getText(); // 8%

5 个答案:

答案 0 :(得分:1)

您可以尝试使用以下css选择器,它可能会对您有所帮助。

table>tr:nth-child(2)>td ---- To get the first td element of second row

table>tr:nth-child(2)>td:nth-child(3) --- To get last td element of second row

在Java中,

List<WebElemet> lstRows=getWebDriver().findElements(By.cssSelector("table>tr[ng-repeat='testing']");

for(WebElement row:lstRows){
   if(row.findElement(By.cssSelector("td")).getText().equals("Mask")){
  {
  String percentage= row.findElement(By.cssSelector("td:last-child")).getText();
   if(percentage.equals("8%")
     System.out.println("pass");
   else
     System.out.println("fail");
  break;
  }
}

答案 1 :(得分:1)

使用CSS和Java,我们可以执行:

List<WebElement> elements = getWebDriver().findElements(By.cssSelector("tr[ng-repeat='testing']"));
    for(int i = 0; i < elements.size(); i++) {
        if(elements.get(i).findElement(By.cssSelector("td")).getText().contains("Mask")) {
            //assert elements.get(i).findElements(By.cssSelector("td")).get(2).getText() equals 8%
    }
}

或者,如果使用xpath,则可以通过比较文本来实现     '// tr [@ ng-repeat ='testing'] / td [contains(text(),'Mask')] /../ td [3]' locator

答案 2 :(得分:1)

您可以使用xpath使用Mask文字

找到元素
WebElement element = getWebDriver().findElement(By.xpath("//td[text()='Mask']/following-sibling::td[2]"));
element.getText(); // 8%

答案 3 :(得分:0)

如您所希望search in web for the word "Mask", take the percent value (in that case it is 8%) and validate with assert that it is exactly 8%,您可以创建一个函数,该函数将采用2个字符串类型的参数,即文本Mask和文本8%。从main()test()类调用提供参数的函数。在被调用函数中,我们可以轻松检索文本和断言百分比。您的代码将如下所示:

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.Assert;

public class Q46088968_validate_score 
{
    static WebDriver driver;
    public static void main(String[] args) 
    {
        System.setProperty("webdriver.chrome.driver", "C:\\Utility\\BrowserDrivers\\chromedriver.exe");
        driver = new ChromeDriver();
        driver.get("https://www.gmail.com");
        //other actions
        validate_score("Mask", "8%");
        driver.quit();
    }

    public static void validate_score(String my_text, String expected_percentage)
    {
        String actual_percentage = driver.findElement(By.xpath("//td[.='" + my_text + "']//following::td[2]")).getText();
        Assert.assertEquals(actual_percentage, expected_percentage);
    }
}

答案 4 :(得分:0)

试试这个

List<WebElement> elements = getWebDriver().findElements(By.xpath("//td[text()='Mask']/../td[3]"));

    int pass = 0;
    for(WebElement e | elements) {
       if(!(e.getText().equals("8%"))) {
          pass = 1
       }
    }

    if(pass == 0) {
System.out.println("Pass");
} 
else {
System.out.println("Fail");
}