JUnit - Temel Kullanım
Şimdi JUnit kullanma sürecini adım adım göstermek için temel bir örneğe sahip olalım.
Bir Sınıf Oluşturun
Test edilecek bir java sınıfı oluşturun, örneğin MessageUtil.java içinde 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;
}
}
Test Vaka Sınıfı Oluşturun
- TestJunit.java gibi bir java test sınıfı oluşturun.
- Test sınıfınıza bir test yöntemi testPrintMessage () ekleyin.
- TestPrintMessage () yöntemine bir @Test Notu ekleyin.
- Test koşulunu uygulayın ve JUnit'in assertEquals API'sini kullanarak koşulu kontrol edin.
TestJunit.java adında bir java sınıfı dosya oluşturun C:\>JUNIT_WORKSPACE.
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
assertEquals(message,messageUtil.printMessage());
}
}
Test Runner Sınıfı Oluşturun
- Bir TestRunner java sınıfı oluşturun.
- Yukarıda oluşturulan test sınıfının test durumunu çalıştırmak için JUnit'in JUnitCore sınıfının runClasses yöntemini kullanın.
- Sonuç Nesnesinde çalıştırılan test senaryolarının sonucunu alın.
- Result nesnesinin getFailures () yöntemini kullanarak hataları alın.
- Result nesnesinin wasSuccessful () yöntemini kullanarak Başarı sonucunu alın.
TestRunner.java adlı bir java sınıf dosyası oluşturun. C:\>JUNIT_WORKSPACE test senaryolarını yürütmek için.
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
Javac kullanarak MessageUtil, Test case ve Test Runner sınıflarını derleyin.
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
Şimdi, sağlanan Test Case sınıfında tanımlanan test senaryosunu çalıştıracak olan Test Runner'ı çalıştırın.
C:\JUNIT_WORKSPACE>java TestRunner
Çıkışı doğrulayın.
Hello World
true
Şimdi TestJunit'i güncelleyin C:\>JUNIT_WORKSPACEböylece test başarısız olur. Mesaj dizisini değiştirin.
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Hello World";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
message = "New Word";
assertEquals(message,messageUtil.printMessage());
}
}
Geri kalan sınıfları olduğu gibi tutalım ve aynı Test Runner'ı çalıştırmayı deneyelim.
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
Şimdi, sağlanan Test Case sınıfında tanımlanan test senaryosunu çalıştıracak olan Test Runner'ı çalıştırın.
C:\JUNIT_WORKSPACE>java TestRunner
Çıkışı doğrulayın.
Hello World
testPrintMessage(TestJunit): expected:<[New Wor]d> but was:<[Hello Worl]d>
false