일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 리액트 렌더링 최적화
- 실행컨텍스트
- 자바스크립트 엔진 v8
- 함수형 프로그래밍 특징
- 항해99 부트캠프
- JS module system
- this
- 리액트
- js배열 알고리즘
- gql restapi 차이
- 항해99 미니프로젝트
- Js module
- FP 특징
- next js
- 타입스크립트
- 렌더링 최적화
- 알고리즘
- 항해99
- 리덕스
- 항해99 사전스터디
- toggle-btn
- jwt
- v8 원리
- 코어자바스크립트
- 웹팩 기본개념
- 테스트 코드 툴 비교
- 웹 크롤링
- 리액트 메모이제이션
- 리액트 메모
- chromatic error
- Today
- Total
Jaeilit
nextjs @svgr/webpack jest + @issue 해결 본문
@svg/webpack 으로 react compoent 로 svg 를 사용하고 있었는데 jest testing 하려니까 이런 에러가 발생했다.
에러 내용은 import 를 잘못했다는 내용이다.
첫번째 시도 - 구글링
@icons/ 경로로 tsconfig 에서 path 를 매핑해서 쓰고있었는데 이게 문젠가 싶어서 jest config 에서 moduleNameMapper 부분을 여러번 수정해봤지만 이건 아니였다.
tsconfig
"paths": {
"@/*": ["./src/*"],
"@icons/*": ["./public/images/*"]
}
jestconfig
moduleNameMapper: {
...,
"^@icons/(.*)$": "<rootDir>/public/images/$1",
},
두번째 시도 - git issue
svgr 레포에 git issue 를 찾아봤는데 나랑 똑같은 이슈를 겪는 사람들이 많았다.
https://github.com/gregberge/svgr/issues/83
이슈에 대한 테스트를 한 다른 개발자의 글
https://github.com/gregberge/svgr/issues/83#issuecomment-1120763572
차이
// "\\.svg": "<rootDir>/__mocks__/svgrMock.tsx", // .svg 확장자 검색
"^.+\\.(svg)$": "<rootDir>/__mocks__/svgrMock.tsx", // .svg 문자열을 검색
첫번째 정규식은 .svg 가 문자열이 포함되어있으면 검색이 가능하고
두번째 정규식은 ^ 문자열로 시작해서 .svg 라는 문자열로 끝나야해서 정확하게 .svg 파일을 검색하는 정규식이라고 할 수 있지만
정확히 왜 success/ fail 인지는 알지못했다.
첫번째 예상은 svgr 로 react-compoentns 로 변환했을 때는 브라우저에서 svg 태그로 변환되어있어서라고 생각했는데
저 두개의 정규식은 확장자를 검색하는 정규식이지 svg 태그는 검색하지 못하니 이 예상은 아니다.
두번째 예상은 svg 태그의 xmls 이라는 svg 태그 내부의 url같은 것인데 이것 또한 http://www.w3.org/2000/svg 이런식이기 때문에 저 두개의 정규식 어디에도 검색되지 못한다.
정확한 이유는 알지못했으나 일단 이슈는 해결되었다..
svg + r 의 조합으로 svg to react 라는 뜻으로
@svgr/webpack 는 빌드시에 svg 파일을 리액트 컴포넌트처럼 사용하게 도와준다.
https://react-svgr.com/docs/what-is-svgr/
jest.config.js
// jest.config.js
moduleNameMapper: {
"\\.svg": "<rootDir>/__mocks__/svgrMock.tsx",
}
svg 파일을 처리하는 방법에 대해서 매핑을 해줘야한다.
Jest는 테스트할 때 일반적으로 모듈을 모킹(mocking)하여 테스트 환경을 구축합니다.
모킹은 특정 모듈의 실제 구현을 대체하여 테스트에 더 작합한 환경을 만들기 위해 사용됩니다.
예를들어 "\\.svg" 는 .svg 확장자를 가진 파일은 __mocks__/svgMock.tsx 을 모킹하라는 뜻이이다.
nextjs 공식문서에도 jest testing 관련하여 fileMock.js 를 활용하는 예제도 있습니다.
https://nextjs.org/docs/pages/building-your-application/optimizing/testing
그럼 svgrMock.tsx 을 작성해보면 이렇게 svg component 를 모킹하게끔 작성할수있습니다.
import React, { SVGProps } from "react";
const SvgrMock = React.forwardRef<SVGSVGElement, SVGProps<SVGSVGElement>>(
(props, ref) => <svg ref={ref} {...props} />
);
SvgrMock.displayName = "SvgrMock";
export const ReactComponent = SvgrMock;
export default SvgrMock;
사실 이렇게 작성하지 않고
// export const ReactComponent = "span"; // tag name
// export default ReactComponent;
이렇게 작성하더라도 테스트는 통과한다.
여기 같은 경우는 ReactComponent 에 span 이 아닌 spansss 이런 없는 태그를 적으면 테스트는 통과하지만 에러를 내뱉게 된다.
그리고 디버깅에 <spanss/> 가 생긴걸 볼 수 있다. 이상한걸 모킹했다는 뜻이다.
모킹한다는건 진짜 객체를 가짜 객체로 대체한다는거고 위의 svgrMock.tsx 에 모킹할 가짜 객체를 정의하는건데,
첫번째는 svg 를, 두번째는 span 태그를 적어줬다.
이 svg 컴포넌트에 대한 더 상세한 테스트가 필요한 경우 모킹을 하더라도 svg 태그로 해주는게 맞다.
'TIL' 카테고리의 다른 글
JS - Module System (0) | 2023.08.20 |
---|---|
프론트엔드 테스트 종류와 비교 (0) | 2023.07.28 |
프로그래밍 패러다임 (0) | 2023.07.09 |
Nextjs v13.4 Error: connect ECONNREFUSED 127.0.0.1:3001 에러해결 (0) | 2023.06.14 |
리액트 재조정과 가상돔 (0) | 2023.06.08 |