我们怎样才能让Watir-Webdriver与IE无效证书屏幕一起使用?

时间:2011-11-12 01:05:32

标签: webdriver watir watir-webdriver

我们可能在测试时都看到了这个屏幕,您只需要一个带有自签名证书的HTTPS站点,并且您会看到“此网站的安全证书存在问题”屏幕,这需要您单击链接继续。

使用Watir这没问题,我像其他任何网页一样自动化屏幕,根据文本或ID值点击链接。

使用Watir-Webdriver,就好像HTML中的任何内容都无法识别。我并不孤单See this question

这不仅仅是尝试点击链接,您在此处尝试的几乎任何内容都会在此页面上失败即使像puts browser.text这样的简单函数也会返回错误。

Selenium::WebDriver::Error::NoSuchElementError: Unable to find element with tag name == body

您可以查看源代码,使用开发人员工具,或者让浏览器元素吐出HTML,并在那里清楚地看到darned body标签,但Webdriver因某种原因对此视而不见。

我不知道它是线索还是红鲱鱼,但我知道webdriver在引擎盖下使用了大量的XPATH,我相信XPATH是区分大小写的。在这方面,当我对这个页面使用puts browser.html时,我看到了一些非常不寻常的东西,因为每个标记名都是完整的大写字母。在任何情况下都有点不寻常但合法有效的HTML。在其他页面上使用browser.html显示小写标签。这可能是导致webdriver在这个页面上出现这么多问题的原因吗?

有没有人有任何明智的想法,我怎么能够让webdriver看到链接元素,所以我可以点击它?

当我询问页面HTML

时,浏览器对象的输出
irb(main):019:0> puts $browser.html  #note, indentation is added later for clarity
<HTML dir=ltr>
<HEAD>
<TITLE>Certificate Error: Navigation Blocked</TITLE>
<LINK rel=stylesheet type=text/css href="ErrorPageTemplate.css">
<META name=MS.LOCALE content=EN-US>
<META content="text/html; charset=utf-8" http-equiv=Content-Type>
<META content=Yes http-equiv=MSThemeCompatible>
<SCRIPT language=javascript type=text/javascript src="errorPageStrings.js">
</SCRIPT>
<SCRIPT language=javascript type=text/javascript src="httpErrorPagesScripts.js">
</SCRIPT>
<SCRIPT language=javascript type=text/javascript src="invalidcert.js">
</SCRIPT>
</HEAD>
<BODY onload="BodyLoad(); initMoreInfo('infoBlockID');" class=securityError>
<TABLE border=0 cellSpacing=0 cellPadding=0 width=730>
  <!-- Main title -->
  <TBODY>
  <TR>
    <TD id=shieldIconAlign vAlign=top rowSpan=3 width=60 align=left>
      <IMG id=shieldIcon alt="Shield icon" src="red_shield_48.png"> 
    </TD>
    <TD id=mainTitleAlign vAlign=middle align=left>
      <H1 id=mainTitle>There is a problem with this website's security certificate</H1>
    </TD>
  </TR>
  <TR>
    <TD>
      <H3>
        <DIV id=linkdiv name="linkdiv"></DIV>
      </H3>
    </TD>
  </TR>
  <TR>
  <!-- This row is for the the divider-->
    <TD id=errorCodeAlign class=errorCodeAndDivider align=right>&nbsp;
      <DIV class=divider></DIV>
    </TD>
  </TR>
  <!-- Error Body -->
  <TR>
    <TD></TD>
    <TD>
      <H3>
        <DIV style="DISPLAY: block" id=CertUnknownCA name="CertUnknownCA">
          The security certificate presented by this website was not issued by a trusted certificate authority.
        </DIV>
        <DIV style="DISPLAY: none" id=CertExpired name="CertExpired"></DIV>
        <DIV style="DISPLAY: none" id=CertCNMismatch name="CertCNMismatch"></DIV>
        <DIV style="DISPLAY: none" id=CertRevoked name="CertRevoked"></DIV>
        <NOSCRIPT id=securityCert1></NOSCRIPT><BR>
          <ID id=securityCert2>
            Security certificate problems may indicate an attempt to fool you or intercept any data you send to the server.
          </ID>
      </H3>
    </TD>
  </TR>
  <!-- Recommendation-->
  <TR>
    <TD>&nbsp;</TD>
    <TD><H2 id=recommendation><B>We recommend that you close this webpage and do not continue to this website. </B></H2></TD>
  </TR>
  <!-- close webpage-->
  <TR>
    <TD>&nbsp;</TD>
    <TD id=closeWebpageAlign vAlign=middle align=left>
      <H4 id=closeWebpage>
        <IMG class=actionIcon border=0 alt="Recommended icon" src="green_shield.png">
        <A href="javascript:closePage()">Click here to close this webpage.</A> 
      </H4>
    </TD>
  </TR>
  <!-- continue to site-->
  <TR>
    <TD>&nbsp;</TD>
    <TD id=continueToSiteAlign vAlign=middle align=left>
      <H4 id=continueToSite>
        <IMG id=ImgOverride class=actionIcon border=0 alt="Not recommended icon" src="red_shield.png">
        <A id=overridelink href="http://admanager.qa-prod.local/signups/lead_form" name=overridelink>Continue to this website (not recommended).</A> 
      </H4>
    </TD>
  </TR>
  <!-- InfoBlock -->
  <TR>
    <TD id=infoBlockAlign vAlign=top align=right>&nbsp; </TD>
    <TD id=moreInformationAlign vAlign=middle align=left>
      <H4>
        <TABLE>
          <TBODY>
            <TR>
              <TD vAlign=top>
                <A onclick="javascript:expandCollapse('infoBlockID', true); return false;" href="#">
                  <IMG id=infoBlockIDImage class=actionIcon border=0 alt="More information" src="down.png">
                </A>
              </TD>
              <TD vAlign=top>
                <SPAN id=moreInfoContainer>
                  <A href="javascript:expandCollapse('infoBlockID', true);">More information</A>
                </SPAN>
                <NOSCRIPT></NOSCRIPT>
              </TD>
            </TR>
          </TBODY>
        </TABLE>
      </H4>
      <DIV style="DISPLAY: none" id=infoBlockID class=infoBlock>
        <P>
        <LI id=errorExpl1>If you arrived at this page by clicking a link, check the website address in the address bar to be sure that it is the address you were expecting.
        <LI id=errorExpl2>When going to a website with an address such as https://example.com, try adding the 'www' to the address, https://www.example.com.
          <P></P>
          <P id=moreInfoSeeHelpPF>For more information, see "Certificate Errors" in Internet Explorer Help.
          </P>
        </LI>
      </DIV>
    </TD>
  </TR>
</TBODY>
</TABLE>
</BODY>
</HTML>
=> nil
irb(main):020:0>

2 个答案:

答案 0 :(得分:2)

我做了一些实验,包括使用我发布的HTML来创建我自己的页面,没有任何JavaScript。如果我使用该页面,我发现它阻止了JavaScript操作。在这种情况下,当我尝试执行browser.text或browser.link.exists等操作时,我看到一个IE警告弹出窗口,告诉我IE正在阻止JS在该页面上工作。 (我在实际的证书错误页面上看不到的东西)在watir-webdriver中,我得到了与我报告的相同的错误。如果我单击选择以允许JS,那么我可以使用watir-webdriver中的页面。

因此,在页面的本质上看起来似乎阻止了任何阻止Webdriver访问页面的JS级别自动化。

我知道为什么MS会这样做,他们不希望虚假网站以某种方式使用JavaScript来解决这个警告。显然,Watir驱动事物的方式(通过OLE?)并不被视为您可以远程执行的操作,因此可以访问该页面。

然后解决方案是使用Watir进行IE自动化,或者使证书可信,因此您不会看到警告。

如果要使用Watir-Webdriver,则需要将测试服务器上使用的证书添加到“受信任的根证书颁发机构”存储中。注意不是默认的“个人”商店!添加证书时,您需要更改证书的位置,或者您基本上只对该会话授权执行一次。将会发出警告,现在所有来自该授权的证书都将受到信任。我会非常谨慎地使用它,仅在测试系统上使用,并且仅用于信任来自您自己的内部测试服务器的证书。

手动进入页面后,通过双击红色警告提醒您证书无效,这很容易。如果你做得对,你可以关闭浏览器,重新打开,导航并且不会出错。

答案 1 :(得分:2)

driver.goto("javascript:document.getElementById('overridelink').click()")