aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild
diff options
context:
space:
mode:
authorWeston Schmidt <Weston_Schmidt@alumni.purdue.edu>2021-07-13 03:17:27 -0700
committerJussi Pakkanen <jpakkane@gmail.com>2021-07-23 22:15:00 +0300
commit2e30b5a1e2ca21555bb3aa50f91e87f4d2821bb6 (patch)
tree8aa0c83c313a20ecfd172952288ae4907198b966 /mesonbuild
parentdb6efa06c2138c7f24c94a3586649eecd44b3d04 (diff)
downloadmeson-2e30b5a1e2ca21555bb3aa50f91e87f4d2821bb6.zip
meson-2e30b5a1e2ca21555bb3aa50f91e87f4d2821bb6.tar.gz
meson-2e30b5a1e2ca21555bb3aa50f91e87f4d2821bb6.tar.bz2
Add support for gcovr --sonarqube report
Sonarcloud.io only can read the sonarqube based report that gcovr can produce. This change enables support for this output in meson and ninja. Signed-off-by: Weston Schmidt <Weston_Schmidt@alumni.purdue.edu>
Diffstat (limited to 'mesonbuild')
-rw-r--r--mesonbuild/backend/ninjabackend.py7
-rw-r--r--mesonbuild/scripts/coverage.py14
2 files changed, 21 insertions, 0 deletions
diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py
index 85a5f36..31d9813 100644
--- a/mesonbuild/backend/ninjabackend.py
+++ b/mesonbuild/backend/ninjabackend.py
@@ -1064,6 +1064,13 @@ class NinjaBackend(backends.Backend):
# Alias that runs the target defined above
self.create_target_alias('meson-coverage-xml')
+ e = NinjaBuildElement(self.all_outputs, 'meson-coverage-sonarqube', 'CUSTOM_COMMAND', 'PHONY')
+ self.generate_coverage_command(e, ['--sonarqube'])
+ e.add_item('description', 'Generates Sonarqube XML coverage report')
+ self.add_build(e)
+ # Alias that runs the target defined above
+ self.create_target_alias('meson-coverage-sonarqube')
+
e = NinjaBuildElement(self.all_outputs, 'meson-coverage-text', 'CUSTOM_COMMAND', 'PHONY')
self.generate_coverage_command(e, ['--text'])
e.add_item('description', 'Generates text coverage report')
diff --git a/mesonbuild/scripts/coverage.py b/mesonbuild/scripts/coverage.py
index b60d5d1..2bd93e8 100644
--- a/mesonbuild/scripts/coverage.py
+++ b/mesonbuild/scripts/coverage.py
@@ -46,6 +46,18 @@ def coverage(outputs: T.List[str], source_root: str, subproject_root: str, build
print('gcovr >= 3.3 needed to generate Xml coverage report')
exitcode = 1
+ if not outputs or 'sonarqube' in outputs:
+ if gcovr_exe:
+ subprocess.check_call(gcovr_base_cmd +
+ ['--sonarqube',
+ '-o', os.path.join(log_dir, 'sonarqube.xml'),
+ '-e', subproject_root
+ ] + gcov_exe_args)
+ outfiles.append(('Sonarqube', pathlib.Path(log_dir, 'sonarqube.xml')))
+ elif outputs:
+ print('gcovr >= 4.2 needed to generate Xml coverage report')
+ exitcode = 1
+
if not outputs or 'text' in outputs:
if gcovr_exe:
subprocess.check_call(gcovr_base_cmd +
@@ -156,6 +168,8 @@ def run(args: T.List[str]) -> int:
const='text', help='generate Text report')
parser.add_argument('--xml', dest='outputs', action='append_const',
const='xml', help='generate Xml report')
+ parser.add_argument('--sonarqube', dest='outputs', action='append_const',
+ const='sonarqube', help='generate Sonarqube Xml report')
parser.add_argument('--html', dest='outputs', action='append_const',
const='html', help='generate Html report')
parser.add_argument('--use_llvm_cov', action='store_true',