Dre*_*ens 18 javascript jenkins jestjs
我有一个具有Jest测试的React应用程序.我在我的配置Jest package.json:
…
"jest": {
"setupEnvScriptFile": "./test/jestenv.js",
"setupTestFrameworkScriptFile": "./test/setup-jasmine-env.js",
"testRunner": "node_modules/jest-cli/src/testRunners/jasmine/jasmine2.js",
"unmockedModulePathPatterns": [
"./node_modules/q",
"./node_modules/react"
]
},
…
Run Code Online (Sandbox Code Playgroud)
该setup-jasmine-env.js如下所示:
var jasmineReporters = require('jasmine-reporters');
jasmine.VERBOSE = true;
jasmine.getEnv().addReporter(
new jasmineReporters.JUnitXmlReporter({
consolidateAll: true,
savePath: "output/",
filePrefix: "test-results"
})
);
Run Code Online (Sandbox Code Playgroud)
我花了一些工作来正确设置茉莉花环境,但是我没有在output目录中看到任何东西(事实上,它没有被创建并且自己创建并没有帮助.)我怀疑我对jasminevar的改动与Jest使用的不一样,但我无法弄清楚如何将它们连接在一起.
小智 7
如果您使用更新版本的jest(我正在查看16.0.2),则无需指定,testrunner因为jasmine是默认值.您也不需要unmockedModulePathPatternsjest配置的部分.
即你只需要devDependencies在你的内容中加入以下内容package.json:
"jasmine-reporters": "^2.2.0",
"jest": "^16.0.2",
"jest-cli": "^16.0.2"
Run Code Online (Sandbox Code Playgroud)
并将此jest配置添加到您的package.json(注意:您不再需要该unmockedModulePathPatterns部分):
"jest": {
"setupTestFrameworkScriptFile": "./setup-jasmine-env.js"
}
Run Code Online (Sandbox Code Playgroud)
然后setup-jasmine-env.js从问题中使用Drew's .
小智 6
Jest通过testResultsProcessor配置支持自己的记者.所以我写了一个小东西,为此生成兼容的junit xml.你可以在这里找到它.https://github.com/palmerj3/jest-junit
看起来上面的设置中您缺少的只是添加jasmine-reporters到unmockedModulePathPatterns,所以请尝试以下操作:
"jest": {
...
"unmockedModulePathPatterns": [
"./node_modules/q",
"./node_modules/react",
"./node_modules/jasmine-reporters"
]
},
Run Code Online (Sandbox Code Playgroud)
希望有帮助!
更新:对于遇到此问题的其他人,我在这里放置了一个工作演示。
| 归档时间: |
|
| 查看次数: |
10219 次 |
| 最近记录: |