Watir-자동 대기

이 장에서는 대기 시간을 자세히 이해하겠습니다. 자동 대기를 이해하기 위해 간단한 테스트 페이지를 만들었습니다. 사용자가 텍스트 상자에 텍스트를 입력하면 onchange 이벤트가 발생하고 3 초 후에 버튼이 활성화됩니다.

Watir에는 특정 이벤트 또는 속성을 기다리는 wait_unit api 호출이 있습니다. 아래에 주어진 테스트 페이지에 대해 동일하게 테스트합니다.

통사론

browser.button(id: 'btnsubmit').wait_until(&:enabled?)
//here the wait is on the button with id : btnsubmit to be enabled.

testwait.html

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsentered() {
            setTimeout(function() {
            document.getElementById("btnsubmit").disabled = false; }, 3000);
         }
         function wsformsubmitted() {
            document.getElementById("showmessage").style.display = "";
         }
      </script>
      
      <div id = "divfirstname">
         Enter First Name : 
         <input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
      </div>
      <br/>
      <br/>
      <button id = "btnsubmit" disabled onclick = "wsformsubmitted();">Submit</button>
      <br/<
      <br/<
      
      <div id = "showmessage" style = "display:none;color:green;font-size:25px;"&gtl;
         Button is clicked
      </div>
   </body>
</html>

산출

텍스트 상자에 텍스트를 입력 할 때 버튼이 활성화 될 때까지 3 초 동안 기다려야합니다.

제출 버튼을 클릭하면 다음 텍스트가 표시됩니다.

이제 버튼을 활성화하는 데 지연을 추가 했으므로 자동화가 이러한 경우를 처리하기가 어렵습니다. 지연이 발생하거나 찾을 요소의 이벤트 나 속성을 기다려야 할 때마다 아래와 같이 wait_until을 사용할 수 있습니다.

wait_until을 사용하는 Watir 코드

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/testwait.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'waittestbefore.png'
t.value
t.fire_event('onchange')
btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)
btn.fire_event('onclick');
b.screenshot.save 'waittestafter.png'

다음으로 다음 명령을 사용하십시오.

btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)

Watir는 버튼이 활성화 될 때까지 기다렸다가 나중에 클릭 이벤트가 시작될 때까지 기다릴 것입니다. 캡처 된 스크린 샷은 다음과 같습니다.

Waittestbefore.png

waittestafter.png