JUnit-확장
다음은 JUnit 확장입니다-
- Cactus
- JWebUnit
- XMLUnit
- MockObject
선인장
Cactus는 서버 측 자바 코드 (서블릿, EJB, 태그 라이브러리, 필터)를 단위 테스트하기위한 간단한 테스트 프레임 워크입니다. Cactus의 목적은 서버 측 코드에 대한 테스트 작성 비용을 낮추는 것입니다. JUnit을 사용하고 확장합니다. Cactus는 컨테이너 내부에서 테스트를 실행하는 컨테이너 내 전략을 구현합니다.
선인장 생태계는 여러 구성 요소로 구성됩니다.
Cactus Framework선인장의 심장입니다. Cactus 테스트를 작성하기위한 API를 제공하는 엔진입니다.
Cactus Integration Modules Cactus Framework (Ant 스크립트, Eclipse 플러그인 및 Maven 플러그인)를 사용하는 쉬운 방법을 제공하는 프런트 엔드 및 프레임 워크입니다.
다음 코드는 Cactus를 사용하는 방법을 보여줍니다.
import org.apache.cactus.*;
import junit.framework.*;
public class TestSampleServlet extends ServletTestCase {
@Test
public void testServlet() {
// Initialize class to test
SampleServlet servlet = new SampleServlet();
// Set a variable in session as the doSomething()
// method that we are testing
session.setAttribute("name", "value");
// Call the method to test, passing an
// HttpServletRequest object (for example)
String result = servlet.doSomething(request);
// Perform verification that test was successful
assertEquals("something", result);
assertEquals("otherValue", session.getAttribute("otherName"));
}
}
JWebUnit
JWebUnit은 웹 애플리케이션을위한 Java 기반 테스트 프레임 워크입니다. HtmlUnit 및 Selenium과 같은 기존 테스트 프레임 워크를 통합 된 간단한 테스트 인터페이스로 래핑하여 웹 애플리케이션의 정확성을 테스트합니다.
JWebUnit은 애플리케이션의 정확성을 확인하기 위해 어설 션 세트와 결합 된 웹 애플리케이션을 탐색하기위한 고급 Java API를 제공합니다. 여기에는 링크를 통한 탐색, 양식 입력 및 제출, 테이블 내용 유효성 검사 및 기타 일반적인 비즈니스 웹 응용 프로그램 기능이 포함됩니다.
간단한 탐색 방법과 바로 사용할 수있는 어설 션을 사용하면 JUnit 또는 HtmlUnit 만 사용하는 것보다 더 빠른 테스트 생성이 가능합니다. 그리고 HtmlUnit에서 Selenium (곧 사용 가능)과 같은 다른 플러그인으로 전환하려는 경우 테스트를 다시 작성할 필요가 없습니다.
다음은 샘플 코드입니다.
import junit.framework.TestCase;
import net.sourceforge.jwebunit.WebTester;
public class ExampleWebTestCase extends TestCase {
private WebTester tester;
public ExampleWebTestCase(String name) {
super(name);
tester = new WebTester();
}
//set base url
public void setUp() throws Exception {
getTestContext().setBaseUrl("http://myserver:8080/myapp");
}
// test base info
@Test
public void testInfoPage() {
beginAt("/info.html");
}
}
XMLUnit
XMLUnit은 단일 JUnit 확장 클래스, XMLTestCase 및 어설 션을 작성할 수있는 지원 클래스 세트를 제공합니다.
두 XML 부분의 차이점 (Diff 및 DetailedDiff 클래스를 통해).
XML 조각의 유효성 (Validator 클래스를 통해).
XSLT를 사용하여 XML 조각을 변환 한 결과 (Transform 클래스를 통해).
XML 조각에 대한 XPath 표현식 평가 (XpathEngine 인터페이스를 구현하는 클래스를 통해).
DOM Traversal (NodeTest 클래스를 통해)에 의해 노출되는 XML 조각의 개별 노드.
두 개의 XML 조각을 비교하고 동일하다고 가정 해 보겠습니다. 다음과 같은 간단한 테스트 클래스를 작성할 수 있습니다.
import org.custommonkey.xmlunit.XMLTestCase;
public class MyXMLTestCase extends XMLTestCase {
// this test method compare two pieces of the XML
@Test
public void testForXMLEquality() throws Exception {
String myControlXML = "<msg><uuid>0x00435A8C</uuid></msg>";
String myTestXML = "<msg><localId>2376</localId></msg>";
assertXMLEqual("Comparing test xml to control xml", myControlXML, myTestXML);
}
}
MockObject
단위 테스트에서 모의 객체는 복잡한 실제 (모의가 아닌) 객체의 동작을 시뮬레이션 할 수 있으므로 실제 객체가 비실용적이거나 단위 테스트에 통합 할 수없는 경우에 유용합니다.
모의 객체로 테스트하는 일반적인 코딩 스타일은 다음과 같습니다.
- 모의 개체의 인스턴스를 만듭니다.
- 모의 객체에 상태와 기대치를 설정합니다.
- 모의 객체를 매개 변수로 사용하여 도메인 코드를 호출합니다.
- 모의 객체의 일관성을 확인합니다.
다음은 Jmock을 사용하는 MockObject의 예입니다.
import org.jmock.Mockery;
import org.jmock.Expectations;
class PubTest extends TestCase {
Mockery context = new Mockery();
public void testSubReceivesMessage() {
// set up
final Sub sub = context.mock(Sub.class);
Pub pub = new Pub();
pub.add(sub);
final String message = "message";
// expectations
context.checking(new Expectations() {
oneOf (sub).receive(message);
});
// execute
pub.publish(message);
// verify
context.assertIsSatisfied();
}
}