运行sonarqube分析我的代码时得到NullPointerException

我有一个Jenkins的工作来发布unit testing覆盖(lcov格式)到SonarQube服务器,如问题及其答案中所述。 有时,我在Jenkins控制台日志的node_modules目录中看到以下JavaScript文件exception。

 16:57:15.037 ERROR - Problem while calculating coverage for /var/lib/jenkins/jobs/jenkins-project-name/workspace/project-name/node_modules/js-tokens/test/fixtures/regex.js java.lang.NullPointerException: null at org.sonar.plugins.javascript.lcov.UTCoverageSensor.saveZeroValueForResource(UTCoverageSensor.java:146) [sonar-javascript-plugin-2.9.jar:na] at org.sonar.plugins.javascript.lcov.UTCoverageSensor.saveMeasureFromLCOVFile(UTCoverageSensor.java:128) [sonar-javascript-plugin-2.9.jar:na] at org.sonar.plugins.javascript.lcov.UTCoverageSensor.analyse(UTCoverageSensor.java:85) [sonar-javascript-plugin-2.9.jar:na] at org.sonar.batch.phases.SensorsExecutor.executeSensor(SensorsExecutor.java:58) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.phases.SensorsExecutor.execute(SensorsExecutor.java:50) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.phases.PhaseExecutor.execute(PhaseExecutor.java:98) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:192) [sonar-batch-shaded-5.2.jar:na] at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:100) [sonar-batch-shaded-5.2.jar:na] at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:85) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.scan.ProjectScanContainer.scan(ProjectScanContainer.java:258) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:253) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:243) [sonar-batch-shaded-5.2.jar:na] at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:100) [sonar-batch-shaded-5.2.jar:na] at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:85) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.bootstrap.GlobalContainer.executeAnalysis(GlobalContainer.java:153) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.bootstrapper.Batch.executeTask(Batch.java:110) [sonar-batch-shaded-5.2.jar:na] at org.sonar.batch.bootstrapper.Batch.execute(Batch.java:76) [sonar-batch-shaded-5.2.jar:na] at org.sonar.runner.batch.IsolatedLauncher.execute(IsolatedLauncher.java:48) [sonar-runner-batch8900787800742033772.jar:na] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_79] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) ~[na:1.7.0_79] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.7.0_79] at java.lang.reflect.Method.invoke(Method.java:606) ~[na:1.7.0_79] at org.sonar.runner.impl.BatchLauncher$1.delegateExecution(BatchLauncher.java:87) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.impl.BatchLauncher$1.run(BatchLauncher.java:75) [sonar-runner-dist-2.4.jar:na] at java.security.AccessController.doPrivileged(Native Method) [na:1.7.0_79] at org.sonar.runner.impl.BatchLauncher.doExecute(BatchLauncher.java:69) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.impl.BatchLauncher.execute(BatchLauncher.java:50) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.api.EmbeddedRunner.doExecute(EmbeddedRunner.java:102) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.api.Runner.execute(Runner.java:100) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.Main.executeTask(Main.java:70) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.Main.execute(Main.java:59) [sonar-runner-dist-2.4.jar:na] at org.sonar.runner.Main.main(Main.java:53) [sonar-runner-dist-2.4.jar:na] 

我将node_modules目录添加到排除列表中:

 sonar.exclusions=./project-name/node_modules/**/* sonar.test.exclusions=./project-name/node_modules/**/* 

但是我仍然有时会得到错误。 任何想法有什么不对?

看起来你的情况类似于JavaScript插件2.10版本中已知的已知问题 。 这个版本应该在未来几天内发布。

作为一个解决方法,设置排除如你所做的应该工作。 如果你仍然得到相同的错误,我想你提供的path没有被SonarQube正确parsing:你可以尝试在开始时删除./