Skip to content

Commit

Permalink
feat: 리뷰 쿼리 성능 테스트를 위한 세팅
Browse files Browse the repository at this point in the history
* 조인을 사용하는 쿼리와 사용하지 않는 쿼리
  • Loading branch information
EunChanNam committed Dec 4, 2023
1 parent f03d439 commit be830c5
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,8 @@ public void addInterceptors(final InterceptorRegistry registry) {
.addExcludePathPattern("/api/users/refresh/*")
.addExcludePathPattern("/api/like/test/clean")
.addExcludePathPattern("/api/like/test/count/**")
.addExcludePathPattern("/api/email/*");
.addExcludePathPattern("/api/email/*")
.addExcludePathPattern("/api/reviews/test/**");

registry
.addInterceptor(pathMatcherInterceptor)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@
import java.util.List;

import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.inq.wishhair.wesharewishhair.global.dto.response.ResponseWrapper;
import com.inq.wishhair.wesharewishhair.review.application.LikeReviewService;
import com.inq.wishhair.wesharewishhair.review.application.dto.response.ReviewResponse;
import com.inq.wishhair.wesharewishhair.review.application.dto.response.ReviewResponseAssembler;
import com.inq.wishhair.wesharewishhair.review.domain.entity.Review;
Expand All @@ -21,19 +23,26 @@
public class ReviewQueryTestController {

private final ReviewQueryDslRepository reviewQueryDslRepository;
private final LikeReviewService likeReviewService;

@Transactional(readOnly = true)
@GetMapping("/join")
public ResponseWrapper<ReviewResponse> withJoin() {
List<Review> reviews = reviewQueryDslRepository.joinWithLikeQuery()
.stream()
.map(ReviewQueryResponse::getReview)
.toList();

return ReviewResponseAssembler.toWrappedReviewResponse(reviews);
}

@Transactional(readOnly = true)
@GetMapping("/no_join")
public ResponseWrapper<ReviewResponse> withoutJoin() {
List<Review> reviews = reviewQueryDslRepository.noJoinQuery();
return ReviewResponseAssembler.toWrappedReviewResponse(reviews);
List<Long> reviewIds = reviews.stream().map(Review::getId).toList();
likeReviewService.getLikeCounts(reviewIds);

return ReviewResponseAssembler.toWrappedReviewResponse(reviews, reviewIds);
}
}

0 comments on commit be830c5

Please sign in to comment.