JMock+Junit 4を組み合わせてTDDインスタンスを完了
3274 ワード
通常、測定されるクラスは、他のクラスの方法を避けられない.他のクラスメソッドの正確性を保証できない前提の下で、どのようにユニットテストの方式を通じてテストするクラスメソッドが正しいことを保証しますか?あるいは、テスト対象のメソッドが依存する他のクラスのコードが実装されずにインタフェースを定義している場合、テスト対象のメソッドはテストできますか?JMockの出現は上記の問題を解決した.JMockは開発者に測定対象メソッドが他のクラスに依存する能力を遮断し、開発者が他のクラスメソッドが正しい結果を返すことができるかどうかを心配することなく、測定対象メソッドの論理にすべての注意力を集中させることができるようにする.このようなテストは、より的確であり、潜在的な問題に位置づけやすい.
まず、依存するパッケージを用意します.
次に例を書きます.
1.まず、インタフェースクラスを書きます.
2.次に、上記のインタフェースを実装していない一般的なメソッドクラスを書きます.
ここまで来ると、上のインタフェースには実装クラスがありません.ここでは、実装クラスにはありません.では、ユニットテストにはどうすればいいのでしょうか.切れたんじゃないの?はい、確かに切れましたが、どうすればいいですか.切断してもテストできる方法はありますか?答えは肯定的で、次はJMockを引用してこの切断されたテストを実現します.
3.最後に、テストクラスを作成します.
このようにして、私たちは切断してもユニットテストを実現して、mockインタフェース実装クラスが返すべきデータと呼ばれて、それによって、私たちはそれがインタフェースの実装クラスがあるかどうかを気にする必要はありません.クラスの中に方法があるかどうか、私たちは現在のテストクラスの論理だけを重視すればいいです.
まず、依存するパッケージを用意します.
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.jmock</groupId>
<artifactId>jmock-junit4</artifactId>
<version>2.8.1</version>
</dependency>
<dependency>
<groupId>org.jmock</groupId>
<artifactId>jmock</artifactId>
<version>2.8.1</version>
</dependency>
<dependency>
<groupId>org.jmock</groupId>
<artifactId>jmock-legacy</artifactId>
<version>2.8.1</version>
</dependency>
</dependencies>
次に例を書きます.
1.まず、インタフェースクラスを書きます.
package jmust.demo.Cobertura.Inter;
public interface IMathfun {
public int abs(int num);
}
2.次に、上記のインタフェースを実装していない一般的なメソッドクラスを書きます.
package jmust.demo.Cobertura.Service;
import jmust.demo.Cobertura.Inter.IMathfun;
public class TestJunit4 {
private IMathfun util;
public TestJunit4(IMathfun util) {
this.util = util;
}
public int cal(int num) {
return 10 * util.abs(num);
}
}
ここまで来ると、上のインタフェースには実装クラスがありません.ここでは、実装クラスにはありません.では、ユニットテストにはどうすればいいのでしょうか.切れたんじゃないの?はい、確かに切れましたが、どうすればいいですか.切断してもテストできる方法はありますか?答えは肯定的で、次はJMockを引用してこの切断されたテストを実現します.
3.最後に、テストクラスを作成します.
package jmust.demo.CoberturaTest;
import org.jmock.Expectations;
import org.jmock.Mockery;
import org.jmock.integration.junit4.JUnit4Mockery;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import jmust.demo.Cobertura.Inter.IMathfun;
import jmust.demo.Cobertura.Service.TestJunit4;
import junit.framework.TestCase;
public class Junit4Test extends TestCase{
private Mockery context = new JUnit4Mockery();
private IMathfun math = null;
private TestJunit4 test = null;
@Before
public void setUp() throws Exception{
super.setUp();
math = context.mock(IMathfun.class);
test = new TestJunit4(math);
context.checking(new Expectations(){
{
exactly(1).of(math).abs(-20);will(returnValue(20));
}
});
}
@After
public void setDown(){
}
@Test
public void test(){
assertEquals(200, test.cal(-20));
}
}
このようにして、私たちは切断してもユニットテストを実現して、mockインタフェース実装クラスが返すべきデータと呼ばれて、それによって、私たちはそれがインタフェースの実装クラスがあるかどうかを気にする必要はありません.クラスの中に方法があるかどうか、私たちは現在のテストクラスの論理だけを重視すればいいです.