Задать вопрос
@souhhhhh

Почему Jest не может распарсить CSS модуля?

import { render, screen } from '@testing-library/react'
import { Button } from "./Button"
describe('Button', () => { 
    test('Button test', () => { 
        render(<Button>TEST</Button>);
        expect(screen.getByText('TEST')).toBeInTheDocument()
    })
})


import { classNames } from '../../../shared/lib/classNames/classNames';
import cls from './Button.module.scss'
import {ButtonHTMLAttributes, FC} from "react";

export enum ThemeButton {
    CLEAR = 'clear',
}

interface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement>{
    className?: string;
    theme?: ThemeButton;
}

export const Button: FC<ButtonProps> = (props) => {
    const {
        className,
        children,
        theme,
        ...otherProps
    } = props;

    return (
        <button
            className={classNames(cls.Button, {[cls[theme]]: true}, [className])}
            {...otherProps}
        >
            {children}
        </button>
    );
};

const config = {
    clearMocks: true,
    testEnvironment: 'jsdom',
    coveragePathIgnorePatterns: ['\\\\node_modules\\\\'],
    moduleDirectories: ['node_modules'],
    moduleFileExtensions: [
      'js',
      'mjs',
      'cjs',
      'jsx',
      'ts',
      'tsx',
      'json',
      'node'
    ],
    "modulePaths": [
      "<rootDir>",
    ],
    testMatch: [
      '<rootDir>src/**/*(*.)@(spec|test).[tj]s?(x)'
    ],
    rootDir: '../../',
    setupFilesAfterEnv: ['<rootDir>config/jest/setupTest.ts'],
    moduleNameMapper: {
    "\\.(scss)$": "identity-obj-proxy"
  }

};

export default config;

.Button {
^

SyntaxError: Unexpected token '.'

1 | import { classNames } from '../../../shared/lib/classNames/classNames';
> 2 | import cls from './Button.module.scss'
  • Вопрос задан
  • 86 просмотров
Подписаться 1 Простой 3 комментария
Пригласить эксперта
Ответы на вопрос 1
bingo347
@bingo347 Куратор тега JavaScript
Crazy on performance...
https://jestjs.io/docs/webpack#handling-static-assets

В обычной сборке у Вас scss файлы собираются бандлером вроде webpack.
А в jest никакого бандлера нет.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы