-
Notifications
You must be signed in to change notification settings - Fork 8
테스트 전략 및 CI 설정
MYONG JAEWI edited this page Jul 26, 2024
·
5 revisions
- 테스트 이유: 컴포넌트의 독립적인 UI 테스트를 위해서
- 테스트 도구:
Storybook
- 테스트 이유: 각 기능을 작은 단위로 테스트하여 명확하고 예측 가능한 동작 확인을 위해서
- 테스트 도구:
jest
+RTL
- 테스트 이유: 개발 환경에서 mock data 사용하기 위해서, 서버 개발 정도에서 벗어나 독립적으로 테스트 하기 위해서
- 테스트 도구:
MSW
- 코드 품질 보장
- 개발자가 작성한 코드가 의도대로 정확히 작동하며, 전체 소스 코드 베이스와 원활하게 통합되는지 확인합니다.
- 인적 오류 최소화
- 수동으로 테스트를 실행하고 풀 리퀘스트를 생성하는 과정에서 발생할 수 있는 인적 오류를 방지합니다.
=> 코드 변경사항에 대한 자동화된 테스트 실행을 통해 견고한 '안전망'을 구축하기 위해 CI 설정
- 각 브랜치 간 통합되기 이전 Github Action
으로 타입 체킹과 테스트를 자동으로 실행시킨다.
- 전체 소스 코드의 병합은 오로지 PR을 통해서만 이루어지기 때문에 Github Action
으로도 충분하다고 판단
name: Frontend CI
on:
pull_request:
branches:
- '**'
jobs:
build-with-test:
runs-on: ubuntu-latest
env:
frontend-directory: ./frontend
steps:
- uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install Dependencies
run: npm install
working-directory: ${{ env.frontend-directory }}
- name: Run Type Checking
run: npm run tsc
working-directory: ${{ env.frontend-directory }}
- name: Run Tests
run: npm run test
working-directory: ${{ env.frontend-directory }}
- 백엔드 코드 컨벤션
- 백엔드 기술 스택 및 선정 이유
- 각종 인스턴스 설정 파일 및 구성 위치 가이드
- ERD (24.09.27)
- 백엔드 CI CD 동작 프로세스
- 로컬 DB 환경 설정
- 백엔드 로깅 전략
- 백엔드 로그 모니터링 구성도
- 스프링 메트릭 모니터링 구성도
- Flyway 로 스키마 관리
- 코드잽 서버 구성도
- Git Submodule 사용 메뉴얼
- 프론트엔드 코드 컨벤션
- 프론트엔드 기술 스택 및 선정 이유
- 프론트엔드 서비스 타겟 환경 및 브라우저 지원 범위 선정
- 프론트엔드 모니터링 및 디버깅 환경 구축
- 프론트엔드 테스트 목록
- 프론트엔드 라이브러리 기술 검토
- 프론트엔드 개발서버, 운영서버 빌드 및 배포 환경 구분
- 목표했던 타겟 환경과 디바이스에서 서비스 핵심 기능 동작 확인
- 프론트엔드 접근성 개선 보고서
- EC2 로그 확인 방법
- VSCode를 통한 EC2 인스턴스 SSH 연결 방법
- 터미널을 통한 EC2 인스턴스 SSH 연결 방법
- NGINX 설정 파일 접근 및 적용 방법
- DB 접속 및 백업 방법
- [QA] 배포 전 체크리스트
- CI 파이프라인 구축
- CD 파이프라인 구축
- 백엔드 CI CD 트러블슈팅
- Lombok Annotation Processor 의존성을 추가한 이유
- 2차 스프린트 기준 ERD
- DTO 검증하기
- ProblemDetail
- Fork된 레포지토리 PR에서 CI Secrets 접근 문제 해결
- AWS CloudWatch 모니터링
- 스프링 메트릭 모니터링 구축 방법
- 로깅과 Logback에 대해 알아보아요.
- 백엔드 CD 파이프라인 Ver.2
- 요청, 응답 로그에 correlationId 를 추가하자!
- 3차 스프린트 기준 ERD
- 더미데이터 생성하고 실행하기
- 쿼리 성능 개선 결과
- 테이블별 인덱스 설정 목록
- 사용자 증가 시 발생할 수 있는 문제 상황과 개선 방안
- k6를 사용한 서버 부하 테스트
- 6차 스프린트 기준 ERD
- Query Performance Improvement Results
- 테스트 전략 및 CI 설정
- CI CD 구조
- 배포 전, 로컬에서 로그인 기능 포함 테스트해보는 법
- stylelint 적용기
- 내 작업 브랜치 중간에 Merge된 동료의 작업물을 넣고 싶다면 pull vs rebase
- [TS] Webpack config
- [TS] Webpack 환경에서 MSW v2 이슈
- [TS] webpack에서 react‐router‐dom 적용 안됨
- 2024.07.28 새 기획 회의
- 2024.07.26 2차 데모데이 후 회의
- 2024.07.11 백엔드 논의 좀 할게요
- 2024.07.11 백엔드 ERD 회의
- 2024.07.09 깃 브랜치 전략, PR 템플릿 회의
- 2024.07.03 주제 선정 회의
- 2023.07.03 팀빌딩데이 킥오프 회의
- 2023.08.07 3차 스프린트 중간회고