Ana içeriğe atla

HTMLUnit Başlangıç

HtmlUnit java programları için kullanılan headless (govdesiz, sanal) bir web browser. Yani ortada herhangi bir arayüz olmadan tüm tarayıcı fonksiyonlarını java kodları ile yapmakta. HtmlUnit ile sayfaların html bilgisini alabilirsiniz ya da test için kullanabilirsiniz. Herhangi bir web sayfasındaki; sayfa çağırma, form doldurma, linke tıklama vs. gibi işlemleri yapabilirsiniz.

JavaScript desteği bulunmakta, AJAX kütüphaneleriyle çalışmakta ve Chrome, Firefox, Internet Explorer gibi tarayıcıları simüle etmektedir. 

HtmlUnit, birim test framework ü değil, JUnit, TestNG gibi frameworklerle beraber çalışmaktadır.

Eğer maven kullanıyorsanız; bağımlılıkları pom.xml dosyanıza ekleyerek, projenizi derleyerek HtmlUnit in bağımlı olduğu jar kütüphanelerini projenize eklemiş olursunuz.

Eğer kullanmıyorsanız , HtmlUnit in jar kütüphanelerini indirip, kullandığınız IDE'deki ilgili pakete Build Path-Configure Build Path- Libraries kısmından Add External Libraries e tıklayarak eklemelisiniz. Selenium ile HtmlUnit in versiyonlarının uyumlu olmasına dikkat etmelisiniz yoksa WebDriverException: java.lang.IllegalArgumentException: gibi hata alabilirsiniz. Bunun için System.out.println(HttpClientBuilder.class.getProtectionDomain().getCodeSource().getLocation ile hangi jarı kullandığını görüp düzeltebilirsiniz.

HtmlUnit in faydaları platform bağımsız ve hızlı çalışmasıdır. Eğer isterseniz kodunuza hangi tarayıcıyı simüle edeceğini belirtebilirsiniz. Aşağıda Chrome u simüle etmesini belirtiyoruz.

HtmlUnitDriver driver = new HtmlUnitDriver(BrowserVersion.CHROME)

Aşağıda Google un başlığını kontrol eden çok basit HtmlUnit kullanılarak yazılmış test kodu bulunmakta. 



public class HTMLUnit {

  HtmlUnitDriver driver = new HtmlUnitDriver();//HtmlUnitDriver ı kullanıyoruz



  @Before

  public void setUp() throws Exception {

   driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);

  }

  

  @Test

  public void testRelativexpath() throws Exception {

   driver.get("https://www.google.com/");

   String Title = driver.getTitle();

   System.out.println("Title of the webpage = " +Title);

   

      assertEquals(Title,"Google");  

  } 



  @After

  public void tearDown() throws Exception {

    driver.quit();

  }

  

}



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

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

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