Mercurial > repos > shellac > sam_consensus_v3
diff env/lib/python3.9/site-packages/planemo/ci.py @ 0:4f3585e2f14b draft default tip
"planemo upload commit 60cee0fc7c0cda8592644e1aad72851dec82c959"
author | shellac |
---|---|
date | Mon, 22 Mar 2021 18:12:50 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/env/lib/python3.9/site-packages/planemo/ci.py Mon Mar 22 18:12:50 2021 +0000 @@ -0,0 +1,84 @@ +"""Utilities for dealing with continous integration systems.""" + +from __future__ import print_function + +import copy +import math +import os + +import yaml + +from planemo import git +from planemo import io +from planemo.shed import REPO_METADATA_FILES + + +def filter_paths(ctx, raw_paths, path_type="repo", **kwds): + """Filter ``paths``. + + ``path_type`` is ``repo`` or ``file``. + """ + cwd = os.getcwd() + + filter_kwds = copy.deepcopy(kwds) + changed_in_commit_range = kwds.get("changed_in_commit_range", None) + diff_paths = None + if changed_in_commit_range is not None: + diff_files = git.diff(ctx, cwd, changed_in_commit_range) + if path_type == "repo": + diff_dirs = set(os.path.dirname(p) for p in diff_files) + diff_paths = set() + for diff_dir in diff_dirs: + diff_path = metadata_file_in_path(diff_dir) + if diff_path: + diff_paths.add(diff_path) + else: + diff_paths = diff_files + + unique_paths = set(os.path.relpath(p, cwd) for p in raw_paths) + if diff_paths is not None: + unique_paths = unique_paths.intersection(diff_paths) + filtered_paths = sorted(io.filter_paths(unique_paths, cwd=cwd, **filter_kwds)) + excluded_paths = sorted(set(unique_paths) - set(filtered_paths)) + if excluded_paths: + ctx.log("List of excluded paths: %s" % excluded_paths) + + path_count = len(filtered_paths) + chunk_size = ((1.0 * path_count) / kwds["chunk_count"]) + chunk = kwds["chunk"] + + chunked_paths = [] + for i, path in enumerate(filtered_paths): + if int(math.floor(i / chunk_size)) == chunk: + chunked_paths.append(path) + + return chunked_paths + + +def metadata_file_in_path(diff_dir): + while diff_dir: + for metadata_file in REPO_METADATA_FILES: + if os.path.isfile(os.path.join(diff_dir, metadata_file)): + return diff_dir + diff_dir = os.path.dirname(diff_dir) + + +def group_paths(paths): + repos = {} + for path in paths: + repo = os.path.split(path)[0] + if repo not in repos: + repos[repo] = [] + repos[repo].append(path) + return [" ".join(repos[_]) for _ in repos] + + +def print_path_list(paths, **kwds): + with io.open_file_or_standard_output(kwds["output"], "w") as f: + for path in paths: + print(path, file=f) + + +def print_as_yaml(item, **kwds): + with io.open_file_or_standard_output(kwds["output"], "w") as f: + f.write(yaml.safe_dump(item))