From b05e22e5bc2719a5785e42570b73f61fa7380476 Mon Sep 17 00:00:00 2001 From: Anders Goncalves da Silva Date: Fri, 17 Mar 2023 15:20:35 -0700 Subject: [PATCH] Add example --- README.md | 47 +++++++++++++++++++++++++++++++++++++++++++ example/config.yaml | 9 +++++++++ example/example1.py | 29 ++++++++++++++++++++++++++ src/vezzo/__init__.py | 2 +- 4 files changed, 86 insertions(+), 1 deletion(-) create mode 100644 example/config.yaml create mode 100644 example/example1.py diff --git a/README.md b/README.md index 25ca956..832a3dd 100644 --- a/README.md +++ b/README.md @@ -43,4 +43,51 @@ string is returned. The majority of cases this is 0, but `bwa`, for instance, re By specifying all the version requirements in a YAML config file that ships with your package it is easy to check dependencies and modify requirement all in one location. +A full working example is provided in the `example` directory. To run the example, +simply run `python example/example1.py`. +The output from the example is (the exact output will depend on the versions you have, and any tweaks you make to the example config file): + +```bash +blastn version 2.13.0 DOES NOT match requirements >=2.14.0.... ❌ +samtools version 1.17.0 matches requirements >=1.16.0.... ✔ +There was 1 tool that failed the version requirements. Please ensure these are corrected before proceeding. 😢 +``` + +The basic code might look like this: + +```python +for is_match, obs_version, exp_version, tool in vezzo.verify_from_config(config): + if is_match: + sys.stderr.write( + f"\033[32m {tool} version {obs_version} matches requirements {exp_version}.... \u2714 \033[0m\n" + ) + else: + sys.stderr.write( + f"\033[31m {tool} version {obs_version} DOES NOT matches requirements {exp_version}.... \u274C \033[0m\n" + ) + fails += 1 + +if fails > 0: + sys.stderr.write( + f"\033[31m There {'was' if fails == 1 else 'were'} {fails} tool{'s' if fails > 0 else ''} that failed the version requirements. Please ensure these are corrected before proceeding. \U0001F622 \033[0m\n" + ) + sys.exit(1) +``` + +As as can be seen, the function returns a generator that yields a tuple of the following +format: `(is_match, obs_version, exp_version, tool)`. The `is_match` field is a boolean +that indicates whether the observed version matches the expected version criteria. +The `obs_version` field is the observed version string. The `exp_version` field is the +expected string requirement in the format outlined above. The `tool` field is the name of the tool. + +## Installation + +The library can be installed via `pip`: + +```bash +pip install vezzo +``` + +## Author +Anders Goncalves da Silva (@andersgs) diff --git a/example/config.yaml b/example/config.yaml new file mode 100644 index 0000000..ce465b8 --- /dev/null +++ b/example/config.yaml @@ -0,0 +1,9 @@ +- name: blastn + req_version: ">=2.14.0" + version_flag: -version + exit_code: 0 + +- name: samtools + req_version: ">=1.16.0" + version_flag: --version + exit_code: 0 \ No newline at end of file diff --git a/example/example1.py b/example/example1.py new file mode 100644 index 0000000..b9233e7 --- /dev/null +++ b/example/example1.py @@ -0,0 +1,29 @@ +""" +An example of using the library to check if appropriate versions of blastn and +samtools are installed. +""" + +import sys +import os +import vezzo + +path = os.path.dirname(os.path.realpath(__file__)) +config = os.path.join(path, "config.yaml") + +fails = 0 +for is_match, obs_version, exp_version, tool in vezzo.verify_from_config(config): + if is_match: + sys.stderr.write( + f"\033[32m {tool} version {obs_version} matches requirements {exp_version}.... \u2714 \033[0m\n" + ) + else: + sys.stderr.write( + f"\033[31m {tool} version {obs_version} DOES NOT match requirements {exp_version}.... \u274C \033[0m\n" + ) + fails += 1 + +if fails > 0: + sys.stderr.write( + f"\033[31m There {'was' if fails == 1 else 'were'} {fails} tool{'s' if fails > 0 else ''} that failed the version requirements. Please ensure these are corrected before proceeding. \U0001F622 \033[0m\n" + ) + sys.exit(1) diff --git a/src/vezzo/__init__.py b/src/vezzo/__init__.py index ee2e90a..af2c0dd 100644 --- a/src/vezzo/__init__.py +++ b/src/vezzo/__init__.py @@ -148,4 +148,4 @@ def verify_from_config(config: pathlib.Path): tool["exit_code"], ) result, obs_version = verify(tool["req_version"], version_string) - yield result, obs_version, tool["req_version"] + yield result, obs_version, tool["req_version"], tool["name"]