Written on
·
303
1
지금 저희가 하는 코드에서
7분07초쯤 expected가 1밖에 될 수 없는건가요?
Answer 1
2
안녕하세요. alrnr3521님, 공식 서포터즈 OMG입니다.
네, 반드시 1개일 수 밖에 없습니다.
이유는 OrderServiceTest코드 상단에 @Transactional이 해당 테스트 종료 후 롤백을 하기 때문에
다른 테스트 데이터로 인한 주문이 생성될 수 없고,
테스트 실행하게 되면, 아래 로그에서 확인할 수 있듯 테이블을 drop하고 새로 생성하여 데이터가 없는 '무' 상태 이기 때문에 상품주문 테스트의 주문 데이터 1건이 최초 주문 건이 됩니다.
@RunWith(SpringRunner.class)
@SpringBootTest
@Transactional
public class OrderServiceTest {
@Autowired EntityManager em;
@Autowired OrderService orderService;
@Autowired OrderRepository orderRepository;
@Test
public void 상품주문() throws Exception {
//given
Member member = createMember();
Book book = createBook("시골 JPA", 10000, 10);
int orderCount = 2;
//when
Long orderId = orderService.order(member.getId(), book.getId(), orderCount);
//then
Order getOrder = orderRepository.findOne(orderId);
assertEquals("상품 주문시 상태는 ORDER", OrderStatus.ORDER, getOrder.getStatus());
assertEquals("주문한 상품 종류 수가 정확해야 한다.", 1, getOrder.getOrderItems().size());
assertEquals("주문 가격은 가격 * 수량이다.", 10000 * orderCount, getOrder.getTotalPrice());
assertEquals("주문 수량만큼 재고가 줄어야 한다.", 8, book.getStockQuantity());
}
테스트 전용 yml 혹은 properties 설정 파일을 생성하고, ddl-auto를 none으로 한다면 기존에 데이터가 있는 테이블과 연동하여 주문이 등록되면서 테이블을 삭제되지 않는 테스트 또한 가능합니다.
감사합니다.