简体   繁体   English

Jest 遇到了意外的令牌 - SyntaxError: Unexpected token 'export'

[英]Jest encountered an unexpected token - SyntaxError: Unexpected token 'export'

I'm using jest to test a react typescript app.我正在使用 jest 来测试反应 typescript 应用程序。

This is the test I'm running:这是我正在运行的测试:

import { render, screen } from '@testing-library/react'
import { toBeInTheDocument } from '@testing-library/jest-dom'

import ContextProvider from '../../context/ContextProvider'
import { BrowserRouter } from 'react-router-dom'
import BlogPage from './BlogPage'

describe('BlogPage', () => {

  test('Render blog page', () => {
    render(
      <ContextProvider>
        <BrowserRouter>
          <BlogPage/>
        </BrowserRouter>
      </ContextProvider>
    )

    expect(screen.getByText('In this page you can see some of the last articles I wrote.')).toBeInTheDocument()
  })

})

And this is the error I'm getting:这是我得到的错误:

FAIL  src/components/blogPage/BlogPage.test.js
  ● Test suite failed to run

    Jest encountered an unexpected token

    Jest failed to parse a file. This happens e.g. when your code or its dependencies use non-standard JavaScript syntax, or when Jest is not configured to support such syntax.

    Out of the box Jest supports Babel, which will be used to transform your files into valid JS based on your Babel configuration.

    By default "node_modules" folder is ignored by transformers.

    Here's what you can do:
     • If you are trying to use ECMAScript Modules, see https://jestjs.io/docs/ecmascript-modules for how to enable it.
     • If you are trying to use TypeScript, see https://jestjs.io/docs/getting-started#using-typescript
     • To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
     • If you need a custom transformation specify a "transform" option in your config.
     • If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.

    You'll find more details and examples of these config options in the docs:
    https://jestjs.io/docs/configuration
    For information about custom transformations, see:
    https://jestjs.io/docs/code-transformation

    Details:

    /home/German/Desktop/ger/code/projects/my-website/node_modules/react-markdown/index.js:6
    export {uriTransformer} from './lib/uri-transformer.js'
    ^^^^^^

    SyntaxError: Unexpected token 'export'

    > 1 | import ReactMarkdown from 'react-markdown'
        | ^
      2 | import Accordion from 'react-bootstrap/Accordion'
      3 |
      4 | interface Props {

I understand this is because the library I'm using (react-markdown) doesn't have pre-compiled source code.我理解这是因为我使用的库(react-markdown)没有预编译的源代码。 The thing is I followed the docs ( https://jestjs.io/docs/tutorial-react-native#transformignorepatterns-customization ) and added the react-markdown folder to the transformIgnorePatterns config and I still get the error.问题是我遵循了文档( https://jestjs.io/docs/tutorial-react-native#transformignorepatterns-customization )并将react-markdown文件夹添加到transformIgnorePatterns配置中,但仍然出现错误。

This is my jest.config.ts file:这是我的 jest.config.ts 文件:

import type { Config } from '@jest/types'

const config: Config.InitialOptions = {
  verbose: true,
  transform: {
    '^.+\\.ts?$': 'ts-jest'
  },
  transformIgnorePatterns: [
    'node_modules/(?!react-markdown/)'
  ]
}
export default config

I tried adding <rootDir> like <rootDir>/node_modules/(?!react-markdown/) and It didn't make a difference.我尝试添加<rootDir><rootDir>/node_modules/(?!react-markdown/)并没有什么不同。

I also tried configuring jest directly from package.json instead of a jest.config file and It didn't make a difference either.我还尝试直接从 package.json 而不是 jest.config 文件配置 jest,它也没有任何区别。

Then I found this question: Jest transformIgnorePatterns not working , which mentions you need to configure Babel.然后我发现了这个问题: Jest transformIgnorePatterns not working ,里面提到需要配置Babel。

I created my app with create-react-app so I didn't have Babel on my app.我使用 create-react-app 创建了我的应用程序,所以我的应用程序上没有 Babel。 I installed it and created a babel.config.js file inside of wich I put:我安装了它并在其中创建了一个 babel.config.js 文件:

module.exports = {
    "presets": [
        "@babel/preset-env"
    ]
};

But I still get the error... I'm running out of ideas.但我仍然得到错误......我的想法已经不多了。 Any clue of how could I solve this?我该如何解决这个问题的任何线索?

Full code can be found here: https://github.com/coccagerman/my-website完整代码可以在这里找到: https://github.com/coccagerman/my-website

react-markdown is shipped as js, add babel-jest as a transformer in your jest config react-markdown作为 js 发布,在你的 jest 配置中添加babel-jest作为转换器

  transform: {
    '^.+\\.ts?$': 'ts-jest',
    "^.+\\.(js|jsx)$": "babel-jest"
  },

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM