Groovy - testy jednostkowe
Podstawową jednostką systemu obiektowego jest klasa. Dlatego testowanie jednostkowe składa się z testig w klasie. Podejście polega na utworzeniu obiektu testowanej klasy i wykorzystaniu go do sprawdzenia, czy wybrane metody działają zgodnie z oczekiwaniami. Nie każdą metodę można przetestować, ponieważ testowanie każdej rzeczy nie zawsze jest praktyczne. Ale testy jednostkowe należy przeprowadzać dla kluczowych i krytycznych metod.
JUnit to platforma testowa typu open source, która jest akceptowanym standardem branżowym dla zautomatyzowanych testów jednostkowych kodu Java. Na szczęście framework JUnit można łatwo wykorzystać do testowania klas Groovy. Wystarczy rozszerzyć klasę GroovyTestCase, która jest częścią standardowego środowiska Groovy. Klasa przypadku testowego Groovy jest oparta na przypadku testowym Junit.
Pisanie prostego przypadku testowego Junit
Załóżmy, że mamy następującą klasę zdefiniowaną w pliku klasy aplikacji -
class Example {
static void main(String[] args) {
Student mst = new Student();
mst.name = "Joe";
mst.ID = 1;
println(mst.Display())
}
}
public class Student {
String name;
int ID;
String Display() {
return name +ID;
}
}
Wynik powyższego programu podano poniżej.
Joe1
A teraz przypuśćmy, że chcieliśmy napisać przypadek testowy dla klasy Student. Typowy przypadek testowy wyglądałby jak ten poniżej. Należy zwrócić uwagę na następujące punkty dotyczące następującego kodu -
- Klasa przypadku testowego rozszerza klasę GroovyTestCase
- Używamy instrukcji assert, aby upewnić się, że metoda Display zwraca właściwy ciąg.
class StudentTest extends GroovyTestCase {
void testDisplay() {
def stud = new Student(name : 'Joe', ID : '1')
def expected = 'Joe1'
assertToString(stud.Display(), expected)
}
}
Zestaw testów Groovy
Zwykle wraz ze wzrostem liczby testów jednostkowych trudno byłoby wykonywać wszystkie przypadki testowe jeden po drugim. Dlatego Groovy zapewnia narzędzie do tworzenia zestawu testów, który może zawierać wszystkie przypadki testowe w jednej jednostce logicznej. Poniższy fragment kodu pokazuje, jak można to osiągnąć. Należy zwrócić uwagę na następujące kwestie dotyczące kodu -
GroovyTestSuite służy do hermetyzacji wszystkich przypadków testowych w jeden.
W poniższym przykładzie zakładamy, że mamy dwa pliki przypadków testowych, jeden o nazwie StudentTest a drugi jest EmployeeTest który zawiera wszystkie niezbędne testy.
import groovy.util.GroovyTestSuite
import junit.framework.Test
import junit.textui.TestRunner
class AllTests {
static Test suite() {
def allTests = new GroovyTestSuite()
allTests.addTestSuite(StudentTest.class)
allTests.addTestSuite(EmployeeTest.class)
return allTests
}
}
TestRunner.run(AllTests.suite())