diff --git a/setup.py b/setup.py index afe82c873d..fd9e0ab25c 100644 --- a/setup.py +++ b/setup.py @@ -54,6 +54,7 @@ def runSetup(): 'cwl': [ 'cwltool==1.0.20170822192924', 'schema-salad >= 2.6, < 3', + 'galaxy-lib==17.9.3', 'cwltest>=1.0.20170214185319']}, package_dir={'': 'src'}, packages=find_packages(where='src', diff --git a/src/toil/cwl/cwltoil.py b/src/toil/cwl/cwltoil.py index fcf395fa4f..554747cdde 100755 --- a/src/toil/cwl/cwltoil.py +++ b/src/toil/cwl/cwltoil.py @@ -40,6 +40,7 @@ import cwltool.draft2tool from cwltool.pathmapper import PathMapper, adjustDirObjs, adjustFileObjs, get_listing, MapperEnt, visit_class, normalizeFilesDirs from cwltool.process import shortname, fillInDefaults, compute_checksums, collectFilesAndDirs, stageFiles +from cwltool.software_requirements import DependenciesConfiguration, get_container_from_software_requirements from cwltool.utils import aslist import schema_salad.validate as validate import schema_salad.ref_resolver @@ -831,6 +832,14 @@ def main(args=None, stdout=sys.stdout): metavar=("VAR1 VAR2"), default=("PATH",), dest="preserve_environment") + # help="Dependency resolver configuration file describing how to adapt 'SoftwareRequirement' packages to current system." + parser.add_argument("--beta-dependency-resolvers-configuration", default=None) + # help="Defaut root directory used by dependency resolvers configuration." + parser.add_argument("--beta-dependencies-directory", default=None) + # help="Use biocontainers for tools without an explicitly annotated Docker container." + parser.add_argument("--beta-use-biocontainers", default=None, action="store_true") + # help="Short cut to use Conda to resolve 'SoftwareRequirement' packages." + parser.add_argument("--beta-conda-dependencies", default=None, action="store_true") # mkdtemp actually creates the directory, but # toil requires that the directory not exist, @@ -853,22 +862,32 @@ def main(args=None, stdout=sys.stdout): outdir = os.path.abspath(options.outdir) fileindex = {} existing = {} + make_tool_kwargs = {} + conf_file = getattr(options, "beta_dependency_resolvers_configuration", None) # Text + use_conda_dependencies = getattr(options, "beta_conda_dependencies", None) # Text + job_script_provider = None + if conf_file or use_conda_dependencies: + dependencies_configuration = DependenciesConfiguration(options) # type: DependenciesConfiguration + job_script_provider = dependencies_configuration + + options.default_container = None + make_tool_kwargs["find_default_container"] = functools.partial(find_default_container, options) with Toil(options) as toil: if options.restart: outobj = toil.restart() else: useStrict = not options.not_strict + make_tool_kwargs["hints"] = [{ + "class": "ResourceRequirement", + "coresMin": toil.config.defaultCores, + "ramMin": toil.config.defaultMemory / (2**20), + "outdirMin": toil.config.defaultDisk / (2**20), + "tmpdirMin": 0 + }] try: t = cwltool.load_tool.load_tool(options.cwltool, toilMakeTool, - kwargs={ - "hints": [{ - "class": "ResourceRequirement", - "coresMin": toil.config.defaultCores, - "ramMin": toil.config.defaultMemory / (2**20), - "outdirMin": toil.config.defaultDisk / (2**20), - "tmpdirMin": 0 - }]}, + kwargs=make_tool_kwargs, resolver=cwltool.resolver.tool_resolver, strict=useStrict) unsupportedRequirementsCheck(t.requirements) @@ -931,7 +950,8 @@ def setSecondary(fileobj): try: (wf1, wf2) = makeJob(t, {}, use_container=use_container, preserve_environment=options.preserve_environment, - tmpdir=os.path.realpath(outdir), workdir=options.workDir) + tmpdir=os.path.realpath(outdir), workdir=options.workDir, + job_script_provider=job_script_provider) except cwltool.process.UnsupportedRequirement as e: logging.error(e) return 33 @@ -948,3 +968,13 @@ def setSecondary(fileobj): stdout.write(json.dumps(outobj, indent=4)) return 0 + + +def find_default_container(args, builder): + default_container = None + if args.default_container: + default_container = args.default_container + elif args.beta_use_biocontainers: + default_container = get_container_from_software_requirements(args, builder) + + return default_container