Ana içeriğe atla

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ı fonksiyonları:

clickAndHold () Geçerli fare konumuna (serbest bırakmadan) tıklar.

contextClick () Geçerli fare konumunda sağ tıklar. (Sağ Tıklama İşlemi)

doubleClick () Geçerli fare konumunda çift tıklama gerçekleştirir.

dragAndDrop (kaynak, hedef) Kaynak öğenin konumunda tıklayıp bekletir, hedef öğenin konumuna gider, sonra fareyi serbest bırakır.
Parametreler:
kaynak-elementin tutulduğu yer.
hede-elementin götürüleceği ve farenin serbest bırakılacağı yer

dragAndDropBy (kaynak, x-offset, y-offset) Kaynak öğenin konumunda tıklayıp bekletir, belirli bir ofset tarafından hareket eder ve ardından fareyi serbest bırakır.
Parametreler:
kaynak-elementin tutulduğu yer
xOffset-yatay hareket ofseti.
yOffset - dikey hareket ofseti.

keyDown (modifier_key) Bir değiştirici tuşa basma işlemini gerçekleştirir. Değiştirici tuşu serbest bırakmaz - sonraki etkileşimler basılı tutulduğunu varsayabilir. 
Parametreler:
modifier_key - değiştirici tuşlardan herhangi biri (Keys.ALT, Keys.SHIFT veya Keys.CONTROL)

keyUp (değiştirici _key) Bir anahtar bırakma işlemi gerçekleştirir.
Parametreler:
modifier_key - değiştirici tuşlardan herhangi biri (Keys.ALT, Keys.SHIFT veya Keys.CONTROL)

moveByOffset (x-offset, y-offset) Fareyi mevcut konumundan (veya 0,0) belirtilen ofsete hareket ettirir.
Parametreler:
x-uzaklık-yatay sapma. Negatif bir değer, fareyi sola hareket ettirmek anlamına gelir.
y-sapma - dikey sapma. Negatif bir değer, fareyi aşağı hareket ettirmek anlamına gelir.

moveToElement (toElement) Fareyi öğenin ortasına taşır.
Parametreler:
toElement-taşınacak element.

release () Geçerli fare konumundaki basılan sol fare düğmesini serbest bırakır

sendKeys (onElement, charsequence) Öğeye bir dizi tuş vuruşu gönderir.
Parametreler:
onElement - tuş vuruşlarını alacak olan eleman, genellikle bir metin alanı
charsequence - gönderilecek tuş vuruşlarının sırasını temsil eden herhangi bir dize değeri

Örnek:

Blogtaki arama butonuna tıklayıp "git komutlar" metnini büyük harflerle yazdırma kodu aşağıdadır.

  @Test
public void KeyboardAndMouse() throws InterruptedException{

    driver.get("http://sinemayk.blogspot.com/");    Actions action = new Actions(driver);    WebElement araButonu = driver.findElement(By.xpath("//button[@class='search-expand touch-icon-button']"));    Action click = action.moveToElement(araButonu).click().keyDown(araButonu, Keys.SHIFT).sendKeys("git komutlar").keyUp(araButonu, Keys.SHIFT).build();    click.perform();    Thread.sleep(5000);    System.out.println("GİT KOMUTLAR yazısı yazıldı");}


*build fonsiyonunu son yazarak birden fazla fonksiyonu peşpeşe kullanabilirsiniz.
*Thread.sleep in amacı sadece yazılanı gözle görmek, kullanmayabiliriz.

Yorumlar

Bu blogdaki popüler yayınlar

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