TestNG - Panduan Cepat
Pengujian adalah proses memeriksa fungsionalitas aplikasi untuk memastikannya berfungsi sesuai persyaratan. Pengujian unit menjadi gambaran di tingkat pengembang di mana tindakan yang memadai diambil untuk menguji setiap entitas (kelas atau metode) untuk memastikan produk akhir memenuhi persyaratan.
JUnit telah mendorong pengembang untuk memahami kegunaan pengujian, terutama pengujian unit, jika dibandingkan dengan framework pengujian lainnya. Memanfaatkan arsitektur yang agak sederhana, pragmatis, dan ketat, JUnit telah mampu "menginfeksi" sejumlah besar pengembang. Lihatlah tutorial kami di JUnit untuk mendapatkan pemahaman yang baik tentang fitur-fiturnya. JUnit, pada saat yang sama, juga memiliki beberapa kekurangan, yang tercantum di bawah ini -
Awalnya dirancang untuk mengaktifkan pengujian unit saja, sekarang digunakan untuk semua jenis pengujian.
Tidak dapat melakukan pengujian ketergantungan.
Kontrol konfigurasi yang buruk (setUp / tearDown).
Intrusive (memaksa Anda untuk memperluas kelas dan memberi nama metode Anda dengan cara tertentu).
Model pemrograman statis (memaksa Anda untuk mengkompilasi ulang jika tidak perlu).
Pengelolaan rangkaian pengujian yang berbeda dalam proyek yang kompleks bisa sangat rumit.
Apa itu TestNG?
Definisi TestNG sesuai dokumentasinya adalah sebagai berikut -
TestNG adalah framework pengujian yang terinspirasi dari JUnit dan NUnit, tetapi memperkenalkan beberapa fungsi baru yang membuatnya lebih kuat dan lebih mudah digunakan.
TestNG adalah kerangka pengujian otomatis open source; dimanaNG cara NextGenerasi. TestNG mirip dengan JUnit (terutama JUnit 4), tetapi ini bukan ekstensi JUnit. Ini terinspirasi oleh JUnit. Ini dirancang untuk menjadi lebih baik daripada JUnit, terutama saat menguji kelas terintegrasi. Pencipta TestNG adalah Cedric Beust .
Menghilangkan sebagian besar batasan kerangka lama, TestNG memberi pengembang kemampuan untuk menulis pengujian yang lebih fleksibel dan kuat. Karena banyak meminjam dari Anotasi Java (diperkenalkan dengan JDK 5.0) untuk menentukan pengujian, ini juga dapat menunjukkan kepada Anda bagaimana menggunakan fitur baru bahasa Java ini dalam lingkungan produksi yang sebenarnya.
Fitur TestNG
Mendukung anotasi.
TestNG menggunakan lebih banyak fitur Java dan OO.
Mendukung pengujian kelas terintegrasi (misalnya, secara default, tidak perlu membuat instance kelas pengujian baru untuk setiap metode pengujian).
Memisahkan kode uji waktu kompilasi dari konfigurasi / info data run-time.
Konfigurasi runtime yang fleksibel.
Memperkenalkan 'kelompok uji'. Setelah Anda menyusun pengujian, Anda dapat meminta TestNG untuk menjalankan semua pengujian "front-end", atau pengujian "cepat", "lambat", "database", dll.
Mendukung metode pengujian dependen, pengujian paralel, pengujian beban, dan kegagalan parsial.
API plug-in yang fleksibel.
Dukungan untuk pengujian multi-thread.
TestNG adalah framework untuk Java, jadi persyaratan pertama adalah menginstal JDK di mesin Anda.
Persyaratan Sistem
JDK | 1.5 atau lebih tinggi. |
Penyimpanan | Tidak ada persyaratan minimum. |
Ruang Disk | Tidak ada persyaratan minimum. |
Sistem operasi | Tidak ada persyaratan minimum. |
Langkah 1 - Verifikasi Instalasi Java di Mesin Anda
Buka konsol dan jalankan perintah java berdasarkan sistem operasi yang telah Anda instal di sistem Anda.
OS | Tugas | Perintah |
---|---|---|
Windows | Buka Konsol Perintah | c: \> java -version |
Linux | Buka Terminal Perintah | $ java -version |
Mac | Buka Terminal | mesin: ~ joseph $ java -version |
Mari verifikasi output untuk semua sistem operasi -
OS | Keluaran |
---|---|
Windows | versi java "1.7.0_25" Java (TM) SE Runtime Environment (build 1.7.0_25-b15) Java HotSpot (TM) 64-Bit Server VM (build 23.25-b01, mode campuran) |
Linux | versi java "1.7.0_25" Java (TM) SE Runtime Environment (build 1.7.0_25-b15) Java HotSpot (TM) 64-Bit Server VM (build 23.25-b01, mode campuran) |
Mac | versi java "1.7.0_25" Java (TM) SE Runtime Environment (build 1.7.0_25-b15) Java HotSpot (TM) 64-Bit Server VM (build 23.25-b01, mode campuran) |
Jika Anda tidak memiliki Java, instal Java Software Development Kit (SDK) dari https://www.oracle.com/technetwork/java/javase/downloads/index.html. Kami mengasumsikan Java 1.7.0_25 sebagai versi yang diinstal untuk tutorial ini.
Langkah 2: Setel Lingkungan JAVA
Mengatur JAVA_HOMEvariabel lingkungan untuk menunjuk ke lokasi direktori dasar, tempat Java diinstal pada mesin Anda. Sebagai contoh,
OS | Keluaran |
---|---|
Windows | Setel variabel lingkungan JAVA_HOME ke C: \ Program Files \ Java \ jdk1.7.0_25. |
Linux | Ekspor JAVA_HOME = / usr / local / java-current. |
Mac | Ekspor JAVA_HOME = / Library / Java / Home. |
Tambahkan lokasi compiler Java ke System Path.
OS | Keluaran |
---|---|
Windows | Tambahkan string C: \ Program Files \ Java \ jdk1.7.0_25 \ bin di akhir variabel sistem, Path. |
Linux | Ekspor PATH =$PATH:$JAVA_HOME / bin / |
Mac | Tidak dibutuhkan |
Verifikasi Instalasi Java menggunakan perintah java -version seperti yang dijelaskan di atas.
Langkah 3: Unduh Arsip TestNG
Unduh versi terbaru file jar TestNG dari http://www.testng.org. Pada saat menulis tutorial ini, kami telah mengunduh testng-6.8.jar dan menyalinnya ke folder C: \> TestNG.
OS | Nama arsip |
---|---|
Windows | testng-6.8.jar |
Linux | testng-6.8.jar |
Mac | testng-6.8.jar |
Langkah 4: Atur Lingkungan TestNG
Mengatur TESTNG_HOMEvariabel lingkungan untuk menunjuk ke lokasi direktori dasar, tempat jar TestNG disimpan di komputer Anda. Tabel berikut menunjukkan cara menyetel variabel lingkungan di Windows, Linux, dan Mac, dengan asumsi kita telah menyimpan testng-6.8.jar di lokasi C: \> TestNG.
OS | Deskripsi |
---|---|
Windows | Setel variabel lingkungan TESTNG_HOME ke C: \ TESTNG. |
Linux | Ekspor TESTNG_HOME = / usr / local / TESTNG |
Mac | Ekspor TESTNG_HOME = / Library / TESTNG |
Langkah 5: Setel Variabel CLASSPATH
Mengatur CLASSPATH variabel lingkungan untuk menunjuk ke lokasi jar TestNG.
OS | Deskripsi |
---|---|
Windows | Setel variabel lingkungan CLASSPATH ke% CLASSPATH%;% TESTNG_HOME% \ testng-6.8.jar. |
Linux | Ekspor CLASSPATH =$CLASSPATH:$TESTNG_HOME / testng-6.8.jar. |
Mac | Ekspor CLASSPATH =$CLASSPATH:$TESTNG_HOME / testng-6.8.jar. |
Langkah 6: Uji Setup TestNG
Buat file kelas java bernama TestNGSimpleTest di C:\>TestNG_WORKSPACE.
import org.testng.annotations.Test;
import static org.testng.Assert.assertEquals;
public class TestNGSimpleTest {
@Test
public void testAdd() {
String str = "TestNG is working fine";
AssertEquals("TestNG is working fine", str);
}
}
TestNG dapat dipanggil dengan beberapa cara berbeda -
- Dengan file testng.xml.
- Dengan ANT.
- Dari baris perintah.
Mari kita panggil menggunakan file testng.xml. Buat file xml dengan nama testng.xml inC:\>TestNG_WORKSPACE untuk mengeksekusi kasus Uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "TestNGSimpleTest"/>
</classes>
</test>
</suite>
Langkah 7: Verifikasi Hasil
Kompilasi kelas menggunakan javac kompiler sebagai berikut -
C:\TestNG_WORKSPACE>javac TestNGSimpleTest.java
Sekarang, aktifkan testng.xml untuk melihat hasilnya -
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
Menulis tes di TestNG pada dasarnya melibatkan langkah-langkah berikut -
Tulis logika bisnis pengujian Anda dan masukkan anotasi TestNG dalam kode Anda.
Tambahkan informasi tentang pengujian Anda (misalnya nama kelas, grup yang ingin Anda jalankan, dll.) Di file testng.xml atau di build.xml.
Jalankan TestNG.
Di sini, kita akan melihat satu contoh lengkap pengujian TestNG menggunakan kelas POJO, kelas logika bisnis dan xml uji, yang akan dijalankan oleh TestNG.
Membuat EmployeeDetails.java di C:\>TestNG_WORKSPACE, yang merupakan kelas POJO.
public class EmployeeDetails {
private String name;
private double monthlySalary;
private int age;
// @return the name
public String getName() {
return name;
}
// @param name the name to set
public void setName(String name) {
this.name = name;
}
// @return the monthlySalary
public double getMonthlySalary() {
return monthlySalary;
}
// @param monthlySalary the monthlySalary to set
public void setMonthlySalary(double monthlySalary) {
this.monthlySalary = monthlySalary;
}
// @return the age
public int getAge() {
return age;
}
// @param age the age to set
public void setAge(int age) {
this.age = age;
}
}
EmployeeDetails kelas digunakan untuk -
- dapatkan / setel nilai nama karyawan.
- dapatkan / tentukan nilai gaji bulanan karyawan.
- dapatkan / tentukan nilai usia karyawan.
Buat EmpBusinessLogic.java di C:\>TestNG_WORKSPACE, yang berisi logika bisnis.
public class EmpBusinessLogic {
// Calculate the yearly salary of employee
public double calculateYearlySalary(EmployeeDetails employeeDetails) {
double yearlySalary = 0;
yearlySalary = employeeDetails.getMonthlySalary() * 12;
return yearlySalary;
}
// Calculate the appraisal amount of employee
public double calculateAppraisal(EmployeeDetails employeeDetails) {
double appraisal = 0;
if(employeeDetails.getMonthlySalary() < 10000) {
appraisal = 500;
} else {
appraisal = 1000;
}
return appraisal;
}
}
EmpBusinessLogic kelas digunakan untuk menghitung -
- gaji tahunan karyawan.
- jumlah penilaian karyawan.
Sekarang, mari buat kelas TestNG bernama TestEmployeeDetails.javadi C: \> TestNG_WORKSPACE. Kelas TestNG adalah kelas Java yang berisi setidaknya satu anotasi TestNG. Kelas ini berisi kasus uji untuk diuji. Tes TestNG dapat dikonfigurasi dengan anotasi @BeforeXXX dan @AfterXXX (kita akan melihatnya di bab TestNG - Prosedur Eksekusi ), yang memungkinkan untuk melakukan beberapa logika Java sebelum dan setelah titik tertentu.
import org.testng.Assert;
import org.testng.annotations.Test;
public class TestEmployeeDetails {
EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
EmployeeDetails employee = new EmployeeDetails();
@Test
public void testCalculateAppriasal() {
employee.setName("Rajeev");
employee.setAge(25);
employee.setMonthlySalary(8000);
double appraisal = empBusinessLogic.calculateAppraisal(employee);
Assert.assertEquals(500, appraisal, 0.0, "500");
}
// Test to check yearly salary
@Test
public void testCalculateYearlySalary() {
employee.setName("Rajeev");
employee.setAge(25);
employee.setMonthlySalary(8000);
double salary = empBusinessLogic.calculateYearlySalary(employee);
Assert.assertEquals(96000, salary, 0.0, "8000");
}
}
TestEmployeeDetails kelas digunakan untuk menguji metode EmpBusinessLogickelas. Itu melakukan hal berikut -
Menguji gaji tahunan karyawan.
Menguji jumlah penilaian karyawan.
Sebelum Anda dapat menjalankan pengujian, Anda harus mengkonfigurasi TestNG menggunakan file XML khusus, biasanya bernama testng.xml. Sintaks untuk file ini sangat sederhana, dan isinya seperti yang ditunjukkan di bawah ini. Buat file ini diC:\>TestNG_WORKSPACE.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "TestEmployeeDetails"/>
</classes>
</test>
</suite>
Rincian file di atas adalah sebagai berikut -
Sebuah suite diwakili oleh satu file XML. Ini bisa berisi satu atau lebih tes dan ditentukan oleh tag <suite>.
Tag <test> mewakili satu pengujian dan dapat berisi satu atau lebih kelas TestNG.
Tag <class> mewakili kelas TestNG. Ini adalah kelas Java yang berisi setidaknya satu anotasi TestNG. Ini dapat berisi satu atau lebih metode pengujian.
Kompilasi kelas kasus uji menggunakan javac.
C:\TestNG_WORKSPACE>javac EmployeeDetails.java EmpBusinessLogic.java TestEmployeeDetails.java
Sekarang TestNG dengan perintah berikut -
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Jika semua telah dilakukan dengan benar, Anda akan melihat hasil pengujian Anda di konsol. Selanjutnya, TestNG membuat laporan HTML yang sangat bagus di folder bernamatest-outputyang dibuat secara otomatis di direktori saat ini. Jika Anda membukanya dan memuat index.html, Anda akan melihat halaman yang mirip dengan gambar di bawah ini -
Cara tradisional untuk menunjukkan metode pengujian di JUnit 3 adalah dengan mengawali nama mereka dengan test. Ini adalah metode yang sangat efektif untuk menandai metode tertentu di kelas sebagai memiliki arti khusus, tetapi penamaan tidak berskala dengan baik (bagaimana jika kita ingin menambahkan lebih banyak tag untuk kerangka kerja yang berbeda?) Dan agak tidak fleksibel (bagaimana jika kita ingin meneruskan parameter tambahan ke framework pengujian?).
Anotasi secara resmi ditambahkan ke bahasa Java di JDK 5, dan TestNG membuat pilihan untuk menggunakan anotasi untuk memberi anotasi pada kelas pengujian.
Berikut adalah daftar anotasi yang didukung TestNG -
Sr.No. | Anotasi & Deskripsi |
---|---|
1 | @BeforeSuite Metode beranotasi hanya akan dijalankan sekali sebelum semua pengujian dalam rangkaian ini dijalankan. |
2 | @AfterSuite Metode beranotasi hanya akan dijalankan sekali setelah semua pengujian di suite ini dijalankan. |
3 | @BeforeClass Metode beranotasi hanya akan dijalankan sekali sebelum metode pengujian pertama di kelas saat ini dipanggil. |
4 | @AfterClass Metode beranotasi hanya akan dijalankan sekali setelah semua metode pengujian di kelas saat ini dijalankan. |
5 | @BeforeTest Metode beranotasi akan dijalankan sebelum metode pengujian apa pun yang termasuk dalam kelas di dalam tag <test> dijalankan. |
6 | @AfterTest Metode beranotasi akan dijalankan setelah semua metode pengujian milik kelas di dalam tag <test> telah dijalankan. |
7 | @BeforeGroups Daftar grup yang akan dijalankan metode konfigurasi ini sebelumnya. Metode ini dijamin akan berjalan segera sebelum metode pengujian pertama yang termasuk dalam salah satu grup ini dipanggil. |
8 | @AfterGroups Daftar grup yang akan dijalankan metode konfigurasi ini. Metode ini dijamin akan berjalan segera setelah metode pengujian terakhir yang termasuk dalam salah satu grup ini dipanggil. |
9 | @BeforeMethod Metode beranotasi akan dijalankan sebelum setiap metode pengujian. |
10 | @AfterMethod Metode beranotasi akan dijalankan setelah setiap metode pengujian. |
11 | @DataProvider Menandai metode sebagai menyediakan data untuk metode pengujian. Metode yang dianotasi harus mengembalikan Objek [] [], di mana setiap Objek [] dapat diberi daftar parameter dari metode pengujian. Metode @Test yang ingin menerima data dari DataProvider ini perlu menggunakan nama dataProvider yang sama dengan nama anotasi ini. |
12 | @Factory
Menandai metode sebagai pabrik yang mengembalikan objek yang akan digunakan oleh TestNG sebagai kelas Tes. Metode ini harus mengembalikan Objek []. |
13 | @Listeners Mendefinisikan pendengar di kelas pengujian. |
14 | @Parameters Menjelaskan cara meneruskan parameter ke metode @Test. |
15 | @Test Menandai kelas atau metode sebagai bagian dari tes. |
Manfaat Menggunakan Anotasi
Berikut adalah beberapa keuntungan menggunakan anotasi -
TestNG mengidentifikasi metode yang diminati, dengan mencari anotasi. Karenanya, nama metode tidak terbatas pada pola atau format apa pun.
Kami dapat memberikan parameter tambahan ke anotasi.
Anotasi diketik dengan kuat, jadi kompilator akan segera menandai kesalahan apa pun.
Kelas pengujian tidak perlu lagi memperluas apa pun (seperti TestCase, untuk JUnit 3).
Bab ini menjelaskan prosedur eksekusi metode di TestNG. Ini menjelaskan urutan metode yang dipanggil. Berikut adalah prosedur eksekusi metode API pengujian TestNG dengan sebuah contoh.
Buat nama file kelas java TestngAnnotation.java di C:\>TestNG_WORKSPACE untuk menguji anotasi.
import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeSuite;
import org.testng.annotations.AfterSuite;
public class TestngAnnotation {
// test case 1
@Test
public void testCase1() {
System.out.println("in test case 1");
}
// test case 2
@Test
public void testCase2() {
System.out.println("in test case 2");
}
@BeforeMethod
public void beforeMethod() {
System.out.println("in beforeMethod");
}
@AfterMethod
public void afterMethod() {
System.out.println("in afterMethod");
}
@BeforeClass
public void beforeClass() {
System.out.println("in beforeClass");
}
@AfterClass
public void afterClass() {
System.out.println("in afterClass");
}
@BeforeTest
public void beforeTest() {
System.out.println("in beforeTest");
}
@AfterTest
public void afterTest() {
System.out.println("in afterTest");
}
@BeforeSuite
public void beforeSuite() {
System.out.println("in beforeSuite");
}
@AfterSuite
public void afterSuite() {
System.out.println("in afterSuite");
}
}
Selanjutnya, mari buat file testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan anotasi.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "TestngAnnotation"/>
</classes>
</test>
</suite>
Kompilasi kelas Test case menggunakan javac.
C:\TestNG_WORKSPACE>javac TestngAnnotation.java
Sekarang, jalankan testng.xml, yang akan menjalankan kasus uji yang ditentukan di kelas Kasus Uji yang disediakan.
C:\TestNG_WORKSPACE>java org.testng.TestNG testng.xml
Verifikasi hasilnya.
in beforeSuite
in beforeTest
in beforeClass
in beforeMethod
in test case 1
in afterMethod
in beforeMethod
in test case 2
in afterMethod
in afterClass
in afterTest
in afterSuite
===============================================
Suite
Total tests run: 2, Failures: 0, Skips: 0
===============================================
Berdasarkan hasil di atas, prosedur eksekusinya adalah sebagai berikut -
Pertama-tama, metode beforeSuite () dijalankan hanya sekali.
Terakhir, metode afterSuite () hanya dijalankan satu kali.
Bahkan metode beforeTest (), beforeClass (), afterClass (), dan afterTest () hanya dijalankan sekali.
beforeMethod () metode dijalankan untuk setiap kasus uji tetapi sebelum menjalankan kasus uji.
metode afterMethod () dijalankan untuk setiap kasus pengujian tetapi setelah menjalankan kasus pengujian.
Di antara beforeMethod () dan afterMethod (), setiap kasus pengujian akan dijalankan.
Kasus uji dieksekusi menggunakan TestNGkelas. Kelas ini adalah titik masuk utama untuk menjalankan pengujian dalam kerangka kerja TestNG. Pengguna dapat membuat objek TestNG mereka sendiri dan memanggilnya dengan berbagai cara seperti -
Di testng.xml yang sudah ada.
Di testng.xml sintetis, seluruhnya dibuat dari Java.
Dengan mengatur kelas tes secara langsung.
Anda juga dapat menentukan grup mana yang akan disertakan atau dikecualikan, menetapkan parameter, dll. Parameter baris perintah adalah -
-d outputdir: tentukan direktori keluaran.
-testclass class_name: menentukan satu atau beberapa nama kelas.
-testjar jar_name: menentukan toples yang berisi tes.
src1 bersumber; src2:; daftar terpisah dari direktori sumber (digunakan hanya jika penjelasan javadoc digunakan).
-target
-groups
-testrunfactory
-listener
Kami akan membuat objek TestNG testng.xml yang ada dalam contoh kami di bawah ini.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\>TestNG_WORKSPACE.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya, SampleTest.java.
Tambahkan metode pengujian testPrintMessage () ke kelas pengujian Anda.
Tambahkan Annotation @Test ke metode testPrintMessage ().
Implementasikan kondisi pengujian dan periksa kondisi menggunakan assertEquals API dari TestNG.
Buat file kelas java bernama SampleTest.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class SampleTest {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
Assert.assertEquals(message, messageUtil.printMessage());
}
}
Buat testng.xml
Selanjutnya, mari buat file testng.xml di C:\>TestNG_WORKSPACE, untuk menjalankan kasus uji. File ini merekam seluruh pengujian Anda dalam XML. File ini memudahkan untuk mendeskripsikan semua rangkaian pengujian Anda dan parameternya dalam satu file, yang dapat Anda periksa di repositori kode atau email ke rekan kerja. Ini juga memudahkan untuk mengekstrak subset pengujian Anda atau membagi beberapa konfigurasi waktu proses (misalnya, testngdatabase.xml hanya akan menjalankan pengujian yang menjalankan database Anda).
<?xml version = "1.0" encoding = "UTF-8"?>
<suite name = "Sample test Suite">
<test name = "Sample test">
<classes>
<class name = "SampleTest" />
</classes>
</test>
</suite>
Kumpulkan kasus uji menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java SampleTest.java
Sekarang, jalankan testng.xml, yang akan menjalankan kasus uji yang ditentukan dalam tag <test>.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
Hello World
===============================================
Sample test Suite
Total tests run: 1, Failures: 0, Skips: 0
===============================================
SEBUAH test suiteadalah kumpulan kasus uji yang dimaksudkan untuk menguji perilaku atau sekumpulan perilaku program perangkat lunak. Di TestNG, kami tidak dapat menentukan suite dalam pengujian kode sumber, tetapi diwakili oleh satu file XML, karena suite adalah fitur eksekusi. Ini juga memungkinkan konfigurasi tes yang fleksibel untuk dijalankan. Sebuah suite dapat berisi satu atau lebih tes dan ditentukan oleh tag <suite>.
<suite> adalah tag root testng.xml Anda. Ini menjelaskan rangkaian pengujian, yang pada gilirannya terdiri dari beberapa bagian <test>.
Tabel berikut mencantumkan semua atribut hukum yang diterima <suite>.
Sr.No. | Atribut & Deskripsi |
---|---|
1 | name Nama suite ini. Ini adalah sebuahmandatory atribut. |
2 | verbose Level atau verbositas untuk proses ini. |
3 | parallel Apakah TestNG harus menjalankan utas yang berbeda untuk menjalankan rangkaian ini. |
4 | thread-count Jumlah utas yang akan digunakan, jika mode paralel diaktifkan (jika tidak, diabaikan). |
5 | annotations Jenis anotasi yang Anda gunakan dalam pengujian Anda. |
6 | time-out Batas waktu default yang akan digunakan di semua metode pengujian yang ditemukan dalam pengujian ini. |
Dalam bab ini, kami akan menunjukkan kepada Anda contoh yang memiliki dua kelas pengujian, Test1 & Test2, untuk dijalankan bersama menggunakan Test Suite.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\>JUNIT_WORKSPACE.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
// Constructor
// @param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat file kelas java bernama Test1.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class Test1 {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
Assert.assertEquals(message, messageUtil.printMessage());
}
}
Buat file kelas java bernama Test2.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class Test2 {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message,messageUtil.salutationMessage());
}
}
Sekarang, mari tulis testng.xml C:\>TestNG_WORKSPACE, yang akan berisi tag <suite> sebagai berikut -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "exampletest1">
<classes>
<class name = "Test1" />
</classes>
</test>
<test name = "exampletest2">
<classes>
<class name = "Test2" />
</classes>
</test>
</suite>
Suite1 termasuk exampletest1 dan exampletest2.
Kompilasi semua kelas java menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java Test1.java Test2.java
Sekarang, jalankan testng.xml, yang akan menjalankan kasus uji yang ditentukan di kelas Kasus Uji yang disediakan.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 2, Failures: 0, Skips: 0
===============================================
Anda juga dapat memeriksa folder keluaran uji . Di bawah folder Suite1 , Anda dapat melihat dua file html yang dibuat, exampletest1.html dan exampletest2.html, yang akan terlihat sebagai berikut -
Terkadang, kode kita belum siap dan kasus uji yang ditulis untuk menguji metode / kode tersebut gagal. Dalam kasus seperti itu, anotasi@Test(enabled = false) membantu untuk menonaktifkan kasus uji ini.
Jika metode pengujian dianotasi dengan @Test (enabled = false) , maka kasus pengujian yang belum siap untuk diuji akan dilewati.
Sekarang, mari kita lihat @Test (enabled = false) beraksi.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\>TestNG_WORKSPACE.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya, IgnoreTest.java.
Tambahkan metode pengujian, testPrintMessage (), dan, testSalutationMessage (), ke kelas pengujian Anda.
Tambahkan Annotation @Test (enabled = false) ke metode testPrintMessage ().
Buat file kelas java bernama IgnoreTest.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class IgnoreTest {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test(enabled = false)
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = "Manisha";
Assert.assertEquals(message, messageUtil.printMessage());
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message, messageUtil.salutationMessage());
}
}
Buat testng.xml
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "IgnoreTest" />
</classes>
</test>
</suite>
Kompilasi kelas MessageUtil dan uji kasus menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java IgnoreTest.java
Sekarang, jalankan testng.xml, yang tidak akan menjalankan testPrintMessage () kasus uji yang ditentukan dalam asalkan kelas Kasus Uji.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya. test case testPrintMessage () tidak diuji.
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
Anda juga dapat mengabaikan sekelompok pengujian, yang akan dibahas di bab berikutnya.
Uji grup adalah fitur inovatif baru di TestNG, yang tidak ada dalam kerangka JUnit. Ini memungkinkan Anda untuk mengirimkan metode ke dalam porsi yang tepat dan melakukan pengelompokan metode pengujian yang canggih.
Anda tidak hanya dapat mendeklarasikan metode yang dimiliki grup, tetapi Anda juga dapat menentukan grup yang berisi grup lain. Kemudian, TestNG dapat dipanggil dan diminta untuk menyertakan kumpulan grup tertentu (atau ekspresi reguler), sambil mengecualikan kumpulan lain.
Pengujian grup memberikan fleksibilitas maksimum dalam cara Anda mempartisi pengujian, dan tidak mengharuskan Anda mengompilasi ulang apa pun jika Anda ingin menjalankan dua rangkaian pengujian yang berbeda secara berurutan.
Grup ditentukan dalam file testng.xml Anda menggunakan tag <groups>. Itu dapat ditemukan di bawah tag <test> atau <suite>. Grup yang ditentukan dalam tag <suite> berlaku untuk semua tag <test> di bawahnya.
Sekarang, mari kita ambil contoh untuk melihat cara kerja pengujian kelompok.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\> TestNG_WORKSPACE.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
// Constructor
// @param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
// add "tutorialspoint" to the message
public String salutationMessage() {
message = "tutorialspoint" + message;
System.out.println(message);
return message;
}
// add "www." to the message
public String exitMessage() {
message = "www." + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya, GroupTestExample.java.
Tambahkan metode pengujian, testPrintMessage () dan testSalutationMessage (), ke kelas pengujian Anda.
Kelompokkan metode pengujian dalam dua kategori -
Check-in tests (checkintest)- Tes ini harus dijalankan sebelum Anda mengirimkan kode baru. Mereka biasanya harus cepat dan hanya memastikan tidak ada fungsi dasar yang rusak.
Functional tests (functest) - Tes ini harus mencakup semua fungsi perangkat lunak Anda dan dijalankan setidaknya sekali sehari, meskipun idealnya Anda ingin menjalankannya terus menerus.
Buat file kelas java bernama GroupTestExample.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class GroupTestExample {
String message = ".com";
MessageUtil messageUtil = new MessageUtil(message);
@Test(groups = { "functest", "checkintest" })
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = ".com";
Assert.assertEquals(message, messageUtil.printMessage());
}
@Test(groups = { "checkintest" })
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "tutorialspoint" + ".com";
Assert.assertEquals(message, messageUtil.salutationMessage());
}
@Test(groups = { "functest" })
public void testingExitMessage() {
System.out.println("Inside testExitMessage()");
message = "www." + "tutorialspoint"+".com";
Assert.assertEquals(message, messageUtil.exitMessage());
}
}
Buat testng.xml
Buat testng.xml di C:\> TestNG_WORKSPACE, untuk menjalankan kasus uji. Di sini, kami hanya akan menjalankan tes tersebut, yang termasuk dalam grup functest .
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<groups>
<run>
<include name = "functest" />
</run>
</groups>
<classes>
<class name = "GroupTestExample" />
</classes>
</test>
</suite>
Kompilasi MessageUtil, Uji kelas kasus menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java GroupTestExample.java
Sekarang, jalankan testng.xml, yang hanya akan menjalankan metode testPrintMessage (), karena itu milik grup functest .
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya. Hanya metode testPrintMessage () yang dijalankan.
Inside testPrintMessage()
.com
Inside testExitMessage()
www..com
===============================================
Suite1
Total tests run: 2, Failures: 1, Skips: 0
===============================================
Kelompok Grup
Grup juga dapat menyertakan grup lain. Kelompok-kelompok ini disebutMetaGroups. Sebagai contoh, Anda mungkin ingin mendefinisikan sebuah kelompok semua yang mencakup checkintest dan functest . Mari kita ubah file testng.xml kita sebagai berikut -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<groups>
<define name = "all">
<include name = "functest"/>
<include name = "checkintest"/>
</define>
<run>
<include name = "all"/>
</run>
</groups>
<classes>
<class name = "GroupTestExample" />
</classes>
</test>
</suite>
Menjalankan testng.xml di atas akan menjalankan ketiga tes dan akan memberi Anda hasil berikut -
Inside testPrintMessage()
.com
Inside testSalutationMessage()
tutorialspoint.com
Inside testExitMessage()
www.tutorialspoint.com
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================
Grup Pengecualian
Anda dapat mengabaikan grup dengan menggunakan tag <exclude> seperti yang ditunjukkan di bawah ini -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<groups>
<define name = "all">
<exclude name = "functest"/>
<include name = "checkintest"/>
</define>
<run>
<include name = "all"/>
</run>
</groups>
<classes>
<class name = "GroupTestExample" />
</classes>
</test>
</suite>
TestNG menyediakan opsi untuk melacak penanganan pengecualian kode. Anda dapat menguji apakah suatu kode menampilkan pengecualian yang diinginkan atau tidak. Di siniexpectedExceptionsparameter digunakan bersama dengan anotasi @Test. Sekarang mari kita lihat@Test(expectedExceptions) sedang beraksi.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\> TestNG_WORKSPACE. Tambahkan kondisi kesalahan di dalam metode printMessage ().
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public void printMessage() {
System.out.println(message);
int a =0;
int b = 1/a;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya, ExpectedExceptionTest.java.
Tambahkan pengecualian yang diharapkan ArithmeticException ke kasus pengujian testPrintMessage ().
Buat file kelas java bernama ExpectedExceptionTest.java di C:\> TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class ExpectedExceptionTest {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test(expectedExceptions = ArithmeticException.class)
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
messageUtil.printMessage();
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message,messageUtil.salutationMessage());
}
}
Buat Test Runner
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "ExpectedExceptionTest" />
</classes>
</test>
</suite>
Kompilasi MessageUtil, Uji kelas kasus menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java TestJunit.java
Sekarang, jalankan Test Runner, yang akan menjalankan kasus pengujian yang ditentukan di kelas Test Case yang disediakan.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya. test case testPrintMessage () akan dilalui.
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 2, Failures: 0, Skips: 0
===============================================
Terkadang, Anda mungkin perlu menjalankan metode dalam kasus pengujian dalam urutan tertentu, atau Anda mungkin ingin berbagi beberapa data dan status antar metode. Jenis ketergantungan ini didukung oleh TestNG, karena mendukung deklarasi ketergantungan eksplisit antara metode pengujian.
TestNG memungkinkan Anda menentukan dependensi baik dengan -
Menggunakan atribut dependOnMethods dalam anotasi @Test , ATAU.
Menggunakan atribut dependOnGroups dalam anotasi @Test .
Contoh Menggunakan dependOnMethods
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\>TestNG_WORKSPACE.
public class MessageUtil {
private String message;
// Constructor
// @param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya DependencyTestUsingAnnotation.java.
Tambahkan metode pengujian, testPrintMessage () dan testSalutationMessage (), dan initEnvironmentTest (), ke kelas pengujian Anda.
Tambahkan atribut dependsOnMethods = {"initEnvironmentTest"} ke anotasi @Test testSalutationMessage() metode.
Buat nama file kelas java DependencyTestUsingAnnotation.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class DependencyTestUsingAnnotation {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = "Manisha";
Assert.assertEquals(message, messageUtil.printMessage());
}
@Test(dependsOnMethods = { "initEnvironmentTest" })
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message, messageUtil.salutationMessage());
}
@Test
public void initEnvironmentTest() {
System.out.println("This is initEnvironmentTest");
}
}
Buat testng.xml
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "DependencyTestUsingAnnotation" />
</classes>
</test>
</suite>
Kompilasi MessageUtil, Uji kelas kasus menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java
Sekarang, jalankan testng.xml, yang akan menjalankan metode testSalutationMessage () hanya setelah eksekusi metode initEnvironmentTest ().
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================
Contoh Menggunakan dependOnGroups
Anda juga dapat memiliki metode yang bergantung pada seluruh grup. Mari kita punya contoh untuk menunjukkan ini.
Buat Kelas
Buat kelas java untuk diuji, misalnya, MessageUtil.java di C:\>TestNG_WORKSPACE.
public class MessageUtil {
private String message;
// Constructor
// @param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya DependencyTestUsingAnnotation.java.
Tambahkan metode pengujian, testPrintMessage () testSalutationMessage (), dan initEnvironmentTest () ke kelas pengujian Anda, dan tambahkan ke grup "init".
Tambahkan atribut dependsOnMethods = {"init.*"} ke anotasi @Test testSalutationMessage() metode.
Buat file kelas java bernama DependencyTestUsingAnnotation.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class DependencyTestUsingAnnotation {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test(groups = { "init" })
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
message = "Manisha";
Assert.assertEquals(message, messageUtil.printMessage());
}
@Test(dependsOnGroups = { "init.*" })
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message, messageUtil.salutationMessage());
}
@Test(groups = { "init" })
public void initEnvironmentTest() {
System.out.println("This is initEnvironmentTest");
}
}
Dalam contoh ini, testSalutationMessage () dideklarasikan sebagai bergantung pada grup apa pun, cocok dengan ekspresi reguler "init. *", Yang menjamin bahwa metode testPrintMessage () dan initEnvironmentTest () akan selalu dipanggil sebelum testSalutationMessage ().
Jika metode bergantung pada gagal, dan Anda memiliki ketergantungan keras padanya (selaluRun = false, yang merupakan default), metode yang bergantung padanya tidak ditandai sebagai GAGAL tetapi sebagai SKIP. Metode yang dilewati akan dilaporkan seperti itu di laporan akhir (dengan warna bukan Merah atau Hijau di HTML), yang penting karena metode yang dilewati belum tentu gagal.
Buat testng.xml
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "DependencyTestUsingAnnotation" />
</classes>
</test>
</suite>
Kompilasi MessageUtil, Uji kelas kasus menggunakan javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java
Sekarang, jalankan testng.xml, yang akan menjalankan metode testSalutationMessage () hanya setelah eksekusi metode initEnvironmentTest () .
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================
dependOnGroups Vs dependOnMethods
Saat menggunakan grup, kami tidak lagi terkena masalah refactoring. Selama kami tidak mengubah atribut dependOnGroups atau grup, pengujian kami akan terus berjalan dengan pengaturan dependensi yang tepat.
Kapan pun metode baru perlu ditambahkan ke grafik ketergantungan, yang perlu kita lakukan hanyalah meletakkannya di grup yang tepat dan memastikannya bergantung pada grup yang benar. Kami tidak perlu mengubah metode lain.
Fitur menarik lainnya yang tersedia di TestNG adalah parametric testing. Dalam kebanyakan kasus, Anda akan menemukan skenario di mana logika bisnis membutuhkan jumlah pengujian yang sangat bervariasi.Parameterized tests memungkinkan pengembang untuk menjalankan pengujian yang sama berulang kali menggunakan nilai yang berbeda.
TestNG memungkinkan Anda meneruskan parameter langsung ke metode pengujian Anda dengan dua cara berbeda -
- Dengan testng.xml
- Dengan Penyedia Data
Meneruskan Parameter dengan testng.xml
Dengan teknik ini, Anda menentukan parameter sederhana di file testng.xml dan kemudian mereferensikan parameter tersebut di file sumber. Mari kita punya contoh untuk mendemonstrasikan bagaimana menggunakan teknik ini untuk melewatkan parameter.
Buat Kelas Kasus Uji
Buat kelas pengujian java, misalnya, ParameterizedTest1.java.
Tambahkan metode pengujian parameterTest () ke kelas pengujian Anda. Metode ini mengambil string sebagai parameter masukan.
Tambahkan anotasi @Parameters ("myName") ke metode ini. Parameter akan diberi nilai dari testng.xml, yang akan kita lihat di langkah berikutnya.
Buat file kelas java bernama ParameterizedTest1.java di C:\>TestNG_WORKSPACE.
import org.testng.annotations.Parameters;
import org.testng.annotations.Test;
public class ParameterizedTest1 {
@Test
@Parameters("myName")
public void parameterTest(String myName) {
System.out.println("Parameterized value is : " + myName);
}
}
Buat testng.xml
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<parameter name = "myName" value="manisha"/>
<classes>
<class name = "ParameterizedTest1" />
</classes>
</test>
</suite>
Kami juga dapat menentukan parameter di tingkat <suite>. Misalkan kita telah mendefinisikan myName pada level <suite> dan <test>. Dalam kasus seperti itu, aturan pelingkupan reguler berlaku. Artinya, setiap kelas di dalam tag <test> akan melihat nilai parameter yang ditentukan di <test>, sedangkan kelas di file testng.xml lainnya akan melihat nilai yang ditentukan di <suite>.
Kompilasi kelas kasus uji menggunakan javac.
C:\TestNG_WORKSPACE>javac ParameterizedTest1.java
Sekarang, jalankan testng.xml, yang akan menjalankan metode parameterTest . TestNG akan mencoba menemukan parameter bernama myName terlebih dahulu di tag <test>, dan kemudian, jika tidak dapat menemukannya, ia akan mencari di tag <suit> yang membungkusnya.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
Parameterized value is : manisha
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
TestNG akan secara otomatis mencoba mengonversi nilai yang ditentukan di testng.xml ke jenis parameter Anda. Berikut adalah jenis yang didukung -
- String
- int/Integer
- boolean/Boolean
- byte/Byte
- char/Character
- double/Double
- float/Float
- long/Long
- short/Short
Meneruskan Parameter dengan Penyedia Data
Saat Anda perlu meneruskan parameter kompleks atau parameter yang perlu dibuat dari Java (objek kompleks, objek yang dibaca dari file properti atau database, dll.), Parameter dapat diteruskan menggunakan Dataproviders.
Penyedia Data adalah metode yang dianotasi @DataProvider. Anotasi ini hanya memiliki satu atribut string: namanya. Jika nama tidak diberikan, nama penyedia data secara otomatis default ke nama metode. Penyedia data mengembalikan larik objek.
Contoh berikut menunjukkan cara menggunakan penyedia data. Contoh pertama adalah tentang @DataProvider yang menggunakan Vector, String, atau Integer sebagai parameter, dan contoh kedua adalah tentang @DataProvider yang menggunakan objek sebagai parameter.
Contoh 1
Di sini, @DataProvider meneruskan Integer dan Boolean sebagai parameter.
Create Java class
Buat kelas java bernama PrimeNumberChecker.java. Kelas ini memeriksa apakah bilangan tersebut adalah bilangan prima. Buat kelas ini diC:\>TestNG_WORKSPACE.
public class PrimeNumberChecker {
public Boolean validate(final Integer primeNumber) {
for (int i = 2; i < (primeNumber / 2); i++) {
if (primeNumber % i == 0) {
return false;
}
}
return true;
}
}
Create Test Case Class
Buat kelas pengujian java, misalnya, ParamTestWithDataProvider1.java.
Tentukan metode primeNumbers (), yang didefinisikan sebagai penyedia Data menggunakan anotasi. Metode ini mengembalikan larik objek.
Tambahkan metode pengujian testPrimeNumberChecker () ke kelas pengujian Anda. Metode ini menggunakan Integer dan Boolean sebagai parameter masukan. Metode ini memvalidasi jika parameter yang dilewatkan adalah bilangan prima.
Tambahkan anotasi @Test (dataProvider = "test1") ke metode ini. Atribut dataProvider dipetakan ke "test1".
Buat file kelas java bernama ParamTestWithDataProvider1.java di C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider1 {
private PrimeNumberChecker primeNumberChecker;
@BeforeMethod
public void initialize() {
primeNumberChecker = new PrimeNumberChecker();
}
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] {{2, true}, {6, false}, {19, true}, {22, false}, {23, true}};
}
// This test will run 4 times since we have 5 parameters defined
@Test(dataProvider = "test1")
public void testPrimeNumberChecker(Integer inputNumber, Boolean expectedResult) {
System.out.println(inputNumber + " " + expectedResult);
Assert.assertEquals(expectedResult, primeNumberChecker.validate(inputNumber));
}
}
Create testng.xml
Buat testng.xml C:\>TestNG_WORKSPACE untuk mengeksekusi kasus Uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "ParamTestWithDataProvider1" />
</classes>
</test>
</suite>
Kompilasi kelas Test case menggunakan javac.
C:\TestNG_WORKSPACE>.javac ParamTestWithDataProvider1.java PrimeNumberChecker.java
Sekarang, jalankan testng.xml.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
2 true
6 false
19 true
22 false
23 true
===============================================
Suite1
Total tests run: 5, Failures: 0, Skips: 0
===============================================
Contoh 2
Di sini, @DataProvider meneruskan Objek sebagai parameter.
Create Java class
Buat kelas java Bean.java, yang merupakan objek sederhana dengan metode get / set, di C:\>TestNG_WORKSPACE.
public class Bean {
private String val;
private int i;
public Bean(String val, int i) {
this.val = val;
this.i = i;
}
public String getVal() {
return val;
}
public void setVal(String val) {
this.val = val;
}
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
}
Create Test Case Class
Buat kelas pengujian java, misalnya, ParamTestWithDataProvider2.java.
Tentukan metode primeNumbers (), yang didefinisikan sebagai penyedia data menggunakan anotasi. Metode ini mengembalikan larik objek.
Tambahkan metode pengujian testMethod () ke kelas pengujian Anda. Metode ini mengambil objek kacang sebagai parameter.
Tambahkan anotasi @Test (dataProvider = "test1") ke metode ini. Atribut dataProvider dipetakan ke "test1".
Buat file kelas java bernama ParamTestWithDataProvider2.java di C:\>TestNG_WORKSPACE.
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider2 {
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] { { new Bean("hi I am the bean", 111) } };
}
@Test(dataProvider = "test1")
public void testMethod(Bean myBean) {
System.out.println(myBean.getVal() + " " + myBean.getI());
}
}
Create testng.xml
Buat testng.xml di C:\>TestNG_WORKSPACE untuk menjalankan kasus uji.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "ParamTestWithDataProvider2" />
</classes>
</test>
</suite>
Kompilasi kelas kasus uji menggunakan javac.
C:\TestNG_WORKSPACE>javac ParamTestWithDataProvider2.java Bean.java
Sekarang, jalankan testng.xml.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Verifikasi hasilnya.
hi I am the bean 111
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
Sekarang setelah Anda memahami TestNG dan berbagai pengujiannya, Anda harus khawatir sekarang tentang cara memfaktorkan ulang kode JUnit Anda yang ada. Tidak perlu khawatir, karena TestNG menyediakan cara untuk beralih dari JUnit ke TestNG sesuai keinginan Anda. Anda dapat menjalankan kasus uji JUnit yang ada menggunakan TestNG.
TestNG dapat secara otomatis mengenali dan menjalankan pengujian JUnit, sehingga Anda dapat menggunakan TestNG sebagai runner untuk semua pengujian yang ada dan menulis pengujian baru menggunakan TestNG. Yang harus Anda lakukan adalah meletakkan pustaka JUnit di jalur kelas TestNG, sehingga dapat menemukan dan menggunakan kelas JUnit, mengubah runner pengujian Anda dari JUnit ke TestNG di Ant, lalu menjalankan TestNG dalam mode "campuran". Dengan cara ini, Anda dapat memiliki semua pengujian Anda dalam proyek yang sama, bahkan dalam paket yang sama, dan mulai menggunakan TestNG. Pendekatan ini juga memungkinkan Anda untuk mengubah pengujian JUnit yang ada ke TestNG secara bertahap.
Mari kita memiliki contoh untuk menunjukkan kemampuan TestNG yang luar biasa ini.
Buat Kelas Kasus Uji JUnit
Buat kelas java, yang merupakan kelas pengujian JUnit, TestJunit.java di C:\>TestNG_WORKSPACE.
import org.junit.Test;
import static org.testng.AssertJUnit.assertEquals;
public class TestJunit {
@Test
public void testAdd() {
String str = "Junit testing using TestNG";
AssertEquals("Junit testing using TestNG",str);
}
}
Sekarang, mari tulis testng.xml C:\>TestNG_WORKSPACE, yang akan berisi tag <suite> sebagai berikut -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name = "Converted JUnit suite" >
<test name = "JUnitTests" junit="true">
<classes>
<class name = "TestJunit" />
</classes>
</test>
</suite>
Untuk menjalankan kasus pengujian JUnit, tentukan properti junit = "true" seperti pada xml di atas. Kelas kasus uji JUnit TestJunit didefinisikan dalam nama kelas.
Untuk JUnit 4, TestNG akan menggunakan runner org.junit.runner.JUnitCore untuk menjalankan pengujian Anda.
Kompilasi semua kelas java menggunakan javac.
C:\TestNG_WORKSPACE>javac TestJunit.java
Sekarang, jalankan testng.xml, yang akan menjalankan kasus uji JUnit sebagai TestNG.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE:C:\TestNG_WORKSPACE\lib\junit-4.11.jar" org.testng.TestNG testng.xml
Di sini, kami telah menempatkan junit-4.11.jar di bawah C: \ TestNG_WORKSPACE \ lib \ junit-4.11.jar.
Verifikasi hasilnya.
===============================================
Converted JUnit suite
Total tests run: 1, Failures: 0, Skips: 0
===============================================
Pelaporan adalah bagian terpenting dari setiap eksekusi uji, karena membantu pengguna memahami hasil eksekusi uji, titik kegagalan, dan alasan kegagalan. Logging, di sisi lain, penting untuk mengawasi aliran eksekusi atau untuk debugging jika terjadi kegagalan.
TestNG, secara default, menghasilkan jenis laporan yang berbeda untuk eksekusi pengujiannya. Ini termasuk HTML dan keluaran laporan XML. TestNG juga memungkinkan penggunanya untuk menulis reporter mereka sendiri dan menggunakannya dengan TestNG. Ada juga opsi untuk menulis logger Anda sendiri, yang diberi tahu saat runtime oleh TestNG.
Ada dua cara untuk menghasilkan laporan dengan TestNG -
Listeners- Untuk mengimplementasikan kelas pendengar, kelas tersebut harus mengimplementasikan antarmuka org.testng.ITestListener . Kelas-kelas ini diberi tahu saat runtime oleh TestNG ketika pengujian dimulai, selesai, gagal, dilewati, atau lulus.
Reporters- Untuk mengimplementasikan kelas pelaporan, kelas tersebut harus mengimplementasikan antarmuka org.testng.IReporter . Kelas-kelas ini dipanggil ketika seluruh rangkaian berakhir. Objek yang berisi informasi dari keseluruhan pengujian yang dijalankan diteruskan ke kelas ini saat dipanggil.
Dalam bab ini, kami akan memiliki empat contoh berbeda untuk menunjukkan empat kasus pelaporan dan pencatatan yang berbeda -
Sr.No. | Kasus & Contoh |
---|---|
1 | Pencatatan Kustom Contoh ini menggambarkan bagaimana menulis logger Anda sendiri. |
2 | Reporter Kustom Contoh ini menggambarkan bagaimana menulis reporter Anda sendiri. |
3 | Laporan HTML dan XML Contoh ini menggambarkan laporan HTML dan XML default yang dihasilkan oleh TestNG. |
4 | Laporan JUnit Contoh ini menggambarkan bagaimana menghasilkan laporan JUnit dari laporan TestNG. |
Dalam bab ini, kami akan mendemonstrasikan cara menjalankan TestNG menggunakan ANT. Mari ikuti langkah-langkah yang diberikan di bawah ini -
Langkah 1: Unduh Apache Ant
Unduh Apache Ant versi terbaru
OS | Nama Arsip |
---|---|
Windows | apache-ant-1.8.4-bin.zip |
Linux | apache-ant-1.8.4-bin.tar.gz |
Mac | apache-ant-1.8.4-bin.tar.gz |
Langkah 2: Atur Lingkungan Semut
Mengatur ANT_HOMEvariabel lingkungan untuk menunjuk ke lokasi direktori dasar, tempat pustaka ANT disimpan di komputer Anda. Mari kita asumsikan kita telah menyimpan perpustakaan Ant di folder apache-ant-1.8.4.
OS | Keluaran |
---|---|
Windows | Setel variabel lingkungan ANT_HOME ke C: \ Program Files \ Apache Software Foundation \ apache-ant-1.8.4 |
Linux | Ekspor ANT_HOME = / usr / local / apache-ant-1.8.4 |
Mac | Ekspor ANT_HOME = / Library / apache-ant-1.8.4 |
Tambahkan lokasi kompilator Ant ke Jalur Sistem sebagai berikut -
OS | Deskripsi |
---|---|
Windows | Tambahkan string% ANT_HOME \ bin di akhir variabel sistem, Path. |
Linux | Ekspor PATH =$PATH:$ANT_HOME / bin / |
Mac | Tidak dibutuhkan. |
Langkah 3: Unduh Arsip TestNG
Unduh file jar yang diperlukan http://www.testng.org.
OS | Nama arsip |
---|---|
Windows | testng-6.8.jar |
Linux | testng-6.8.jar |
Mac | testng-6.8.jar |
Langkah 4: Buat Struktur Proyek
Buat folder TestNGWithAnt di C:\>TestNG_WORKSPACE.
Buat folder src di C:\>TestNG_WORKSPACE>TestNGWithAnt.
Buat folder test di C:\>TestNG_WORKSPACE>TestNGWithAnt.
Buat folder lib di C:\>TestNG_WORKSPACE>TestNGWithAnt.
Membuat MessageUtil kelas di C:\>TestNG_WORKSPACE>TestNGWithAnt>src map.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public void printMessage() {
System.out.println(message);
return message;
}
// add "Hi!" to the message
public String salutationMessage() {
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
Buat kelas TestMessageUtil di C:\>TestNG_WORKSPACE>TestNGWithAnt>src map.
import org.testng.Assert;
import org.testng.annotations.Test;
public class TestMessageUtil {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
Assert.assertEquals(message,messageUtil.printMessage());
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message,messageUtil.salutationMessage());
}
}
Salin testng-6.8.jar di C:\>TestNG_WORKSPACE>TestNGWithAnt>lib map.
Buat ANT build.xml
Pertama, kita perlu mendefinisikan tugas Ant TestNG sebagai berikut -
<taskdef name = "testng" classname = "org.testng.TestNGAntTask">
<classpath>
<pathelement location = "lib/testng-6.8.jar"/>
</classpath>
</taskdef>
Kemudian, kami akan menggunakan <testng> tugas di Ant untuk menjalankan kasus uji TestNG kami.
Itu build.xml file adalah sebagai berikut -
<project name = "TestNGTest" default = "test" basedir = ".">
<!-- Define <testng> task -->
<taskdef name = "testng" classname = "org.testng.TestNGAntTask">
<classpath>
<pathelement location = "lib/testng-6.8.jar"/>
</classpath>
</taskdef>
<property name = "testdir" location = "test" />
<property name = "srcdir" location = "src" />
<property name = "libdir" location = "lib" />
<property name = "full-compile" value="true" />
<path id = "classpath.base"/>
<path id = "classpath.test">
<fileset dir = "${libdir}"> <include name = "**/*.jar" /> </fileset> <pathelement location = "${testdir}" />
<pathelement location = "${srcdir}" /> <path refid = "classpath.base" /> </path> <target name = "clean" > <delete verbose="${full-compile}">
<fileset dir = "${testdir}" includes="**/*.class" /> </delete> </target> <target name = "compile" depends="clean"> <javac srcdir = "${srcdir}" destdir = "${testdir}" verbose="${full-compile}">
<classpath refid = "classpath.test"/>
</javac>
</target>
<target name = "test" depends="compile">
<testng outputdir = "${testdir}" classpathref="classpath.test"> <xmlfileset dir = "${srcdir}" includes="testng.xml"/>
</testng>
</target>
</project>
Jalankan perintah Ant berikut.
C:\TestNG_WORKSPACE\TestNGWithAnt>ant
Verifikasi hasilnya.
test:
[testng] [TestNG] Running:
[testng] C:\TestNG_WORKSPACE\TestNGWithAnt\src\testng.xml
[testng]
[testng] Inside testPrintMessage()
[testng] Manisha
[testng] Inside testSalutationMessage()
[testng] Hi!Manisha
[testng]
[testng] ===============================================
[testng] Plug ANT test Suite
[testng] Total tests run: 2, Failures: 0, Skips: 0
[testng] ===============================================
[testng]
BUILD SUCCESSFUL
Total time: 1 second
Untuk mengatur TestNG dengan Eclipse, ikuti langkah-langkah yang diberikan di bawah ini -
Langkah 1: Unduh Arsip TestNG
Unduh versi terbaru file jar TestNG dari http://www.testng.org
OS | Nama arsip |
---|---|
Windows | testng-6.8.jar |
Linux | testng-6.8.jar |
Mac | testng-6.8.jar |
Kami menganggap Anda telah menyalin file JAR di atas di folder C: \> TestNG.
Langkah 2: Setel lingkungan Eclipse
Buka eclipse → klik kanan pada proyek dan pergi ke property → Build Path → Configure Build Path dan tambahkan testng-6.8.jar di perpustakaan menggunakan tombol Add External Jar .
Kami berasumsi bahwa Eclipse Anda memiliki plugin TestNG bawaan; jika tidak tersedia, dapatkan versi terbaru menggunakan situs pembaruan.
Di Eclipse IDE Anda, pilih Bantuan / Pembaruan perangkat lunak / Temukan dan Instal .
Cari fitur baru untuk diinstal.
Situs jarak jauh baru.
Untuk Eclipse 3.4 dan yang lebih baru, masukkan http://beust.com/eclipse.
Untuk Eclipse 3.3 dan yang lebih lama, masukkan http://beust.com/eclipse1.
Pastikan kotak centang di sebelah URL dicentang dan klik Next .
Eclipse kemudian akan memandu Anda melalui proses tersebut.
Sekarang, Eclipse Anda siap untuk pengembangan kasus uji TestNG.
Langkah 3: Verifikasi Instalasi TestNG di Eclipse
Buat proyek TestNGProject di Eclipse di lokasi mana pun.
Buat kelas MessageUtil untuk diuji dalam proyek.
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
}
Buat kelas uji TestNGExample dalam proyek.
import org.testng.Assert;
import org.testng.annotations.Test;
public class TestNGExample {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
Assert.assertEquals(message,messageUtil.printMessage());
}
}
Struktur proyek harus sebagai berikut -
Terakhir, verifikasi output program dengan mengklik kanan program dan menjalankan sebagai TestNG.
Verifikasi hasilnya.