Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

jest unexpected token when importing css

I got error of SyntaxError: Unexpected token .

in my code

import 'react-dates/lib/css/_datepicker.css' 
import 'semantic-ui-css/semantic.min.css' 

those isn't in my spec.js but my implementation code, any clue why? I have no problem running my app but jest throw error when I try to run test.

like image 211
Neini Amanda Avatar asked Feb 11 '19 09:02

Neini Amanda


2 Answers

The problem is that Jest is hitting these CSS imports and trying to parse them as if they were JavaScript.

The "Unexpected token ." message probably comes because the first line of the file it is choking on is a CSS class declaration, i.e. .datepicker: { ... }.

Anyway, as pointed out in this answer, the way to get around this is to create a file containing a module which exports an empty object. I called mine styleMock.js.

module.exports = {}; 

Then, you need to create a jest.config.js file in your project root and add:

module.exports = {   moduleNameMapper: {     '\\.(css|less)$': '<rootDir>/test/jest/__mocks__/styleMock.js',   } }; 

The moduleNameMapper setting tells Jest how to interpret files with different extensions. In this case we simply need to point it at the empty file we just created. Obviously adjust the path to your file accordingly.

And note that you can expand the regex above for whichever file endings you need. Mine looks like:

moduleNameMapper: {   '\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$':     '<rootDir>/test/jest/__mocks__/fileMock.js',   '\\.(css|less)$': '<rootDir>/test/jest/__mocks__/styleMock.js', }, 

where fileMock.js is identical to styleMock.js

Alternatively, you could use a module such as jest-transform-stub, which does the same thing for you.

like image 85
James Hibbard Avatar answered Sep 25 '22 13:09

James Hibbard


For anyone hitting this question in fall 2020 or later, for an error like SyntaxError: Invalid or unexpected token when Jest parses CSS files: True, the error is due to Jest trying to parse the CSS as JavaScript, which wont work. So the updated way to handle this is 3 steps, per the Jest documentation on handling static assets, but you dont need to add an additional package like identity-obj-proxy as @chitra suggested unless you're using CSS Modules. And to contrast @james-hibbard 's suggestions: the fileMock.js now looks slightly different and you don't need to create a jest.config.js .

1 in your package.json add this

{   "jest": {     "moduleNameMapper": {       "\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/__mocks__/fileMock.js",       "\\.(css|less)$": "<rootDir>/__mocks__/styleMock.js"     }   } } 

2 Then create the following two files:

// __mocks__/styleMock.js  module.exports = {}; 

3

// __mocks__/fileMock.js  module.exports = 'test-file-stub'; 

That should fix these specific errors when Jest runs like

SyntaxError: Invalid or unexpected token > 1 | import '../src/css/console.scss'; 
like image 43
Cat Perry Avatar answered Sep 22 '22 13:09

Cat Perry