Sunday, May 12, 2024
 Popular · Latest · Hot · Upcoming
113
rated 0 times [  116] [ 3]  / answers: 1 / hits: 36914  / 5 Years ago, mon, february 11, 2019, 12:00:00

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.


More From » jestjs

 Answers
42

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.


[#52619] Wednesday, February 6, 2019, 5 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
devonw

Total Points: 311
Total Questions: 116
Total Answers: 111

Location: Senegal
Member since Fri, Aug 21, 2020
4 Years ago
;