Merge pull request #212 from google/project-detection
Additional logging for project selection
This commit is contained in:
commit
37fc663a3d
3 changed files with 29 additions and 13 deletions
|
@ -87,11 +87,16 @@ if __name__ == '__main__':
|
||||||
'agents': {'queue': f'{queue_prefix}windows'},
|
'agents': {'queue': f'{queue_prefix}windows'},
|
||||||
'timeout_in_minutes': 120,
|
'timeout_in_minutes': 120,
|
||||||
}
|
}
|
||||||
steps.append(linux_buld_step)
|
deps = []
|
||||||
steps.append(windows_buld_step)
|
if os.getenv('ph_skip_linux') is None:
|
||||||
|
steps.append(linux_buld_step)
|
||||||
|
deps.append(linux_buld_step['key'])
|
||||||
|
if os.getenv('ph_skip_windows') is None:
|
||||||
|
steps.append(windows_buld_step)
|
||||||
|
deps.append(windows_buld_step['key'])
|
||||||
report_step = {
|
report_step = {
|
||||||
'label': ':spiral_note_pad: report',
|
'label': ':spiral_note_pad: report',
|
||||||
'depends_on': [linux_buld_step['key'], windows_buld_step['key']],
|
'depends_on': deps,
|
||||||
'commands': [
|
'commands': [
|
||||||
'mkdir -p artifacts',
|
'mkdir -p artifacts',
|
||||||
'buildkite-agent artifact download "*_result.json" .',
|
'buildkite-agent artifact download "*_result.json" .',
|
||||||
|
|
|
@ -62,7 +62,8 @@ class ChooseProjects:
|
||||||
for used in used_list:
|
for used in used_list:
|
||||||
self.usages.setdefault(used, []).append(user)
|
self.usages.setdefault(used, []).append(user)
|
||||||
self.all_projects = config['allprojects']
|
self.all_projects = config['allprojects']
|
||||||
self.excluded_projects = set(config['excludedProjects'][self.operating_system])
|
excluded = config['excludedProjects'][self.operating_system]
|
||||||
|
self.excluded_projects = set(excluded if excluded is not None else [])
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _detect_os() -> str:
|
def _detect_os() -> str:
|
||||||
|
@ -86,10 +87,19 @@ class ChooseProjects:
|
||||||
logging.warning('There were changes that could not be mapped to a project.'
|
logging.warning('There were changes that could not be mapped to a project.'
|
||||||
'Building all projects instead!')
|
'Building all projects instead!')
|
||||||
return self.FALLBACK_PROJECTS
|
return self.FALLBACK_PROJECTS
|
||||||
|
return self.extend_projects(changed_projects)
|
||||||
|
|
||||||
affected_projects = self.get_affected_projects(changed_projects)
|
def extend_projects(self, projects: Set[str]) -> List[str]:
|
||||||
|
logging.info(f'projects: {projects}')
|
||||||
|
affected_projects = self.get_affected_projects(projects)
|
||||||
|
logging.info(f'with affected projects: {affected_projects}')
|
||||||
affected_projects = self.add_dependencies(affected_projects)
|
affected_projects = self.add_dependencies(affected_projects)
|
||||||
affected_projects = affected_projects - self.excluded_projects
|
logging.info(f'with dependencies: {affected_projects}')
|
||||||
|
to_exclude = affected_projects.intersection(self.excluded_projects)
|
||||||
|
if len(to_exclude) != 0:
|
||||||
|
affected_projects = affected_projects - to_exclude
|
||||||
|
logging.warning(f'{to_exclude} projects are excluded')
|
||||||
|
logging.info(f'without excluded: {affected_projects}')
|
||||||
return sorted(affected_projects)
|
return sorted(affected_projects)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
|
@ -147,9 +157,7 @@ class ChooseProjects:
|
||||||
changes.update(self.usages[project])
|
changes.update(self.usages[project])
|
||||||
affected_projects.update(changes)
|
affected_projects.update(changes)
|
||||||
|
|
||||||
logging.info('Projects affected by this patch:')
|
logging.info(f'added {affected_projects - changed_projects} projects as they are affected')
|
||||||
logging.info(' ' + '\n '.join(sorted(affected_projects)))
|
|
||||||
|
|
||||||
return affected_projects
|
return affected_projects
|
||||||
|
|
||||||
def add_dependencies(self, projects: Set[str]) -> Set[str]:
|
def add_dependencies(self, projects: Set[str]) -> Set[str]:
|
||||||
|
@ -170,8 +178,7 @@ class ChooseProjects:
|
||||||
|
|
||||||
def get_all_enabled_projects(self) -> List[str]:
|
def get_all_enabled_projects(self) -> List[str]:
|
||||||
"""Get list of all not-excluded projects for current platform."""
|
"""Get list of all not-excluded projects for current platform."""
|
||||||
result = set(self.all_projects) - self.excluded_projects
|
return self.extend_projects(set(self.all_projects))
|
||||||
return sorted(list(result))
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|
|
@ -90,8 +90,10 @@ def _select_projects(config: Configuration, projects: str, repo_path: str) -> st
|
||||||
cp = ChooseProjects(repo_path)
|
cp = ChooseProjects(repo_path)
|
||||||
repo = Repo('.')
|
repo = Repo('.')
|
||||||
patch = repo.git.diff("HEAD~1")
|
patch = repo.git.diff("HEAD~1")
|
||||||
|
logging.debug(f'diff {patch}')
|
||||||
enabled_projects = ';'.join(cp.choose_projects(patch))
|
enabled_projects = ';'.join(cp.choose_projects(patch))
|
||||||
if enabled_projects is None or len(enabled_projects) == 0:
|
if enabled_projects is None or len(enabled_projects) == 0:
|
||||||
|
logging.warning('Cannot detect affected projects. Enable all projects')
|
||||||
enabled_projects = cp.get_all_enabled_projects()
|
enabled_projects = cp.get_all_enabled_projects()
|
||||||
return enabled_projects
|
return enabled_projects
|
||||||
return projects
|
return projects
|
||||||
|
@ -164,7 +166,7 @@ def run(projects: str, repo_path: str, config_file_path: str = None, *, dry_run:
|
||||||
print('Running cmake with these arguments:\n{}'.format(cmd), flush=True)
|
print('Running cmake with these arguments:\n{}'.format(cmd), flush=True)
|
||||||
if dry_run:
|
if dry_run:
|
||||||
print('Dry run, not invoking CMake!')
|
print('Dry run, not invoking CMake!')
|
||||||
return 0, build_dir, []
|
return 0, build_dir, [], []
|
||||||
result = subprocess.call(cmd, env=env, shell=True, cwd=build_dir)
|
result = subprocess.call(cmd, env=env, shell=True, cwd=build_dir)
|
||||||
commands.append('cmake ' + ' '.join(_create_args(config, llvm_enable_projects, False)))
|
commands.append('cmake ' + ' '.join(_create_args(config, llvm_enable_projects, False)))
|
||||||
commands.append('# ^note that compiler cache arguments are omitted')
|
commands.append('# ^note that compiler cache arguments are omitted')
|
||||||
|
@ -203,6 +205,8 @@ if __name__ == '__main__':
|
||||||
parser.add_argument('projects', type=str, nargs='?', default='default')
|
parser.add_argument('projects', type=str, nargs='?', default='default')
|
||||||
parser.add_argument('repo_path', type=str, nargs='?', default=os.getcwd())
|
parser.add_argument('repo_path', type=str, nargs='?', default=os.getcwd())
|
||||||
parser.add_argument('--dryrun', action='store_true')
|
parser.add_argument('--dryrun', action='store_true')
|
||||||
|
parser.add_argument('--log-level', type=str, default='WARNING')
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
result, _, _ = run(args.projects, args.repo_path, dry_run=args.dryrun)
|
logging.basicConfig(level=args.log_level, format='%(levelname)-7s %(message)s')
|
||||||
|
result, _, _, _ = run(args.projects, args.repo_path, dry_run=args.dryrun)
|
||||||
sys.exit(result)
|
sys.exit(result)
|
||||||
|
|
Loading…
Reference in a new issue