web-dev-qa-db-fra.com

Extraire du contenu dans: après avoir utilisé XPath

J'essaie d'obtenir la valeur d'un attribut CSS "contenu" avec:

WebElement plusOrMinusSign = currentEntityTypeLevel1.findElement(
    By.xpath("i[@class='tree-branch-head']::after"));
System.out.println(plusOrMinusSign.getCssValue("content"));

Cependant, j'obtiens une erreur: The string 'i[@class='tree-branch-head']::after' is not a valid XPath expression.

Il semble que le "::after "n'est pas reconnu.

Html:

<i class="tree-branch-head" ng-class="iBranchClass()" ng-click="selectNodeHead(node)">::after
</i>

Css:

i:after {
    content: "-";
}

Une idée comment obtenir la valeur du "contenu"?

6
Rico Strydom

Vous utilisez By.xpath mais i[@class='tree-branch-head']::after n'est pas un XPath valide, c'est un mélange de notation XPath (i[@class='tree-branch-head']) et CSS (:after).

Tu devrais utiliser By.cssSelector et un sélecteur CSS valide, par exemple i.tree-branch-head:after. Cela fonctionnerait si Selenium acceptait des pseudo-éléments, ce qu'il ne fait pas.

Pour contourner ce problème, vous pouvez utiliser Chromium, qui génère de faux éléments supplémentaires ::after et ::before, ou utilisez un extracteur Javascript comme décrit dans https://stackoverflow.com/a/28265738/449288 .

7
gioele

Gérer le pseudo-élément dans le pilote Web Selenium

 String script = "return window.getComputedStyle(document.querySelector('Enter root class name here '),':after').getPropertyValue('content')";
            Thread.sleep(3000);
            JavascriptExecutor js = (JavascriptExecutor) driver;
            String content = (String) js.executeScript(script);
            System.out.println(content);

Utilisez maintenant cette chaîne de contenu dans votre commande assert ou n'importe où que vous souhaitez utiliser, espérons que cela fonctionnera pour vous ... Bonne chance

1
Nitin Singh