- Easymock
-
EasyMock Maintainer Tammo Freese, Henri Tremblay Entwickler OFFIS, Tammo Freese, Henri Tremblay Aktuelle Version 3.0[1]
(8. Mai 2010[1])Betriebssystem Plattformübergreifend Programmiersprache Java Kategorie Test-Framework Lizenz Apache Lizenz 2.0 easymock.org EasyMock ist eine Programmbibliothek zum Erstellen von Mock-Objekten für Unit-Tests von Java-Programmen.
Im Unit-Test sollen einzelne Testobjekte (meist Klassen oder Methoden) isoliert von ihrer Umgebung getestet werden. Um einen vollständig isolierten Test zu erreichen, müssen die Schnittstellen, über die das zu testende Objekt auf seine Umgebung zugreift, durch Mock-Objekte ersetzt werden. Die Mock-Objekte fungieren dabei als Platzhalter für die echten Objekte.
Inhaltsverzeichnis
Funktionalität
EasyMock ist die erste Programmbibliothek, die die dynamische Erzeugung von Mock-Objekten basierend auf deren Schnittstelle unterstützt[2]. Es wurde erstmalig auf der OOPSLA im Jahre 2001 vorgestellt. Das Verhalten eines dynamischen Mock-Objekts wird nicht in einer eigenen Klasse programmiert, sondern vor dem Unit-Test aufgezeichnet. Der Ansatz einer dynamischen Erzeugung von Mock-Objekten bietet einige Vorteile gegenüber der statischen Programmierung von Mock-Klassen und Objekten.
- Es müssen keine Klassen von Hand geschrieben werden.
- Es muss kein Quellcode der Mock-Klassen mit denen der echten Klassen synchron gehalten werden.
- Dynamische Mock Objekte sind sicherer gegenüber Refactoring
Zur Benutzung von EasyMock werden folgende Schritte durchlaufen:
- Mock-Objekt von der Klasse bzw. Schnittstelle, die simuliert werden soll, erzeugen und dem zu testenden Objekt übergeben.
- Erwartetes Verhalten aufzeichnen (basierend auf dem Fluent Interface Entwurfsmuster).
- Mock Objekt auf Wiedergabe Modus (Replay) stellen.
- Verifizieren (verify(mock)) ob das Mock-Objekt auch so benutzt wurde wie in Schritt zwei spezifiziert.
Typisches Beispiel
Es soll durch einen Unit Test das Verhalten der Service Klasse KundeService verifiziert werden. Diese Klasse hat eine Referenz zu einer Hilfsklasse KundeDAO, welche die Kundendaten aus einer Datenbank liest. Das Data Access Object KundeDAO muss durch ein Mock-Objekt ersetzt werden, um die Klasse KundeService isoliert testen zu können.
Für den ersten Schritt wird die setUp()-Methode des JUnit-Tests überschrieben:
private IKundeDAO kundeDAOMock; private KundeService kundeService; @Before protected void setUp() throws Exception { super.setUp(); //Schritt 1: Mock-Objekt erstellen kundeDAOMock = EasyMock.createMock(IKundeDAO.class); // KundenService erzeugen kundeService = new KundeService(); // KundenService mit Mock-Objekt versorgen kundeService.setKundeDAO(kundeDAOMock); }
Die Schritte Zwei und Drei werden in der Test-Methode ausgeführt:
@Test public void testKundenLesen() { //Schritt 2: Erwartetes Verhalten vom KundeDAO aufzeichnen // erwartetes Ergebnis erstellen List<Kunde> list = new ArrayList<Kunde>(); list.add(new Kunde("Müller")); list.add(new Kunde("Meier")); // erwarteten Methodenaufruf am Mock-Objekt mit Ergebnis aufzeichnen EasyMock.expect(kundeDAOMock.findAll()).andReturn(list); //Schritt 3: Aufnahme beendet! EasyMock.replay(kundeDAOMock); //Eigentlichen Test durchführen kundeService.leseAlleKunden(); //Prüfen, dass alle erwarteten Methoden am Mock-Objekt aufgerufen wurden. EasyMock.verify(kundeDAOMock); }
Alternativen
Als Alternative zu EasyMock existieren die folgenden Programmbibliotheken, die ebenfalls das dynamische Erzeugen von Mock-Objekten erlauben:
Literatur
- David Astels: Test Driven Development: A Practical Guide. Prentice Hall International, 2003, ISBN 0131016490.
- Vincent Massol, Ted Husted: JUnit in Action. Manning, 2003, ISBN 1930110995.
- Johannes Link: Softwaretests mit JUnit. Dpunkt Verlag, 2005, ISBN 3898643255.
- Michael Hüttermann: Agile Java-Entwicklung in der Praxis. O'Reilly, 2007, ISBN 3897214822.
Weblinks
- EasyMock Homepage (Englisch)
- OOPSLA (Englisch)
Einzelnachweise
Kategorien:- Freies Programmierwerkzeug
- Java-Programmierwerkzeug
- Java-Bibliothek
- Testsoftware
- Testen (Software)
Wikimedia Foundation.