2012-02-13 69 views
1

我怎样才能得到一个网页的所有链接,并使用硒我怎样才能得到一个网页的所有链接,并使用硒

//代码

WebDriver driver = new FirefoxDriver(); 
    driver.get("http://www.HRS.com"); 
    List<WebElement> MyList = driver.findElements(By.xpath("//a")); 
    for(WebElement Element : MyList) 
    { 
    Element.click(); ----> m getting an error (IN 2 ITERATION) stating 
          "Element not found in the cache - perhaps the page has 
          changed since it was looked up" 

    } 
点击逐个点击逐个

任何人都可以帮我吗?

在此先感谢

+0

我现在面临使用PHPUnit +硒类似的问题。 getXpathCount('// a')返回25.但是,isElementPresent('// a [3]')向前返回false。 – 2012-02-27 13:37:08

回答

0

当你点击链接你是以下的链接,你已经找到的元素无效。你需要要么回到页面:

driver.navigate().back(); 

做这样后,你将需要刷新列表中的元素,这意味着当前的循环结构可能会无法正常工作。

另一种选择是通过以下方式查询:

//Might need to do some extra work if this is a relative link 
HttpURLConnection httpConn = new HttpURLConnection(element.getAttribute("href")); 
URLConnection = httpConn.openConnection(); 
if (conn instanceof HttpURLConnection) { 
    HttpURLConnection http = (HttpURLConnection) conn; 
    Assert.assertTrue("Invalid link on page.", http.getResponseCode() < 400); 
} 
0

其中最繁琐的任务,IMO,对于测试工程师,手动验证链接。我们可以实现大部分流程的自动化,只要我们有URL,点击链接后我们可以预期到哪里,我们可以使用Selenium和一点JS来验证这个功能。

在下面的示例中,我们首先导航到我们想要的网站,然后使用Selenium的getEval()函数来执行JavaScript,该页面收集页面上的所有链接(锚点)并将它们保存在逗号分隔的列表中。这个列表然后被分割并推入到一个数组中。然后,我们遍历数组中的链接列表,单击每个链接,然后使用go_back导航回起始页面。下面

例子:

use strict; 
use warnings; 
use Time::HiRes qw(sleep); 
use Test::WWW::Selenium; 
use Test::More "no_plan"; 

my $sel = Test::WWW::Selenium->new(host => "localhost", 
            port => 4444, 
            browser => "*iexplore", 
            browser_url => "http://www.google.com/"); 

$sel->open_ok("/", "true"); 

$sel->set_speed("1000"); 

my $javascript = "var allLinks = this.browserbot.getCurrentWindow().document.getElementsByTagName('a'); 
       var separator = ','; 
       var all_links_texts = ''; 

       for(var i = 0; i < allLinks.length; i++) { 
         all_links_texts = all_links_texts+separator+allLinks[i].href; 
       } 
       all_links_texts;"; 

# Get all of the links in the page and, using a comma to separate each one, add them to the all_links_texts var. 
my $link_list = $sel->get_eval($javascript); 

my @link_array = split /,/ , $link_list; 

my $count = 0; 

# Click on each link contained in the array and then go_back 
# You can add other logic here like capture and store a screenshot for example 
foreach my $link_name (@link_array) { 

    unless ($link_name =~ /^$/){ 

     $sel->click_ok("css=a[href $= $link_name]"); 

     $sel->wait_for_page_to_load("30000"); 

     print "Clicked Link href: $link_name \n"; 

     $sel->go_back(); 

     $count++; 
    } 
} 
print "Clicked $count URL's"; 
pass; 

以上可以很容易地修改做的不仅仅是点击链接等等。当然,在所点击的链接的预定着陆页上,没有什么能够胜出。

我们充分的博客文章是在这里:Get all links and click on each one

相关问题