将源和测试集添加到 sonarqube gradle 配置的正确语法是什么?

What is the correct syntax for adding source and test sets to sonarqube gradle config?

我有一个 jhipster 项目,项目中定义了一个 sonarqube 任务。我们在目录 /src/main/ui/src/... 下构建了一个反应 UI 并在 /src/main/ui/src/test/... 下进行了测试。我们的sonarqube属性如下:

sonarqube {
    properties {
        property "sonar.host.url", "https://our_sonar_server"
        property "sonar.projectKey", "MyProjectGroup:MyProject"
        property "sonar.projectName", "MyProject"
        property "sonar.login", sonarLogin
        property "sonar.password", sonarPassword

        property "sonar.links.scm", "https://mygithub/myProject.git"
        property "sonar.links.scm_dev", "https://mygithub/MyProject.git"
        property "sonar.links.ci", ciLink

        if (pullRequest != null) {
            property "sonar.analysis.mode", "preview"
            property "sonar.github.pullRequest", pullRequest
            property "sonar.github.repository", "MyProjectGroup/MyProject"
            property "sonar.github.oauth", "my_oauth_hash"
            property "sonar.github.endpoint", "https://mygithubapi/v3"
        }
    }
}

我目前,声纳只能拾取标准 /src/main/java 下的 java。我试过添加 属性 "sonar.sources", "src/main/ui/src/*.js" 属性 "sonar.test", "src/main/ui/src/test/**" 以及一些变化。但是,通过调用“./gradlew sonar -Pprod -x test”的 shell 步骤调用它的 jenkin 构建失败,并出现类似 "invalid value" 或类似的错误。我找不到正确语法的示例。

编辑:我能够让声纳构建通过 PR 使用 属性 "sonar.sources", "src/main/ui/src" 属性 "sonar.test", "src/main/ui/src/test"

但是,在声纳服务器上检查项目时,我仍然没有看到任何 java 脚本文件被引用。

合并我最后的编辑后,js 文件出现在 sonarqube 中。 js 测试也出现了,尽管它们没有显示任何覆盖率。只是单元测试的数量和通过的数量。为此可能需要更多配置,但这并不是原始问题的一部分。

在与我的经理交谈后,我们决定将源集缩小到两个子目录,"src/main/ui/src/app" 和 "src/main/ui/src/layouts",这样测试就不会出现在源集下。该文档建议您可以添加逗号分隔列表,因此我创建了一个外部 属性 并在实际 属性:

中引用了那些
ext.jsAppSrc = "src/main/ui/src/app, src/main/ui/src/layout"
ext.jsLayoutSrc = "src/main/ui/src/layout"
ext.jsTest = "src/main/ui/test"
...
property "sonar.sources", jsAppSrc, jsLayoutSrc
property "sonar.test", jsTest

道具评估正确,但声纳任务失败并出现错误 在 org.sonarqube.gradle.SonarQubeProperties.

上找不到参数 [sonar.sources、src/main/ui/src/app、src/main/ui/src/layout 的方法 属性()

然后我重构将逗号分隔列表放在一个 属性 中,然后成功完成。

ext.jsAppSrc = "src/main/ui/src/app, src/main/ui/src/layout"
ext.jsTest = "src/main/ui/test"
...
property "sonar.sources", jsAppSrc
property "sonar.test", jsTest