Files
sodalive-backend-spring-boot/docs/20260325_회원차단요청id만적용.md

2.5 KiB

20260325 회원 차단 요청 id만 적용

  • memberBlock 호출 흐름 및 동일 auth 일괄 차단 지점 확인
  • memberBlock 로직을 request.id 단일 차단으로 수정
  • 관련 테스트 보강 및 회귀 검증
  • LSP 진단, 테스트, 빌드 검증 수행

2차 수정 체크리스트

  • MemberService.memberBlock 의미 단위 주석 추가
  • MemberServiceCacheEvictionTest 신규 테스트 의미 단위 주석 추가
  • 테스트 및 빌드 재검증

검증 기록

1차 구현

  • 무엇을: MemberService.memberBlock에서 동일 auth 기반 다중 계정 확장 차단을 제거하고, request.blockMemberId 1건만 차단/재활성화하도록 수정했다.
  • 왜: 회원 차단 API가 요청한 대상 ID만 차단해야 하며, 동일 auth 계정 전체가 함께 차단되는 과차단 동작을 제거해야 하기 때문이다.
  • 어떻게:
    • 탐색: explore 2개 + librarian 1개 백그라운드 분석, grep/ast-grep/glob로 호출 흐름과 확장 지점 확인.
    • 코드 변경: src/main/kotlin/kr/co/vividnext/sodalive/member/MemberService.ktmemberBlock에서 authRepository.getMemberIdsByNameAndBirthAndDiAndGender(...) 및 다중 루프 제거.
    • 테스트 변경: src/test/kotlin/kr/co/vividnext/sodalive/member/MemberServiceCacheEvictionTest.ktshouldBlockOnlyRequestedMemberEvenWhenTargetHasAuth 추가.
    • 진단: lsp_diagnostics 실행 시 .kt LSP 서버 미구성으로 진단 불가 확인.
    • 검증 명령:
      • ./gradlew test --tests "kr.co.vividnext.sodalive.member.MemberServiceCacheEvictionTest" → 성공
      • ./gradlew build → 성공

2차 수정

  • 무엇을: 1차에서 작성한 memberBlock 변경 코드와 회귀 테스트 코드에 의미 단위 주석을 추가했다.
  • 왜: 요청하신 대로 작성된 코드의 의도를 블록 단위로 바로 파악할 수 있도록 하기 위해서다.
  • 어떻게:
    • 코드 변경: src/main/kotlin/kr/co/vividnext/sodalive/member/MemberService.ktmemberBlock에 검증/단일대상차단/캐시무효화 의도 주석 추가.
    • 코드 변경: src/test/kotlin/kr/co/vividnext/sodalive/member/MemberServiceCacheEvictionTest.ktshouldBlockOnlyRequestedMemberEvenWhenTargetHasAuth에 준비/실행/검증 주석 추가.
    • 진단: lsp_diagnostics 실행 시 .kt LSP 서버 미구성으로 진단 불가 확인.
    • 검증 명령:
      • ./gradlew test --tests "kr.co.vividnext.sodalive.member.MemberServiceCacheEvictionTest" → 성공
      • ./gradlew build → 성공