sonarqube { properties { property "sonar.projectName", "${projectTitle} :: Web" property "sonar.sources", "src/main/js" property "sonar.exclusions", "src/main/js/**/__tests__/**,src/main/js/**/__mocks__/**,src/main/js/@types/**,src/main/js/helpers/mocks/**,src/main/js/helpers/testUtils.ts,src/main/js/helpers/testMocks.ts" property "sonar.tests", "src/main/js" property "sonar.test.inclusions", "src/main/js/**/__tests__/**" property "sonar.coverage.exclusions", "src/main/js/api/**,src/main/js/**/routes.ts,src/main/js/app/index.ts,src/main/js/app/utils/startReactApp.tsx,src/main/js/components/icons/**" property "sonar.eslint.reportPaths", "eslint-report/eslint-report.json" property "sonar.javascript.lcov.reportPaths", "coverage/lcov.info" } } def webappDir = "${buildDir}/webapp" task yarn_run(type: Exec) { ['config', 'public', 'scripts', 'src', '../sonar-docs/src'].each { inputs.dir(it).withPathSensitivity(PathSensitivity.RELATIVE) } ['babel.config.js', 'package.json', 'tsconfig.json', 'yarn.lock'].each { inputs.file(it).withPathSensitivity(PathSensitivity.RELATIVE) } outputs.dir(webappDir) outputs.cacheIf { true } commandLine osAdaptiveCommand(['npm', 'run', 'build-release']) } build.dependsOn(yarn_run) task "yarn_lint-report-ci"(type: Exec) { // Note that outputs are not relocatable, because contain absolute paths, and that's why inputs are not relativized ['config', 'src/main/js'].each { inputs.dir(it) } ['package.json', 'yarn.lock', 'tsconfig.json', '.eslintrc'].each { inputs.file(it) } outputs.dir('eslint-report') outputs.cacheIf { true } commandLine osAdaptiveCommand(['npm', 'run', 'lint-report-ci']) } task "yarn_validate-ci"(type: Exec) { // Note that outputs are not relocatable, because contain absolute paths, and that's why inputs are not relativized ['config', 'src/main/js'].each { inputs.dir(it) } ['package.json', 'yarn.lock', 'tsconfig.json', '.eslintrc'].each { inputs.file(it) } outputs.dir('coverage') outputs.cacheIf { true } commandLine osAdaptiveCommand(['npm', 'run', 'validate-ci']) } task "yarn_check-ci"(type: Exec) { // Note that outputs are not relocatable, because contain absolute paths, and that's why inputs are not relativized ['config', 'src'].each { inputs.dir(it) } ['package.json', 'yarn.lock', 'tsconfig.json'].each { inputs.file(it) } commandLine osAdaptiveCommand(['npm', 'run', 'check-ci']) } // Check for known vulnerabilities task dependency_audit(type: Exec) { inputs.file('package.json') outputs.cacheIf { false } ignoreExitValue = true commandLine osAdaptiveCommand(['npm', 'run', 'audit-ci']) } task dependencyCheckAggregate_prerequisites(type: Exec) { // the OWASP tool does not support yarn and its yarn.lock files, so node modules // should be explicitly installed (yarn install) before running the audit // See https://github.com/jeremylong/DependencyCheck/issues/2393 commandLine osAdaptiveCommand(['yarn', 'install', '--immutable']) } def sources = fileTree(dir: "src") + fileTree(dir: "scripts") + fileTree(dir: "config") + fileTree(dir: "__mocks__") task licenseCheckWeb(type: com.hierynomus.gradle.license.tasks.LicenseCheck) { source = sources exclude 'main/js/helpers/standards.json' if (official) exclude 'main/js/app/components/GlobalFooterBranding.js' } licenseMain.dependsOn licenseCheckWeb task licenseFormatWeb(type: com.hierynomus.gradle.license.tasks.LicenseFormat) { source = sources if (official) exclude 'main/js/app/components/GlobalFooterBranding.js' } licenseFormat.dependsOn licenseFormatWeb