From ed886a7da2d68a02876cf832063014f5baa6c40a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20K=C3=BChnel?= Date: Mon, 3 Feb 2020 13:42:19 +0100 Subject: [PATCH] adding dependencies to project selector --- .../Phabricator-windows-pipeline/Jenkinsfile | 5 +---- scripts/choose_projects.py | 22 ++++++++++++++++++- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/Jenkins/Phabricator-windows-pipeline/Jenkinsfile b/Jenkins/Phabricator-windows-pipeline/Jenkinsfile index 5caf3f6..0630dce 100644 --- a/Jenkins/Phabricator-windows-pipeline/Jenkinsfile +++ b/Jenkins/Phabricator-windows-pipeline/Jenkinsfile @@ -70,10 +70,7 @@ pipeline { stage('CMake') { steps { dir("${LLVM_DIR}"){ - // TODO(kuhnel): disabling because of broken dependencies: - // https://jenkins.llvm-merge-guard.org/job/amd64_windows_vs2017/690/execution/node/53/log/ - //powershell "${SCRIPT_DIR}/run_cmake.ps1 -projects detect" - powershell "${SCRIPT_DIR}/run_cmake.ps1" + powershell "${SCRIPT_DIR}/run_cmake.ps1 -projects detect" } } } diff --git a/scripts/choose_projects.py b/scripts/choose_projects.py index 9d7804d..268281a 100755 --- a/scripts/choose_projects.py +++ b/scripts/choose_projects.py @@ -41,6 +41,7 @@ class ChooseProjects: def __init__(self, llvm_dir: str): self.llvm_dir = llvm_dir + self.dependencies = dict() # type: Dict[str,List[str]] self.usages = dict() # type: Dict[str,List[str]] self.all_projects = [] # type: List[str] self.excluded_projects = set() # type: Set[str] @@ -51,7 +52,8 @@ class ChooseProjects: logging.info('loading project config from {}'.format(self.DEPENDENCIES_FILE)) with open(self.DEPENDENCIES_FILE) as dependencies_file: config = yaml.load(dependencies_file, Loader=yaml.SafeLoader) - for user, used_list in config['dependencies'].items(): + self.dependencies = config['dependencies'] + for user, used_list in self.dependencies.items(): for used in used_list: self.usages.setdefault(used,[]).append(user) self.all_projects = config['allprojects'] @@ -72,6 +74,7 @@ class ChooseProjects: return 0 affected_projects = self.get_affected_projects(changed_projects) + affected_projects = self.add_dependencies(affected_projects) affected_projects = affected_projects - self.excluded_projects print(';'.join(sorted(affected_projects))) return 0 @@ -132,6 +135,23 @@ class ChooseProjects: return affected_projects + def add_dependencies(self, projects: Set[str]): + """Return projects and their dependencies. + + All all dependencies to `projects` so that they can be built. + """ + result = set(projects) + last_len = -1 + while len(result) != last_len: + last_len = len(result) + changes = set() + for project in result: + if project in self.dependencies: + changes.update(self.dependencies[project]) + print(changes) + result.update(changes) + return result + if __name__ == "__main__": logging.basicConfig(filename='choose_projects.log', level=logging.INFO) parser = argparse.ArgumentParser(description='Compute the projects affected by a change.')