Ana içeriğe atla

Explicit Wait

Explicit Wait

Explicit wait, Web Driver a belli şartlarda (Expected Conditions) "ElementNotVisibleException" hatası vermeden önce en çok ne kadar beklemesi gerektiğini söyler.
Explicit wait kullanırken "ExpectedCondtions" ı da kullanmalıyız ya da belirttiğimiz durumu Fluent Wait kullanarak ne kadarda bir kontrol edeceğimizi belirtmeliyiz
public class AppTest {
 protected WebDriver driver;
 @Test
 public void tutorials() throws InterruptedException 
 {
 System.setProperty ("webdriver.chrome.driver",".\\chromedriver.exe" );
 driver = new ChromeDriver(); 
 WebDriverWait wait=new WebDriverWait(driver, 20);
 String eTitle = "Blogger.com - Benzersiz, göz alıcı bir blog hazırlayın. Hizmetimiz ücretsizdir ve kullanımı kolaydır.";
 String aTitle = "" ;
 // launch Chrome and redirect it to the Base URL
 driver.get("https://www.blogger.com/about/?r=1-null_user" );
 //Maximizes the browser window
 driver.manage().window().maximize() ;
 //get the actual value of the title
 aTitle = driver.getTitle();
 //compare the actual title with the expected title
 if (aTitle.contentEquals(eTitle))
 {
 System.out.println( "Test Passed") ;
 }
 else {
 System.out.println( "Test Failed" );
 }
 WebElement blogLink;
 blogLink= wait.until(ExpectedConditions.visibilityOfElementLocated(By.xpath( "/html/body/main/section[1]/header/a")));
 blogLink.click();
 }
 
Burada expectedConditions'daki elementin görünür olması durumu oluşana kadar waitDriverWait'deki süre kadar bekleyecek.

Aşağıdakiler Explicit Wait'deki beklenen durumlar(Expected Conditions): 
  1. alertIsPresent()
  2. elementSelectionStateToBe()
  3. elementToBeClickable()
  4. elementToBeSelected()
  5. frameToBeAvaliableAndSwitchToIt()
  6. invisibilityOfTheElementLocated()
  7. invisibilityOfElementWithText()
  8. presenceOfAllElementsLocatedBy()
  9. presenceOfElementLocated()
  10. textToBePresentInElement()
  11. textToBePresentInElementLocated()
  12. textToBePresentInElementValue()
  13. titleIs()
  14. titleContains()
  15. visibilityOf()
  16. visibilityOfAllElements()
  17. visibilityOfAllElementsLocatedBy()
  18. visibilityOfElementLocated()
  • isEnabled() : komut çalışmadan önce element enable mı değil mi onu doğrular.
  • isDisplayed() : komut çalışmadan önce element görüntüleniyor mu, onu doğrular. 
  • isSelected() : check box, radio button, ya da drop-down daki değer seçilmiş mi, ona bakar. Başka elementlerde çalışmaz.
isEnabled(), isDisplayed(), and isSelected() kullanıldığında, WebDriver elementin sayfada bulunduğunu varsayar. Aksi takdirde NoSuchElementException hatası verir.  Bundan kaçınmak için try-catch bloğu kullanmak gerekir ki program bölünmesin.

Eğer explicit waits kullanılırsa, catch deki exception, "TimeoutException" olmalıdır.
  • alertIsPresent() - uyarı kutusu çıkana kadar bekler.
  • elementToBeClickable() - elementin hem görünür hem de etkin olmasını bekler.
  • frameToBeAvailableAndSwitchToIt() - verilen frame etkin olana kadar bekler, daha sonra otomatik olarak ona geçer.

Yorumlar

Bu blogdaki popüler yayınlar

Selenium Actions Sınıfını Kullanarak Klavye ve Fare İşlemleri

Karmaşık kullanıcı hareketlerini (sağ tıklama, iki kere tıklama, sürükleme,...) taklit etmek için kullanılan API. Doğrudan Klavye veya Fare kullanmak yerine bu sınıf kullanılır. Build patternini uygular: yöntem çağrıları tarafından belirtilen tüm eylemleri içeren bir CompositeAction oluşturur. Kullanıcı hareketlerini uygulayan fonksiyonları kullanmak için Actions ve Action sınıfını import etmek gerekir: Actions sınıfı ve Action sınıfı, WebDriver API'sinin org.openqa.selenium.Interactions paketinde bulunur. import org.openqa.selenium.interactions.Actions; import org.openqa.selenium.interactions.Action; Yöntemlerini kullanmaya çağırmak için Actions sınıfı nesnesine ihtiyaç vardır.  Actions actions = new Actions(WebDriver nesnesi); Üzerinde işlem yapılacak elementi bulmak gerekiyor. WebElement webElement = driver.findElement(...);  actions.contextClick(webElement).perform(); //contextClick, element üzerinde sağ tıklar. Bu sınıfının bazı fonksiyonl...

Selenium WebDriver - Dinamik Web Tablolarla Kod Örnekleri

Verisi sürekli değişen tablolarda XPath kullanılması gerekir. Bunu da tablonun satır ve sütun sayı bilgileriyle yapmak daha doğru olur. Tablo 1: Şirket Grup Kapanış Şimdiki Ücret % Değişim IL&FS Transportation A 337.4 66.5 + 5.4 GRUH Finance Li A 383.8 998.9 + 2.3 IDFC Bank A 351.4 715.9 + 5.1 YES Bank Ltd. A 697.9 669.3 + 3.2 IRB Infrastructure A 271 724.8 + 3.1 Escorts Ltd. A 113.4 890.3 + 5.1 Cox & Kings L A 867 900.8 + 5.5 Bharat Electroni A 176.5 849 + 7.5 Nestle India A 64.8 187.3 + 7.6 Cox & Kings L A 749.4 729.5 + 9.5 JK Tyre & Industries A 687 601.4 + 6 Navin Fluorine Inter A 416.7 865.3 + 8.9 NIIT Technologies A 966.9 117.2 + 9.4 DCB Bank A 853.2 760.2 + 2.4 UCO Bank A 358 719.6 + 9 Coffee Day Enterpris A 53.8 538.6 + 4.1 Kirloskar Oil Engine A 134.1 102.8 + 7.7 Repco Home Finance L A 96.2 449.9 + 8.9 Ajanta Pharma Lt A 161.3 838 + 4.4 CESC Ltd. A 817 490.5 + 4.7 JaiprakashAssociates A 247.3 961.1 + 7.1 Vakrangee A 888.3 652.9 ...

TestNG - Notasyonlar (Annotations), Doğrulamalar (Assertions)

TestNG, JUnit ve NUnit kütüphanelerinden etkilenen ve onlara göre daha fazla yetkinlik barındıran bir test kütüphanesidir. TestNG ait özellikler ve kolaylıklar için şunları örnek verebiliriz: Notasyonlar (Annotations) Testlerin kendine has Thread’lerde koşabilmesi testng.xml dosyasıyla testlerin önceliklendirilmesi, gruplandırılması vb. kolaylıklar Kendi içerisinde loglama, raporlama desteği Notasyonlar sayesinde kodun ve oluşturulan raporun kolaylıkla anlaşılması @DataProvider notasyonu sayesinde veriye dayalı test desteği (Data Driven Test) Maven, Jenkins vb. ide ler için eklenti desteği Parametre desteği Notasyonlar: @Test Notasyonu Yazılan otomasyon kodunda test olarak çalışmasını istediğimiz kod parçasının önüne bu notasyonu ekleriz. Bu notasyonu birden fazla kez kullanabiliriz. Eğer herhangi bir parametre tanımlanmadıysa testler alfabetik olarak çalışır.  Aşağıdaki parametreler, hangi testin hangi sırayla çalışacağının, koşturulup koşturulmayacağın...