"SyntaxError: Cannot use import statement outside a module" when writing test with typescript with lit-html
"SyntaxError: Cannot use import statement outside a module" when writing test with typescript with lit-html
我用打字稿写了一个简单的演示 lit-html:
import {html, TemplateResult} from 'lit-html';
export default function sayHello(name: string): TemplateResult {
return html`<h1>Hello ${name}</h1>`;
}
并使用 jest 编写一些简单的测试:
import sayHello from "./sayHello";
import {render} from "lit-html";
beforeEach(() => {
render('', document.body);
})
describe('sayHello', () => {
it('says hello', () => {
render(sayHello('world'), document.body);
const component = document.querySelector('h1');
expect(component).toBeDefined();
})
})
我的"jest.config.js"是:
module.exports = {
preset: 'ts-jest',
testEnvironment: 'jsdom',
}
但是当我 运行 使用 jest
进行测试时,我得到了这样的错误:
FAIL src/sayHello.test.ts
● Test suite failed to run
Jest encountered an unexpected token
This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain JavaScript.
By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".
Here's what you can do:
• 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/en/configuration.html
Details:
/workspace/typescript-webpack-lit-html-jest-test-demo/node_modules/lit-html/lit-html.js:31
import { defaultTemplateProcessor } from './lib/default-template-processor.js';
^^^^^^
SyntaxError: Cannot use import statement outside a module
> 1 | import {html, TemplateResult} from 'lit-html';
| ^
2 |
3 | export default function sayHello(name: string): TemplateResult {
4 | return html`<h1>Hello ${name}</h1>`;
at Runtime._execModule (node_modules/jest-runtime/build/index.js:1166:56)
at Object.<anonymous> (src/sayHello.ts:1:1)
at Object.<anonymous> (src/sayHello.test.ts:1:1)
Test Suites: 1 failed, 1 total
Tests: 0 total
Snapshots: 0 total
Time: 1.339 s
Ran all test suites.
error Command failed with exit code 1.
原因应该是"node_modules"node_modules/lit-html/lit-html.js
中的文件使用了es模块,jest处理不好
各种配置都试过了,还是不行,求大神帮忙,谢谢
这个问题的一个小而完整的演示项目:https://github.com/freewind-demos/typescript-webpack-lit-html-jest-test-demo
默认情况下 Jest 不会转换 /node_modules/
(docs)。为了让它工作,你可以像这样改变你的配置
点亮 2.0
还有@lit命名空间的包也需要改造:
@lit/reactive-element
所以在正则表达式中添加可选的 @
就可以完成工作
jest.config.js
module.exports = {
// ...
transformIgnorePatterns: ["node_modules/(?!\@?lit)"],
}
ts-jest >27.x
config: remove support for tsConfig option (#2127) (3cc9b80)
应该使用小写 tsconfig
而不是 tsConfig
jest.config.js
module.exports = {
preset: "ts-jest",
testEnvironment: "jsdom",
transform: {
// transform files with ts-jest
"^.+\.(js|ts)$": "ts-jest",
},
transformIgnorePatterns: [
// allow lit-html transformation
"node_modules/(?!lit-html)",
],
globals: {
"ts-jest": {
tsconfig: {
// allow js in typescript
allowJs: true,
},
},
},
};
working GitHub setup(带有“ts-jest”:“27.0.3”)
ts-笑话<27.x
jest.config.js
module.exports = {
preset: "ts-jest",
testEnvironment: "jsdom",
transform: {
// transform files with ts-jest
"^.+\.(js|ts)$": "ts-jest",
},
transformIgnorePatterns: [
// allow lit-html transformation
"node_modules/(?!lit-html)",
],
globals: {
"ts-jest": {
tsConfig: {
// allow js in typescript
allowJs: true,
},
},
},
};
working GitHub setup(修复分支)
我用打字稿写了一个简单的演示 lit-html:
import {html, TemplateResult} from 'lit-html';
export default function sayHello(name: string): TemplateResult {
return html`<h1>Hello ${name}</h1>`;
}
并使用 jest 编写一些简单的测试:
import sayHello from "./sayHello";
import {render} from "lit-html";
beforeEach(() => {
render('', document.body);
})
describe('sayHello', () => {
it('says hello', () => {
render(sayHello('world'), document.body);
const component = document.querySelector('h1');
expect(component).toBeDefined();
})
})
我的"jest.config.js"是:
module.exports = {
preset: 'ts-jest',
testEnvironment: 'jsdom',
}
但是当我 运行 使用 jest
进行测试时,我得到了这样的错误:
FAIL src/sayHello.test.ts
● Test suite failed to run
Jest encountered an unexpected token
This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain JavaScript.
By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".
Here's what you can do:
• 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/en/configuration.html
Details:
/workspace/typescript-webpack-lit-html-jest-test-demo/node_modules/lit-html/lit-html.js:31
import { defaultTemplateProcessor } from './lib/default-template-processor.js';
^^^^^^
SyntaxError: Cannot use import statement outside a module
> 1 | import {html, TemplateResult} from 'lit-html';
| ^
2 |
3 | export default function sayHello(name: string): TemplateResult {
4 | return html`<h1>Hello ${name}</h1>`;
at Runtime._execModule (node_modules/jest-runtime/build/index.js:1166:56)
at Object.<anonymous> (src/sayHello.ts:1:1)
at Object.<anonymous> (src/sayHello.test.ts:1:1)
Test Suites: 1 failed, 1 total
Tests: 0 total
Snapshots: 0 total
Time: 1.339 s
Ran all test suites.
error Command failed with exit code 1.
原因应该是"node_modules"node_modules/lit-html/lit-html.js
中的文件使用了es模块,jest处理不好
各种配置都试过了,还是不行,求大神帮忙,谢谢
这个问题的一个小而完整的演示项目:https://github.com/freewind-demos/typescript-webpack-lit-html-jest-test-demo
默认情况下 Jest 不会转换 /node_modules/
(docs)。为了让它工作,你可以像这样改变你的配置
点亮 2.0
还有@lit命名空间的包也需要改造:
@lit/reactive-element
所以在正则表达式中添加可选的 @
就可以完成工作
jest.config.js
module.exports = {
// ...
transformIgnorePatterns: ["node_modules/(?!\@?lit)"],
}
ts-jest >27.x
config: remove support for tsConfig option (#2127) (3cc9b80)
应该使用小写 tsconfig
而不是 tsConfig
jest.config.js
module.exports = {
preset: "ts-jest",
testEnvironment: "jsdom",
transform: {
// transform files with ts-jest
"^.+\.(js|ts)$": "ts-jest",
},
transformIgnorePatterns: [
// allow lit-html transformation
"node_modules/(?!lit-html)",
],
globals: {
"ts-jest": {
tsconfig: {
// allow js in typescript
allowJs: true,
},
},
},
};
working GitHub setup(带有“ts-jest”:“27.0.3”)
ts-笑话<27.x
jest.config.js
module.exports = {
preset: "ts-jest",
testEnvironment: "jsdom",
transform: {
// transform files with ts-jest
"^.+\.(js|ts)$": "ts-jest",
},
transformIgnorePatterns: [
// allow lit-html transformation
"node_modules/(?!lit-html)",
],
globals: {
"ts-jest": {
tsConfig: {
// allow js in typescript
allowJs: true,
},
},
},
};
working GitHub setup(修复分支)