H'academy
  • H'academy
  • Web
    • Back-end
      • Spring Framework
        • Spring 개발환경 구축
          • Project 생성
          • Maven 설정
          • Maven 저장소 위치 설정
          • Apache Tomcat 연동
          • Lombok 설정
        • Spring MVC Project
          • pom.xml
          • web.xml
          • root-context.xml
          • servlet-context.xml
          • DispatcherServlet
        • Controller
          • File Upload / Download
          • RestController(작성중)
        • Spring Test
          • Assert 단정문
          • Spring 환경 연동 테스트
          • MockMvc Test
        • Spring AOP
          • AOP 용어
          • Pointcut Expression
          • Filter
          • Interceptor
          • Filter vs Interceptor
          • Controller Advice(작성중)
        • Spring JDBC
          • DBCP
          • myBatis
            • ResultMap 활용
        • ETC
          • Logging
            • Tomcat Logging 설정
          • Property 관리
          • E-mail
            • Gmail 변경사항
          • Scheduler
          • Websocket
      • Spring Boot
        • STS 다운로드
        • 프로젝트 생성
        • 프로젝트 구조
        • Spring Devtools
        • Spring Controller
          • JSP 연동
            • * JSP 생성불가 문제
            • Spring Boot 3.x
          • Model
          • 요청 파라미터 처리
          • 경로 변수 처리
          • 요청 메소드
          • Redirect
          • Spring Actuator
        • Spring Boot JDBC
          • Database 정보
          • DAO Pattern
          • ORM Framework
            • myBatis
              • Mapper 생성
            • Spring Data JPA
        • Spring AOP
          • AspectJ
          • Filter
          • Interceptor
          • ControllerAdvice
        • REST API
        • Spring WebSocket
        • Send Mail
        • Logging
        • Spring Boot Test
        • Lombok
      • Java EE
        • 개발환경 구성
          • Server와 Client
          • Web Server와 WAS
        • Dynamic Web Project
      • Apache Tomcat
        • Apache Tomcat 구조
        • Tomcat User 생성
        • Tomcat Manager 설정
      • Maven
      • Jenkins
        • Installation
          • Github Webhook 설정
          • Maven 연동
        • Project setting
          • 소스 코드 관리 설정
          • 빌드 유발 설정
          • 빌드 작업 설정
      • OpenAPI(swagger)
        • swagger 2.x (legacy)
        • swagger 3.x (boot)
        • Swagger UI 꾸미기
        • SpringDoc
    • Front-end
      • HTML
        • Heading
        • <A>
        • <IMG>
        • <DIV>
        • <TABLE>
        • <FORM>
          • <INPUT>
          • <SELECT>
          • <TEXTAREA>
          • <FIELDSET>
        • List
      • CSS
        • CSS 적용 방식
          • 크기(size)
            • 픽셀(px)
          • 색상(color)
        • CSS 선택자
          • 스타일 우선순위
        • CSS 주요 속성
          • 크기 속성
            • border
            • margin
            • padding
            • box-sizing
          • 배경 속성
          • 글자 속성
            • font
            • text
          • 배치 속성
            • position
            • display
            • overflow
            • float
            • flexbox
        • CSS Reset
      • JS
        • syntax
          • let, const
          • 구조 분해 할당
          • spread operator
          • Object copy
          • this
          • module
        • jQuery
          • structure
          • function
          • ajax
            • ajax file upload
        • VueJS
          • CDN(Vue3)
            • 기본 구조
            • Vue Devtools
            • jQuery vs VueJS
            • Vue instance
              • data
                • IME issue
              • v-model
              • template
              • computed
              • watch
                • deep watch
                • vs Computed
              • methods
            • Vue directive
              • v-text
              • v-html
              • v-bind
                • v-bind style
                • v-bind class
              • v-on
                • once
                • prevent
              • v-show
              • v-if
              • v-for
          • Vue-cli 3
            • 프로젝트 구조
            • src
              • main.js
              • App.vue
              • HelloWorld.vue
            • Vue Router 4
              • History mode
              • 404 not found
              • Guard
                • beforeEach
            • Vuex
              • 이동 횟수 측정
            • axios
              • interceptor
          • Vue-electron
        • ReactJS
          • CDN(React18)
            • 템플릿 설명
            • JSX
            • render
            • Handling Events
              • onClick
              • onInput
            • Component
              • 클래스 컴포넌트
                • state
                • props
                • event
                  • Mouse
                  • Input
                • lifecycle
              • 함수형 컴포넌트
                • useState
                • useEffect
                • useReducer
                • useMemo
                • props
                • 조건부 렌더링
          • CRA
            • 자원 경로 설정
            • src 절대 경로 설정
            • react-router
            • Context API
            • Electron 설정
        • Webpack
          • NodeJS
          • Git
    • Ubuntu server
      • Jenkins
    • 테스트 도구
      • JMeter
        • Test Plan
        • Test Plan(with login)
        • Plugin 설치
    • WebRTC
  • Base Language
    • Java
      • Java 실행 과정
        • 개발 환경 구축
        • 샘플 코드 작성
        • 컴파일/실행
        • 환경 변수 설정
      • Java 초급
        • Hello world
        • 자료와 정보
        • 변수
          • 정수
            • 정수의 저장 원리
            • 정수형 변수 생성
          • 실수
            • 실수의 저장 원리
            • 실수형 변수 생성
          • 논리
            • 논리형 변수 생성
          • 문자
          • 문자열
            • 문자열 변수 생성
          • 사용자 정의 자료형
        • 연산자
          • 대입 연산
          • 부호 연산
          • 산술 연산
          • 복합 대입 연산
          • 증감 연산
          • 쉬프트 연산
          • 비트 연산
          • 비교 연산
          • 논리 연산
          • 삼항 연산
          • 변환 연산
        • 표준 입출력
          • 표준 출력
          • 표준 오류 출력
          • 표준 입력
            • Scanner 입력
        • 제어문
          • if 구문
            • 단일 조건
            • 두 가지의 조건
            • 여러 가지의 조건
          • switch~case 구문
          • while 구문
          • do~while 구문
          • for 구문
        • 랜덤(Random)
        • 배열
          • 1차원 배열
          • 2차원 배열
          • 다차원 배열
          • Sort
            • 선택 정렬
            • 버블 정렬
            • 삽입 정렬
      • Java 중급
        • 객체 지향 프로그래밍
        • 클래스
        • 인스턴스
        • 필드
        • 메소드
          • 설정(setter) 메소드
          • 반환(getter) 메소드
        • 생성자
        • 접근 제한
          • private
          • package
          • protected
          • public
        • 정적(static)
        • 불변(final)
        • 상수(constant)
        • 상속
          • this와 super의 이해
          • 멤버 변수 설정
          • 멤버 메소드 설정
          • 생성자 설정
        • 추상화
          • 추상 클래스
          • 인터페이스
        • 다형성
        • 중첩 클래스
          • 일반 중첩 클래스
          • static 중첩 클래스
          • 지역 중첩 클래스
          • 익명 중첩 클래스
      • Java API(작성중)
        • java.lang
        • java.util
        • java.text
        • java.time
        • java.io
        • java.net
        • java.sql
        • java.awt
        • javax.swing
      • Java 고급
        • 제네릭(Generic)
        • 열거형(Enum)
        • Annotation Type
          • Retention
          • Target
          • Nested Annotation
        • Java Reflection
          • Intro
          • Class
          • Field
          • Constructor
          • Method
          • Package
      • JDBC
        • 드라이버 로드
        • 연결 생성
          • JDBC Driver 유형
        • JdbcTemplate
      • Java 버전별 변경사항
        • Java 1.8
          • Lambda Expression
          • Stream API
          • java.time 패키지
        • Java 9
        • Java 12
          • switch~case
        • Java 13
          • Text Block
    • Arduino
      • 학습 준비
        • Reference
        • 아두이노 온라인 시뮬레이터
        • 전기의 이해
        • 그라운드(GND)의 이해
      • 개발 환경 구축
        • CH340 보드 설치
        • Editor 글꼴 설정
      • 아두이노 제어
        • 코드의 구성
        • 시리얼 출력
        • 디지털 출력
          • LED 출력
        • PWM 출력
        • 시리얼 입력
        • 디지털 입력
          • PIR 센서
        • 아날로그 입력
          • 온도 센서(LM35DZ)
          • 조도 센서
          • 가스 센서
        • 피에조 부저
        • 서보 모터 제어
          • 시리얼 서보 모터 제어
          • 스위치 서보 모터 제어
        • 온습도 센서(DHT-11)
        • LCD
      • 아두이노 통신
        • 블루투스(Bluetooth)
          • HC-06
            • 온도 센서 활용
          • HM-10
        • 와이파이(Wi-Fi)
          • ESP-01
            • WiFiEsp 라이브러리 추가
            • WiFiEsp 네트워크 스캔
        • 이더넷(Ethernet)
        • ArduinoJson 라이브리 사용
    • Regular Expression
  • Database
    • Oracle
      • 설치
        • SQL Plus
        • SQL Developer
        • DBeaver
        • Docker(Mac OS)
      • SQL
        • 관리자 명령
          • 사용자 관리
          • 권한 관리
          • Encoding 설정
          • 서비스 포트 설정
        • 사용자 명령
          • 테이블 관리
            • 테이블 항목 제약 조건
            • 외래키 제약조건
            • 데이터 유형
          • 시퀀스 관리
          • 데이터 관리
            • 데이터 추가
            • 데이터 조회
              • 오라클 내장 함수
              • 그룹 조회
              • Top N Query
            • 데이터 수정
            • 데이터 삭제
          • 뷰 관리
          • 인덱스 관리
          • 집합 연산
          • 테이블 조인
            • 등가 조인
            • 외부 조인
        • HR 계정
        • 기타 명령
          • 컬럼 간격 조정
      • 내보내기 및 불러오기
        • EXPDP, IMPDP
        • Docker로 실행중인 경우
      • 기타
        • 자동 세션 제거
        • Tablespace 관리
        • Unlock user
  • 면접대비
    • Q&A
      • Java
      • Database
      • Web
      • IT 일반상식
  • ETC
    • Eclipse IDE
      • 설치
      • 화면 설명
      • 환경 설정
      • 프로젝트 생성
      • 소스파일 작성 및 실행
    • Github
      • Github 계정 관리
      • Github 저장소 관리
        • Profile
        • Collaborators
        • Code
        • Issues
        • Pull requests
        • Action
          • Vue 3 Deploy Action
      • Personal Access Token
      • Git ignore 설정
        • Spring 개발용 샘플
      • Github Eclipse 연동
        • Branches
        • Project
        • Team project
          • Dynamic web project
          • Spring Boot Project
          • Branch 생성
          • Pull Request
          • Branch 보호
          • Branch 다시 생성
    • Figma
      • Team
      • Design
      • Component
    • 과정평가형
      • 실기 모의고사 1회
      • 실기 모의고사 2회
      • 실기 모의고사 3회
      • 실기 모의고사 4회
    • VScode
      • Live Server 실행 오류
      • Github 계정 변경
    • Naver ToastUI Editor
      • Editor 만들기
        • Editor options
          • File upload
      • Viewer 만들기
    • 문자 인코딩 방식
    • OBS
      • 녹화 잡음 제거 설정
    • Semantic Version
Powered by GitBook
On this page
  • TDD
  • Spring Boot Test
  • 필요 의존성
  • JUnit
  • 테스트 클래스 생성
  • @SpringBootTest
  • @Test
  • 테스트 코드 작성
  • 테스트 실행 및 결과 확인
  • 단정문의 종류
  • 모듈 테스트
  • 모듈 생성
  • 테스트 생성
  • 컨트롤러 테스트
  • 컨트롤러 생성
  • 테스트 생성
  1. Web
  2. Back-end
  3. Spring Boot

Spring Boot Test

Spring Boot에서 테스트를 수행하는 방법에 대해서 살펴본다

TDD

TDD(Test Driven Development)란 고품질의 소프트웨어 기능을 구현하기 위하여 테스트를 수행하고 충분한 검토와 피드백을 통해 개선시켜나가는 개발 방법론을 말한다.

Spring Boot Test

Spring Boot에서는 테스트를 위한 별도의 src 공간이 배정되어 있으며 위치는 src/test/java이다. Spring Legacy와 다른점은 src/test/resources가 없다는 것이다. 해당 영역에서 테스트를 할 때 다음 기능을 사용할 수 있다.

  • pom.xml에 <scope>가 test로 설정된 의존성을 사용할 수 있다.

  • test source는 빌드에서 제외된다

  • test source에서는 main source를 사용할 수 있다

필요 의존성

Spring Boot에서는 프로젝트 생성 시 다음 의존성이 필수적으로 추가되어 있다.

  • org.springframework.boot.spring-boot-starter-test

테스트에 필요한 각종 하위 의존성들을 자동으로 불러오므로 대부분의 테스트가 가능하다.

JUnit

Spring Boot Test는 JUnit 5를 기반 기술로 사용한다. JUnit 5는 JUnit의 후속 버전으로 자바와 JVM을 기반으로 한 언어 및 프레임워크에서 사용할 수 있는 강력한 단위 테스트 도구이다.

테스트 클래스 생성

테스트 클래스를 src/test/java에 생성한다. 생성 시 프로젝트에서 설정한 base package를 지켜야 한다.

@SpringBootTest
public class TestClass {

    @Test
    public void testMethod(){
        
    }
    
}

테스트 클래스의 기본 형태이다. 사용된 Annotation은 다음과 같다.

  • @SpringBootTest - 클래스에 설정하여 Spring Test를 위한 준비를 수행한다.

  • @Test - JUnit 테스트 메소드임을 명시한다.

@SpringBootTest

SpringBootTest에서 수행하는 세부 기능은 다음과 같다.

  • ContextLoader 설정

    • 지정된 @ContextConfiguration이 없을 경우 SpringBootContextLoader 사용

  • Configuration 탐색

    • 사용된 @Configuration이 없을 경우 @SpringBootConfiguration을 검색

  • properties 속성 사용 설정

  • args 속성 사용 설정

  • 지정 혹은 랜덤 포트를 사용하여 웹 서버를 테스트할 수 있는 WebEnvironment 모드 설정

@Test

JUnit 테스트 메소드임을 명시한다. 메소드 생성 시 주의할 사항은 다음과 같다.

  • private 접근제한을 가질 수 없다

  • static 메소드는 불가능하다

  • void가 아닌 다른 반환형을 설정할 수 없다

  • 이름은 자유롭게 설정할 수 있다

테스트 코드 작성

테스트를 하는 목적은 가설에 대한 검증을 하는 것이다. 따라서 다음과 같은 가설을 설정해야 한다.

  • 가설 : 1.1 + 2.2 는 3.3 과 같을 것이다.

가설 수립 후 가설에 따른 코드를 작성한다.

@Test
public void testMethod(){
    double a = 1.1;
    double b = 2.2;
    double c = 3.3;
    assertEquals(a+b, c);
}

직접 a + b == c 라는 코드를 작성하여 결과를 확인해도 되지만 가설이 맞지 않을 경우 실패로 간주되어야 하므로 단정문(Assertion)을 사용하여 테스트 성공 조건을 작성한다. static import를 사용하여 구문을 간소화하였으며, 원 코드는 다음과 같다.

@Test
public void testMethod(){
    double a = 1.1;
    double b = 2.2;
    double c = 3.3;a
    Assert.assertEquals(a+b, c);
}

테스트 실행 및 결과 확인

실행하면 테스트의 성공 실패 여부와 실행 시간이 측정되어 JUnit 탭에 출력된다.

실행 시 JUnit Test를 선택해야 한다.

단정문의 종류

사용 가능한 단정문의 종류는 여러 가지가 있으며, 자세한 설명은 다음 문서를 참고한다.

모듈 테스트

@Repository, @Component, @Service 등 개발한 모듈을 주입하여 테스트 할 경우 @SpringBootTest 설정을 통해 Spring Boot 환경에서 설정한 내용들을 @Autowired로 주입하여 사용할 수 있다.

모듈 생성

다음과 같이 랜덤 문자열을 생성하는 도구를 만들었다고 가정한다.

@Component
public class RandomGenerator {
    
    private final String alphabetLowercase = "abcdefghijklmnopqrstuvwxyz";
    private final String alphabetUppercase = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    private final String number = "0123456789";
    private Random r = new Random();
    
    public String alphabet(int size){
        StringBuffer range = new StringBuffer();
        range.append(alphabetLowercase);
        range.append(alphabetUppercase);
        
        Stringbuffer result = new StringBuffer();
        for(int i=0; i < size; i++){
            int index = r.nextInt(range.length());
            result.append(range.charAt(index));
        }
        return result.toString();
    }
}

테스트 생성

RandomGenerator를 테스트하기 위한 코드는 다음과 같다. 테스트 코드는 반드시 src/test/java에 생성해야 한다.

@SpringBootTest
public class ModuleTest {
    @Autowired
    private RandomGenerator generator;
    
    @Test
    public void alphabetGenerateTest(){
        String str = generator.alphabet(10);
        System.out.println("str = " + str);
        
        assertEquals(str.length(), 10);
    }
}

@Autowired를 사용하여 @Component로 등록한 RandomGenerator 클래스를 주입하여 테스트를 수행하고 있다. 따라서 해당 테스트가 성공했다면 프로젝트 내에서 RandomGeneartor 클래스를 주입하여 사용하는 것에 문제가 없다는 것을 확신할 수 있다.

컨트롤러 테스트

컨트롤러를 테스트하기 위해서는 Mock MVC 설정이 이루어져야 한다. Spring Boot에서는 Spring Legacy와 다르게 자동화 설정을 지원한다.

Spring Legacy에 대한 내용은 다음 문서를 참고한다.

컨트롤러 생성

다음과 같이 요청을 처리할 수 있는 컨트롤러를 생성한다. View 는 사용하지 않는다.

@Controller
public class DummyController {
    
    @Autowired
    private RandomGenerator generator;
    
    @GetMapping("/random-string")
    @ResponseBody
    public String randomString(){
        return generator.alphabet(10);
    } 
    
}

해당 컨트롤러의 정상 작동 여부를 테스트하려면 브라우저를 열고 주소를 입력하거나 Spring Boot Test를 사용할 수 있다.

테스트 생성

테스트 클래스를 통해 컨트롤러를 테스트하고 싶을 경우 추가적으로 @AutoConfigureMockMvc 애노테이션을 클래스에 설정해야 한다. 설정하면 자동으로 테스트가 가능한 MockMvc 클래스의 객체를 등록해주며, 이를 주입하여 사용할 수 있다.

@SpringBootTest
@AutoConfigureMockMvc
public class ControllerTest {
    
    @Autowired
    private MockMvc mockMvc;
    
    @Test
    public void requestTest(){
        mockMvc.perform(get("/generate-string"))
                .andExpect(status().is2xxSuccessful())
                .andDo(print())
                .andReturn();
    }
    
}

MockMvc에 대한 명령 설명은 다음 문서를 참조한다.

PreviousLoggingNextLombok

Last updated 2 years ago

Assert 단정문
MockMvc Test
JUnit 5
MockMvc 명령 정리
Logo