Common Workflow Language Specifications, v1.1 §
The CWL specifications are divided up into several documents.
The User Guide provides a gentle introduction to writing CWL command line tools and workflows. Currently it is for CWL v1.0 only.
The Command Line Tool Description Specification specifies the document schema and execution semantics for wrapping and executing command line tools.
The Workflow Description Specification specifies the document schema and execution semantics for composing workflows from components such as command line tools and other workflows.
The Semantic Annotations for Linked Avro Data (SALAD) Specification specifies the preprocessing steps that must be applied when loading CWL documents and the schema language used to write the above specifications.
Running the CWL conformance tests §
Install a CWL runner of your choice. The reference runner can be installed as the default runner by doing:
pip install cwlref-runner
Install the CWL test parser:
pip install cwltest
You may need to activate a virtualenv first, or do a local install by adding
From within a copy of this repository (e.g. cwl-v1.1) execute the main test script
If the CWL runner isn't installed as
cwl-runner then you can specify the name for the runner:
You can also specify additional options that are specific for the particular CWL runner you are using. For example, with CWL reference runner you can turn on parallel execution mode:
./run_test.sh RUNNER=cwltool EXTRA=--parallel
This can be combined with launching more than one CWL conformance test at once with
./run_test.sh -j4 RUNNER=cwltool EXTRA=--parallel
You can list all the tests
You can run a particular test
If you are running tests using the CWL reference runner "cwltool" for an unreleased version of the CWL standards use the
./run_test.sh RUNNER=cwltool EXTRA=--enable-dev
For details of options you can pass to the test script, do: