How does @CacheLookup work in WebDriver?

后端 未结 3 1884
情歌与酒
情歌与酒 2021-01-12 21:05

I\'m not sure that I understand the caching principle :

@CacheLookup
@FindBy(how = How.ID, using = namespace + signifLvl)
private WebElement sigLvl;
<         


        
相关标签:
3条回答
  • 2021-01-12 21:20

    I know this answer is late in the party. I have been trying to understand @Cachelookup myself and came up with certain tests and conclusions. This topic is hard to explain in short here. So please take a look at the article which tries to understand the inner workings of @CacheLookup and also the performance improvements that we get by using this annotation. Article is on ToolsQA here

    0 讨论(0)
  • 2021-01-12 21:30

    Page Factory works on the principle of configuring the proxies when Page Factory is initialized and every time you use a WebElement it will go and search for the element.

    Now what cachelookup does is it stores elements having @cachelookup annotation applied over it and then stores this element for further reference/s. For example:

      public class SearchPage {
     // The element is now looked up using the name attribute,
      // and we never look it up once it has been used the first time
      @FindBy(how = How.NAME, using = "q")
      @CacheLookup
      private WebElement searchBox;
      public void searchFor(String text) {
      // We continue using the element just as before
       searchBox.sendKeys(text);
      searchBox.submit();
       } }
    

    What this annotation does is it stores the value the searchBox element and now there is no need to search for this element on webpage again.

    0 讨论(0)
  • 2021-01-12 21:39

    Imho the question should rather be : What is the element pointer/id is about ?

    As WebElement doesn't have a state, only methods that call browser. @CacheLookup is only a shortcut for public WebElement el = driver.findElement(By); when initializing WebDriver's PageObject, for instance.

    After you have the instance, you are executing its methods, that call browser.

    The WebElement ID corresponds to a JS element instance. if you go like this on client JS :

    var node1 = document.createElement('a');
    

    and then append it somewhere, remove it from there, append it some place else, etc. and it is still the same node1 instance, the WebElement instance still points to the node1 element, because it is the same JS node instance.

    0 讨论(0)
提交回复
热议问题