SonarQube无法读取JavaScript的{lgv.info

时间:2015-11-09 06:52:18

标签: sonarqube sonar-runner isparta

我在我的JavaScript单元测试中使用karma-coverage和isparta-loader来生成lcov.info文件。

但是,当我使用JavaScript Plugin运行SonarQube分析时,不会生成测试覆盖率报告。如果lcov.info包含1个文件的数据,则覆盖率报告不会失败,但如果lcov.info包含2个或更多文件的数据,则它始终会失败:

  

13:43:27.635 INFO - 将结果存储在数据库中       13:43:27.649 DEBUG - 执行org.sonar.batch.phases.GraphPersister       13:43:27.714 DEBUG - 执行org.sonar.batch.index.SourcePersister       13:43:29.852 DEBUG - 在项目上发布信号量:org.sonar.api.resources.Project@6b1e6f8b [id = 7859,key = func.salesorder       NG,qualifier = TRK],带有密钥batch-func.salesorderNG       信息:------------------------------------------------ ------------------------       信息:执行失败       信息:------------------------------------------------ ------------------------       总时间:4:14.804s       最终记忆:23M / 828M       信息:------------------------------------------------ --------------------

     

错误:Sonar跑步者执行期间出错       org.sonar.runner.impl.RunnerException:无法执行Sonar               在org.sonar.runner.impl.BatchLauncher $ 1.delegateExecution(BatchLauncher.java:91)               在org.sonar.runner.impl.BatchLauncher $ 1.run(BatchLauncher.java:75)               at java.security.AccessController.doPrivileged(Native Method)               在org.sonar.runner.impl.BatchLauncher.doExecute(BatchLauncher.java:69)               在org.sonar.runner.impl.BatchLauncher.execute(BatchLauncher.java:50)               在org.sonar.runner.api.EmbeddedRunner.doExecute(EmbeddedRunner.java:102)               在org.sonar.runner.api.Runner.execute(Runner.java:100)               在org.sonar.runner.Main.executeTask(Main.java:70)               在org.sonar.runner.Main.execute(Main.java:59)               at org.sonar.runner.Main.main(Main.java:53)引起:java.lang.IllegalStateException:无法保存文件源               在org.sonar.batch.index.SourcePersister.persist(SourcePersister.java:84)               在org.sonar.batch.phases.DatabaseModePhaseExecutor.executePersisters(DatabaseModePhaseExecutor.java:165)               在org.sonar.batch.phases.DatabaseModePhaseExecutor.execute(DatabaseModePhaseExecutor.java:133)               在org.sonar.batch.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:264)               在org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:92)               在org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:77)               在org.sonar.batch.scan.ProjectScanContainer.scan(ProjectScanContainer.java:235)               在org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:230)               在org.sonar.batch.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:220)               在org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:92)               在org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:77)               在org.sonar.batch.scan.ScanTask.scan(ScanTask.java:57)               在org.sonar.batch.scan.ScanTask.execute(ScanTask.java:45)               在org.sonar.batch.bootstrap.TaskContainer.doAfterStart(TaskContainer.java:135)               在org.sonar.api.platform.ComponentContainer.startComponents(ComponentContainer.java:92)               在org.sonar.api.platform.ComponentContainer.execute(ComponentContainer.java:77)               在org.sonar.batch.bootstrap.GlobalContainer.executeTask(GlobalContainer.java:158)               在org.sonar.batch.bootstrapper.Batch.executeTask(Batch.java:95)               在org.sonar.batch.bootstrapper.Batch.execute(Batch.java:67)               在org.sonar.runner.batch.IsolatedLauncher.execute(IsolatedLauncher.java:48)               at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)               at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)               at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)               at java.lang.reflect.Method.invoke(Unknown Source)               在org.sonar.runner.impl.BatchLauncher $ 1.delegateExecution(BatchLauncher.java:87)               ... 9更多引起:java.lang.ArrayIndexOutOfBoundsException:-1               at java.util.ArrayList.elementData(Unknown Source)               at java.util.ArrayList.get(Unknown Source)               在com.google.protobuf.RepeatedFieldBuilder.getBuilder(RepeatedFieldBuilder.java:245)               at org.sonar.server.source.db.FileSourceDb $ Data $ Builder.getLinesBuilder(FileSourceDb.java:2911)               at org.sonar.batch.index.SourceDataFactory.applyLineMeasure(SourceDataFactory.java:183)               at org.sonar.batch.index.SourceDataFactory.applyLineMeasures(SourceDataFactory.java:117)               在org.sonar.batch.index.SourceDataFactory.consolidateData(SourceDataFactory.java:76)               在org.sonar.batch.index.SourcePersister.computeData(SourcePersister.java:152)               at org.sonar.batch.index.SourcePersister.persist(SourcePersister.java:93)               在org.sonar.batch.index.SourcePersister.persist(SourcePersister.java:81)               ......还有33个

lcov.info显示以下信息:

SF:D:\SOC\src\UI\UI.ng\js\general\services\tabStateService.js
FN:3,_interopRequireDefault
FN:11,(anonymous_2)
FN:14,tabStateService
FN:17,moveNext
FNF:4
FNH:4
FNDA:1,_interopRequireDefault
FNDA:1,(anonymous_2)
FNDA:21,tabStateService
FNDA:2,moveNext
DA:0,1
DA:1,1
DA:4,1
DA:5,1
DA:8,1
DA:9,21
DA:10,21
DA:12,2
LF:8
LH:8
BRDA:3,1,0,0
BRDA:3,1,1,1
BRDA:3,2,0,1
BRDA:3,2,1,1
BRF:4
BRH:4
end_of_record
TN:
SF:D:\SOC\src\UI\UI.ng\js\general\services\pagingService.js
FN:5,(anonymous_1)
FN:8,pagingService
FN:14,getPagingParams
FN:20,calculateSkip
FNF:4
FNH:4
FNDA:1,(anonymous_1)
FNDA:23,pagingService
FNDA:11,getPagingParams
FNDA:7,calculateSkip
DA:1,1
DA:3,1
DA:4,1
DA:7,1
DA:9,23
DA:13,1
DA:14,11
DA:15,2
DA:16,9
DA:17,7
DA:18,2
DA:21,1
DA:22,7
LF:13
LH:13
BRDA:15,1,0,2
BRDA:15,1,1,9
BRDA:15,2,0,11
BRDA:15,2,1,9
BRDA:16,3,0,7
BRDA:16,3,1,2
BRDA:16,4,0,9
BRDA:16,4,1,7
BRF:8
BRH:8
end_of_record

1 个答案:

答案 0 :(得分:0)

问题来自lcov.info

的这一行
    DA:0,1

这意味着第0行由单元测试覆盖。 这使分析失败,因为只有严格的正数行。

在这种情况下,有一个ticket可以改善SonarQube的行为。