Ana içeriğe atla

TestNG - Bağımlılık (Dependency)

Bazı durumlarda yazdığınız test kodunda birbirine bağımlı test metotları olabilir. TestNG, bu bağımlılıkları xml dosyanızda ya da kodunuzda belirtmenize (annotation ile) olanak sağlar.
TestNG'de iki çeşit bağımlılık vardır:
Hard dependency'de testinizin bağımlı olduğu diğer testlerin hepsinin başarılı olması gerekir. Eğer bir tanesi bile başarısız olduysa bağımlı olan testler çalışmaz, atlanır. 
Soft dependency'de ise bağımlı olunan testlerden başarısız olan olsa bile diğer testler çalışır. Bu bağımlılık çeşidini kullanmak için @Test (alwaysRun=true) ifadesini eklemek gerekir.

Aşağıda, Hard dependency'nin kodda belirtilmesine örnek kod bulunmaktadır. Hem metota bağımlılık hem gruba bağımlılık belirtilebilir.

@Test
public void serverStartedOk() {}
@Test(dependsOnMethods = { "serverStartedOk" })
public void method1() {}

Bu örnekte, method1() ,serverStartedOk() metoduna bağımlı olarak belirtilmiştir, bu durumda ilk serverStartedOk() metodu çalışacaktır.

@Test(groups = { "init" })
public void serverStartedOk() {}
@Test(groups = { "init" })
public void initEnvironment() {}
@Test(dependsOnGroups = { "init.*" })
public void method1() {}

Bu örnekte de, method1, init adıyla başlayan gruplara bağımlıdır. Yani method1'den önce init adıyla başlayan gruplar koşacaktır.

Burada da xml dosyası ile bağımlılık belirtilmiştir. <dependencies> etiketinin içine kodunuza uygun bağımlılıkları belirtebilirsiniz. Burada c grubu, a ve b'ye, z grubu ise c'ye bağımlıdır. Yani c'den önce a ve b grupları, z'den önce de c grubu çalışacaktır.

<test name="My suite">
  <groups>
    <dependencies>
      <group name="c" depends-on="a  b" />
      <group name="z" depends-on="c" />
    </dependencies>
  </groups>
</test>

Bağımlılık durumunda, bağımlı olunan metodun bütün instance'ları koşmadan bağımlı olan metot çalıştırılmaz. Bazı durumlarda bunun aksi istenir. Mesela birden fazla web sitesine giriş - çıkış işlemlerini içeren test senaryonuz olması halinde her web sitesine giriş yapıldıktan sonra hemen çıkış işleminin içeren testin koşmasını isteriz, diğer web sitesine giriş yapılmasını değil. Bu durumda xml dosyanıza <suite> ya da <test> için geçerli olan "group-by-instances" özelliğini kullanabilirsiniz.

<suite name="Factory" group-by-instances="true">
ya da
  <test name="Factory" group-by-instances="true">



Yorumlar

Bu blogdaki popüler yayınlar

Selenium - XPath Kodları

XPath, XML Path Absolute XPath: root node u verir ve / ile başlar Elementin path inde herhangi bir değişiklik yapılırsa, test kodu hata verir. Örn:  html/body/div[1]/section/div[1]/div/div/div/div[1]/div/div/div/div/div[3]/div[1]/div/h4[1]/b Relative XPath: xml dokümanındaki elementi verir ve // ile başlar Örn : //*[@class='featured-box']//*[text()='Testing'] XPath Kombinasyonları: Belli bir tagin belli bir attribute değeri ile kullanımı Herhangi bir tag in belli bir attribute değeri ile kullanımı "and" operatörü "or" operatörü Belirli bir değer ile başlayan attribute Metnin bir kısmını içeren attribute Sadece text() Herhangi bir attribute un değeri Belli Bir Tag'ın Belli Bir Attribute Değeri ile Kullanımı (Specific tag with specific attribute value) Html Kodu < input   id = "Lid"  .....   > input:tag adı (etiket adı) id : attribute Lid : attribute değeri Selenium Kodu driver.findElement(By.x...

Test Otomasyonu için Intellij IDEA Maven Projesi Oluşturma

Intellij IDEA - File - Project - New tıklayın.  Soldan Maven ı seçin.  İleriye basın.  Group ID, sizin projenizi tanımlayan bir isim olmalı. Bu alanı doldurun. ArtifactId, projenizin adı. Bu alanı doldurun. Project name, artifactID alanına yazdığınız değer gelir. Finish e basın. İlk olarak karşınıza projenizin pom.xml dosyası gelecek. Buraya ilgili bağımlılıkları ekleyin. Selenium için;  https://www.seleniumhq.org/download/maven.jsp  adresindeki güncel bağımlılığı <dependencies> </dependencies> satırlarının arasına ekleyin. Daha sonra sağ altta çıkan uyarıda Import linkine basın. Böylelikle maven belirttiğiniz versiyonun dosyalarını alacaktır. Test framework ü olarak kullandığımız JUnit bağımlılığı için  https://mvnrepository.com/artifact/junit/junit  adresindeki güncel versiyonundan aldığınız satırları yine aynı  <dependencies> </dependencies> satırlarının arasına ekleyin. Daha sonra sağ altta çıkan uya...

Selenium- WebDriver, WebElement

WebDriver Web tarayıcısını test etmeye yarayan instance. WebDriver driver; driver = new FirefoxDriver(); driver.get("https://www.google.com"); Web uygulamasını test etme : Web tarayıcısını kontrol etme, element bulma ve debugging yapmayı gerektirir.  Web tarayıcısını kontrol etmeye yarayanlar: get navigate close manage switchTo quit Web elementi seçme findElement findElements click ... Debugging getTitle getCurrentUrl getWindowHandle... WebElement Web sayfasındaki elementleri bulma ve işlem yapmaya yarar. By sınıfını kullanır. WebElement element = driver.findElement(By.id("Lid")); By daki element locatorlar: id name classname tagname cssSelector linkText partialLinkText xpath