Ana içeriğe atla

Selenium - Fonksiyonlar


FindElement(By by)

Bu method işlem sırasında 'implicit wait' i bekler. Yani aradığı elementi implicit wait ne kadar verildiyse o kadar süre için arar, bulamazsa timeout olur, NoSuchElementException hatası verir.

FindElements(By by)

Birşey bulamazsa boş liste döndürür.
Bir sayfadaki bütün linkleri bulabilirsin, linkler dediği yere gidiyor mu, aktif link mi, vs.

findElement.getAttribute("attribute name")

Element in verilen attribute unu getirir. Yoksa boş döndürür.

String value = driver.findElement(By.name("btnK")).getAttribute("value");
System.out.println("Value of search button: " + value);

Value of search button: Google'da Ara

findElement.getCssValue("css property")

Verilen CSS özelliğinin değerini getirir; font size, renk, arka plan rengi gibi. F12 ye bastığında style kısmında dönen sonuçları doğrulatabilirsin.

WebElement searchbutton = driver.findElement(By.name("btnK"));
String fontstyle = searchbutton.getCssValue("font-style");//butonu web element olan searchbuttona atadık
String fontsize = searchbutton.getCssValue("font-size");//o yüzden artık driver.find.. değil searchbutton.find yazıyoruz
String backgroundcolour = searchbutton.getCssValue("background-color");

System.out.println("Font style of search button: " + fontstyle);
System.out.println("Font size of search button: " + fontsize);
System.out.println("Background colour of search button: " + backgroundcolour);

findElement.getLocation()

Parametre almaz, istediğinin nokta bilgisini döndürür. X ve Y koordinatlarını alabilirsin.

WebElement searchbutton = driver.findElement(By.name("btnK"));
int xcoordinate = searchbutton.getLocation().x;
int ycoordinate = searchbutton.getLocation().y;
System.out.println("Search button x coordinate: "+ xcoordinate);
System.out.println("Search button y coordinate: "+ ycoordinate);

findElement.getSize()

Objenin boyutlarını döndürür. Genişlik, yükseklik döndürebilirsin.

WebElement searchbutton = driver.findElement(By.name("btnK"));
int width = searchbutton.getSize().width;
int height = searchbutton.getSize().height;
System.out.println("Search button width: "+ width);
System.out.println("Search button height: "+ height);

findElement.getTagName()

Elementin html kodundaki tag name ini döndürür. Parametre almaz.

String tagname = searchbutton.getTagName();
System.out.println("Search button tagname: " +tagname);
Döndürdüğü sonuç: input

findElement.isDisplayed()

Elementin görünür olup olmadığına karar verir. Element sayfada görünüyorsa true döndürür, görünmüyorsa NoSuchElementFound exception döndürür, gizli ise false döndürür.
Parametre almaz. True ya da false döndürür.

findElement.isEnabled()

Elementin enable olup olmadığına karar verir. Element enable ise true döndürür, disable ise false döndürür. Parametre almaz. True ya da false döndürür.

 boolean enabled = searchbutton.isEnabled();
System.out.println("Search button enabled status: " +enabled);

findElement.isSelected()

Elementin seçili olup olmadığına karar verir. Element seçili ise true döndürür, değilse false döndürür.
Parametre almaz. True ya da false döndürür. Bu işlem checkbox, select options ve radio button lar için uygulanır.

  WebElement rmm_me = driver.findElement(By.id("Rem"));
boolean beforeselected = rmm_me.isSelected();
System.out.println("Remember me radio button is selected:" +beforeselected);
rmm_me.click();
boolean afterselected = rmm_me.isSelected();
System.out.println("Remember me radio button is selected:" +afterselected);

findElement.sendKeys("CharSequence")

Veri girilen yerlere karakterlerin yazılmasını sağlar. Parametre olarak character alır.

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...