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();
   }
}