From e3f36a9094d30e3fc96a786eef02ce4e2c6eefd1 Mon Sep 17 00:00:00 2001 From: Kara Moraw Date: Tue, 6 Feb 2024 16:39:09 +0000 Subject: [PATCH] #15 moved build script into requirements --- .../evaluators/fair_evaluator_license_file.py | 72 ++++++++++--------- .../yaml/metrics_v0.7_software_cessda.yaml | 6 ++ 2 files changed, 44 insertions(+), 34 deletions(-) diff --git a/fuji_server/evaluators/fair_evaluator_license_file.py b/fuji_server/evaluators/fair_evaluator_license_file.py index 98c42730..0a5a74c6 100644 --- a/fuji_server/evaluators/fair_evaluator_license_file.py +++ b/fuji_server/evaluators/fair_evaluator_license_file.py @@ -363,40 +363,44 @@ def testBuildScriptChecksLicenseHeader(self): break if test_defined: test_score = self.getTestConfigScore(test_id) - # Maven - mvn_pom = self.fuji.github_data.get("mvn_pom") - if mvn_pom is not None: - # Check whether pom.xml uses license:check-file-header to validate license headers. - # See https://www.mojohaus.org/license-maven-plugin/check-file-header-mojo.html for more info. - root = ET.fromstring(mvn_pom) - namespaces = root.nsmap - # look for plugin with artifactID license-maven-plugin - found_license_plugin = False - for plugin in root.iterfind(".//plugin", namespaces): - artifact_id = plugin.find("artifactId", namespaces) - if artifact_id is not None and artifact_id.text == "license-maven-plugin": - found_license_plugin = True - fail_on_missing_header = plugin.find("configuration/failOnMissingHeader", namespaces) - if fail_on_missing_header is not None and fail_on_missing_header.text == "true": - test_status = True - self.logger.log( - self.fuji.LOG_SUCCESS, - f"{self.metric_identifier} : Maven POM checks for license headers in source files.", - ) - self.maturity = self.getTestConfigMaturity(test_id) - self.setEvaluationCriteriumScore(test_id, test_score, "pass") - self.score.earned += test_score - else: - self.logger.warning( - f"{self.metric_identifier} : Maven POM uses license-maven-plugin (license:check-file-header) but does not fail on missing header." - ) - break - if not found_license_plugin: - self.logger.warning( - f"{self.metric_identifier} : Maven POM does not use license-maven-plugin (license:check-file-header) to check for license headers in source code files." - ) - else: - self.logger.warning(f"{self.metric_identifier} : Did not find a Maven POM file.") + test_requirements = self.metric_tests[test_id].metric_test_requirements[0] + required_build_scripts = test_requirements["required"]["build_script"] + if "maven_pom" in required_build_scripts: # check Maven POM for plugin + mvn_pom = self.fuji.github_data.get("maven_pom") + if mvn_pom is not None: + # Check whether pom.xml uses license:check-file-header to validate license headers. + # See https://www.mojohaus.org/license-maven-plugin/check-file-header-mojo.html for more info. + root = ET.fromstring(mvn_pom) + namespaces = root.nsmap + # look for plugin with artifactID license-maven-plugin + found_license_plugin = False + for plugin in root.iterfind(".//plugin", namespaces): + artifact_id = plugin.find("artifactId", namespaces) + if artifact_id is not None and artifact_id.text == "license-maven-plugin": + found_license_plugin = True + fail_on_missing_header = plugin.find("configuration/failOnMissingHeader", namespaces) + if fail_on_missing_header is not None and fail_on_missing_header.text == "true": + test_status = True + self.logger.log( + self.fuji.LOG_SUCCESS, + f"{self.metric_identifier} : Maven POM checks for license headers in source files.", + ) + self.maturity = self.getTestConfigMaturity(test_id) + self.setEvaluationCriteriumScore(test_id, test_score, "pass") + self.score.earned += test_score + else: + self.logger.warning( + f"{self.metric_identifier} : Maven POM uses license-maven-plugin (license:check-file-header) but does not fail on missing header." + ) + break + if not found_license_plugin: + self.logger.warning( + f"{self.metric_identifier} : Maven POM does not use license-maven-plugin (license:check-file-header) to check for license headers in source code files." + ) + else: + self.logger.warning(f"{self.metric_identifier} : Did not find a Maven POM file.") + if any(e != "maven_pom" for e in required_build_scripts): + self.logger.warning(f"{self.metric_identifier} : Unknown build script configured.") return test_status def evaluate(self): diff --git a/fuji_server/yaml/metrics_v0.7_software_cessda.yaml b/fuji_server/yaml/metrics_v0.7_software_cessda.yaml index fd6f4e7d..1d8b8b7f 100644 --- a/fuji_server/yaml/metrics_v0.7_software_cessda.yaml +++ b/fuji_server/yaml/metrics_v0.7_software_cessda.yaml @@ -369,6 +369,12 @@ metrics: metric_test_name: The build script (Maven POM, where used) checks that the standard header is present in all source code files. metric_test_score: 1 metric_test_maturity: 3 + metric_test_requirements: + - target: https://f-uji.net/vocab/metadata/standards + modality: any + required: + build_script: + - maven_pom created_by: FAIR4RS date_created: 2023-12-13 date_updated: 2023-12-13