我有一个具有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" ] }, …
该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" }) );
我花了一些工作来正确设置茉莉花环境,但是我没有在output
目录中看到任何东西(事实上,它没有被创建并且自己创建并没有帮助.)我怀疑我对jasmine
var的改动与Jest使用的不一样,但我无法弄清楚如何将它们连接在一起.
如果您使用更新版本的jest(我正在查看16.0.2),则无需指定,testrunner
因为jasmine是默认值.您也不需要unmockedModulePathPatterns
jest配置的部分.
即你只需要devDependencies
在你的内容中加入以下内容package.json
:
"jasmine-reporters": "^2.2.0", "jest": "^16.0.2", "jest-cli": "^16.0.2"
并将此jest配置添加到您的package.json
(注意:您不再需要该unmockedModulePathPatterns
部分):
"jest": { "setupTestFrameworkScriptFile": "./setup-jasmine-env.js" }
然后setup-jasmine-env.js
从问题中使用Drew's .
Jest通过testResultsProcessor配置支持自己的记者.所以我写了一个小东西,为此生成兼容的junit xml.你可以在这里找到它.https://github.com/palmerj3/jest-junit