Skip to content

Commit

Permalink
Merge branch 'trs/document-AUGUR_DEBUG'
Browse files Browse the repository at this point in the history
  • Loading branch information
tsibley committed Aug 20, 2024
2 parents 988380c + 8c31208 commit d8faf01
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 9 deletions.
2 changes: 1 addition & 1 deletion CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

* A new command, `augur merge`, now allows for generalized merging of two or more metadata tables. [#1563][] (@tsibley)
* Two new commands, `augur read-file` and `augur write-file`, now allow external programs to do i/o like Augur by piping from/to these new commands. They provide handling of compression formats and newlines consistent with the rest of Augur. [#1562][] (@tsibley)
* A new debugging mode can be enabled by setting the `AUGUR_DEBUG` environment variable to `1` (or another truthy value). Currently the only effect is to print more information about handled (i.e. anticipated) errors. For example, stack traces and parent exceptions in an exception chain are normally omitted for handled errors, but setting this env var includes them. Future debugging and troubleshooting features, like verbose operation logging, will likely also condition on this new debugging mode. [#1577][] (@tsibley)
* A new debugging mode can be enabled by setting the `AUGUR_DEBUG` environment variable to `1` (or any non-empty value). Currently the only effect is to print more information about handled (i.e. anticipated) errors. For example, stack traces and parent exceptions in an exception chain are normally omitted for handled errors, but setting this env var includes them. Future debugging and troubleshooting features, like verbose operation logging, will likely also condition on this new debugging mode. [#1577][] (@tsibley)

### Bug Fixes

Expand Down
6 changes: 1 addition & 5 deletions augur/debug.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,7 @@
"""
Debug flags and utilities.
.. envvar:: AUGUR_DEBUG
Set to a truthy value (e.g. 1) to print more information about (handled)
errors. For example, when this is not set or falsey, stack traces and
parent exceptions in an exception chain are omitted from handled errors.
See also :envvar:`AUGUR_DEBUG`.
"""
from os import environ

Expand Down
2 changes: 1 addition & 1 deletion augur/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ def write_json(data, file, indent=(None if os.environ.get("AUGUR_MINIFY_JSON") e
file
file path or handle to write to
indent : int or None, optional
JSON indentation level. Default is `None` if the environment variable `AUGUR_MINIFY_JSON`
JSON indentation level. Default is `None` if the environment variable :envvar:`AUGUR_MINIFY_JSON`
is truthy, else 1
include_version : bool, optional
Include the augur version. Default: `True`.
Expand Down
14 changes: 12 additions & 2 deletions docs/usage/envvars.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,23 @@ Environment variables
Augur's behaviour can be globally modified by the values of some specific environment variables.
These can be especially useful in the context of an entire pipeline or workflow which uses Augur, as the environment variables can be set once for all Augur commands at the start of the pipeline.

``AUGUR_MINIFY_JSON``
.. envvar:: AUGUR_DEBUG

Boolean.
If set to a non-empty value, more detailed debugging information is shown by Augur during execution and handling of errors.

For example, when this is enabled, stack traces and parent exceptions in an exception chain are no longer omitted from handled (i.e. expected) errors.
Some commands will also emit more verbose operation logging during their execution.

.. envvar:: AUGUR_MINIFY_JSON

Boolean.
If set to a non-empty value, all JSON output produced by Augur will be minified by omitting indentation and newlines.

Minifying the JSON will substantially reduce file sizes, which is helpful for large, deeply nested trees.

``AUGUR_RECURSION_LIMIT``
.. envvar:: AUGUR_RECURSION_LIMIT

Integer.
If set to a non-empty value, the Python recursion limit will be set to the given value early in Augur's execution by calling :func:`sys.setrecursionlimit`.

Expand Down

0 comments on commit d8faf01

Please sign in to comment.