Reflect.getOwnMetadata 不是 karma-typescript 的函数
Reflect.getOwnMetadata is not a function with karma-typescript
我正在尝试对我的 TypeScript 项目进行单元测试(使用 Karma + Jasmine + karma-typescript)。项目结构如下:
root
|- src/*.ts //all TypeScript source files
|- tests/unit/*.spec.ts //all spec (test) files
|- karma.conf.js
|- tsconfig.json
我的 karma.conf.js
如下所示:
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', "karma-typescript"],
karmaTypescriptConfig: {
tsconfig: "./tsconfig.json"
},
files: [
'src/*.ts',
'tests/**/*Spec.ts'
],
exclude: [],
preprocessors: {
"**/*.ts": ["karma-typescript"]
},
reporters: ["progress", "karma-typescript"],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false,
concurrency: Infinity
})
}
我的规范文件如下所示:
import 'aurelia-polyfills'; //<- importing this, as the project have dependency on Aurelia
// import "babel-polyfill";
import "reflect-metadata";
import "jasmine";
import { Utility } from './../../src/Utility';
describe("this is a try to set up karma-jasmine-webpack test (TS)", () => {
it("utility_test", () => {
const result = Utility.doSomething();
const expected = Expected_Result;
expect(result).toEqual(expected);
});
});
但是当我 运行 karma start
时,我得到
Chrome 55.0.2883 (Windows 10 0.0.0) ERROR
Uncaught TypeError: Reflect.getOwnMetadata is not a function
at C:/Users/spal/AppData/Local/Temp/karma-typescript-bundle-16376WqjdFvsYtjdI.js:2325
我想,这是因为 pollyfillis/are 没有在浏览器中加载。但是,我的规范文件中有 import
ed aurelia-pollyfills
。
请建议如何更正此问题。
更新: 任何正在寻找答案的人,可能还会遇到来自 karma-remap-istanbul
的源映射 (Error: Could not find source map for:''
) 试图生成覆盖率报告的问题。
避免此问题的一种方法是简单地删除有问题的记者插件。例如,将 reporters: ['mocha', 'coverage', 'karma-remap-istanbul']
更改为 reporters: ['mocha', 'coverage']
。
其他解决方案是生成源映射。如果您无法在 tsconfig.json
中指定相同的内容,则可以在 karma.conf.js
中指定,如果您使用的是 karma-typescript
:
karmaTypescriptConfig: {
tsconfig: "./tsconfig.json",
compilerOptions: {
sourceMap: true
}
}
最后,我得到了 reporters: ["mocha", "karma-typescript"]
,因为它显示了哪个测试通过了,哪个测试失败了,并生成了覆盖率报告。
您可能缺少 reflect-metadata
导入:
$ npm install --save-dev reflect-metadata
然后将以下内容添加到您的files
:
files: [
{ pattern: "node_modules/reflect-metadata/Reflect.js", include: true },
{ pattern: "src/*.ts", include: true },
{ pattern: "tests/**/*Spec.ts", include: true }
]
我正在尝试对我的 TypeScript 项目进行单元测试(使用 Karma + Jasmine + karma-typescript)。项目结构如下:
root
|- src/*.ts //all TypeScript source files
|- tests/unit/*.spec.ts //all spec (test) files
|- karma.conf.js
|- tsconfig.json
我的 karma.conf.js
如下所示:
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', "karma-typescript"],
karmaTypescriptConfig: {
tsconfig: "./tsconfig.json"
},
files: [
'src/*.ts',
'tests/**/*Spec.ts'
],
exclude: [],
preprocessors: {
"**/*.ts": ["karma-typescript"]
},
reporters: ["progress", "karma-typescript"],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false,
concurrency: Infinity
})
}
我的规范文件如下所示:
import 'aurelia-polyfills'; //<- importing this, as the project have dependency on Aurelia
// import "babel-polyfill";
import "reflect-metadata";
import "jasmine";
import { Utility } from './../../src/Utility';
describe("this is a try to set up karma-jasmine-webpack test (TS)", () => {
it("utility_test", () => {
const result = Utility.doSomething();
const expected = Expected_Result;
expect(result).toEqual(expected);
});
});
但是当我 运行 karma start
时,我得到
Chrome 55.0.2883 (Windows 10 0.0.0) ERROR
Uncaught TypeError: Reflect.getOwnMetadata is not a function
at C:/Users/spal/AppData/Local/Temp/karma-typescript-bundle-16376WqjdFvsYtjdI.js:2325
我想,这是因为 pollyfillis/are 没有在浏览器中加载。但是,我的规范文件中有 import
ed aurelia-pollyfills
。
请建议如何更正此问题。
更新: 任何正在寻找答案的人,可能还会遇到来自 karma-remap-istanbul
的源映射 (Error: Could not find source map for:''
) 试图生成覆盖率报告的问题。
避免此问题的一种方法是简单地删除有问题的记者插件。例如,将 reporters: ['mocha', 'coverage', 'karma-remap-istanbul']
更改为 reporters: ['mocha', 'coverage']
。
其他解决方案是生成源映射。如果您无法在 tsconfig.json
中指定相同的内容,则可以在 karma.conf.js
中指定,如果您使用的是 karma-typescript
:
karmaTypescriptConfig: {
tsconfig: "./tsconfig.json",
compilerOptions: {
sourceMap: true
}
}
最后,我得到了 reporters: ["mocha", "karma-typescript"]
,因为它显示了哪个测试通过了,哪个测试失败了,并生成了覆盖率报告。
您可能缺少 reflect-metadata
导入:
$ npm install --save-dev reflect-metadata
然后将以下内容添加到您的files
:
files: [
{ pattern: "node_modules/reflect-metadata/Reflect.js", include: true },
{ pattern: "src/*.ts", include: true },
{ pattern: "tests/**/*Spec.ts", include: true }
]