我们可能在测试时都看到了这个屏幕,您只需要一个带有自签名证书的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>
<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> </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> </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> </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> </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>
答案 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()")