cli-tool-audit


Namecli-tool-audit JSON
Version 3.1.0 PyPI version JSON
download
home_pagehttps://github.com/matthewdeanmartin/cli_tool_audit
SummaryAudit for existence and version number of cli tools.
upload_time2024-08-24 23:16:25
maintainerNone
docs_urlNone
authorMatthew Martin
requires_python<4.0,>=3.9
licenseMIT
keywords cli tooling version numbers
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # cli_tool_audit

Verify that a list of cli tools are available. Like a requirements.txt for cli tools, but without an installer
component. Intended to work with cli tools regardless to how they were installed, e.g. via pipx, npm, etc.

If 100% of your tools are installed by the same package manager that can install tools from a list with desired
versions, then you don't need this tool.

Some useful scenarios:

- Validating a developer's workstation instead of an "install everything" script.
- - Validating a CI environment and failing the build when configuration has drifted
- Validating an end user's environment before running an app where you can't install all the
  dependencies for them.

## How it works

You declare a list of cli commands and version ranges.

The tool will run `tool --version` for each tool and make best efforts to parse the result and compare it to the
desired version range.

The tool then can either output a report with warnings or signal failure if something is missing, the wrong version
or can't be determined.

There is no universal method for getting a version number from a CLI tool, nor is there a universal orderable
version number system, so the outcome of many check may be limited to an existence check or exact version number check.

Here is an example run.

```text
❯ cli_tool_audit audit
+--------+--------------------------+--------+----------+------------+----------+
|  Tool  |          Found           | Parsed | Desired  |   Status   | Modified |
+--------+--------------------------+--------+----------+------------+----------+
|  java  | openjdk version "17.0.6" | 17.0.6 | >=17.0.6 | Compatible | 01/18/23 |
|  make  |      GNU Make 3.81       | 3.81.0 |  >=3.81  | Compatible | 11/24/06 |
|        |       Copyright (        |        |          |            |          |
| python |      Python 3.11.1       | 3.11.1 | >=3.11.1 | Compatible | 01/13/24 |
+--------+--------------------------+--------+----------+------------+----------+
```

## Installation

You will need to install it to your virtual environment if tools you are looking for are in your virtual environment.
If all the tools are global then you can pipx install. It is on the roadmap to support a pipx install for all scenarios.

```shell
pipx install cli-tool-audit
```

## Usage

Generate minimal config for a few tools.

```bash
cli_tool_audit freeze python java make rustc
```

Copy result of above into your pyproject.toml. Edit as needed, especially if you don't want snapshot versioning,
which is probably too strict.

Audit the environment with the current configuration.

```bash
cli_tool_audit audit
```

All commands

```text
❯ cli_tool_audit --help
usage: cli_tool_audit [-h] [-V] [--verbose] [--demo {pipx,venv,npm}]
                      {interactive,freeze,audit,single,read,create,update,delete} ...

Audit for existence and version number of cli tools.

positional arguments:
  {interactive,freeze,audit,single,read,create,update,delete}
                        Subcommands.
    interactive         Interactively edit configuration
    freeze              Freeze the versions of specified tools
    audit               Audit environment with current configuration
    single              Audit one tool without configuration file
    read                Read and list all tool configurations
    create              Create a new tool configuration
    update              Update an existing tool configuration
    delete              Delete a tool configuration

options:
  -h, --help            show this help message and exit
  -V, --version         Show program's version number and exit.
  --verbose             verbose output
  --demo {pipx,venv,npm}
                        Demo for values of npm, pipx or venv

    Examples:

        # Audit and report using pyproject.toml
        cli_tool_audit audit

        # Generate config for snapshots
        cli_tool_audit freeze python java make rustc
```

Note. If you use the create/update commands and specify the `--version` switch, it must have an equal sign.

Here is how to generate a freeze, a list of current versions by snapshot, for a lis tof tools. All tools will be
check with `--version` unless they are well known.

```shell
cli_tool_audit freeze python java make rustc
```

This is for programmatic usage.

```python
import cli_tool_audit

print(cli_tool_audit.validate(file_path="pyproject.toml"))
```

The configuration file lists the tools you expect how hints on how detect the version.

```toml
[tool.cli-tools]
# Typical example
pipx = { version = ">=1.0.0", version_switch = "--version" }
# Restrict to specific OS
brew = { version = ">=0.1.0", if_os="darwin" }
# Pin to a snapshot of the output of `poetry --version`
poetry = {version = "Poetry (version 1.5.1)", schema="snapshot"}
# Don't attempt to run `notepad --version`, just check if it is on the path
notepad = { schema = "existence" }
# Any version.
vulture = { version = "*" }
# Supports ^ and ~ version ranges.
shellcheck = { version = "^0.8.0" }
# Uses semver's compatibility logic, which is not the same as an exact match.
rustc = { version = "1.67.0" }
```

See [semver3](https://python-semver.readthedocs.io/en/latest/usage/check-compatible-semver-version.html) for
compatibility logic for versions without operators/symbols.

See [poetry](https://python-poetry.org/docs/dependency-specification/) for version range specifiers.

See [stackoverflow](https://stackoverflow.com/a/13874620/33264) for os names.

## Demos

Demos will discover a bunch of executables as installed in the local virtual environment, installed by pipx or
installed by npm. It will then assume that we want the current or any version and run an audit. Since we know these
files already exist, the failures are centered on failing to execute, failing to guess the version switch, failure
to parse the switch or the
tool's version switch returning a version incompatible to what the package manager reports.

```bash
cli_tool_audit --demo=pipx --verbose
cli_tool_audit --demo=venv --verbose
cli_tool_audit --demo=npm --verbose
```

## How does this relate to package managers, e.g. apt, pipx, npm, choco, etc.

Package managers do far more than check for the existence of a tool. They will install it, at the desired version
and make sure that tools and their transitive dependencies are compatible.

What they can't do is verify what other package managers have done.

This captures your desired tools, versions and guarantees you have them by installing them.

```shell
# list everything available on one machine
pip freeze>requirements.txt
# install it on another.
pip install -r requirements.txt
```

This is the same thing, but for windows and .net centric apps.

```shell
choco export requirements.txt
choco install -y requirements.txt
```

There are similar patterns, for apt, brew, npm, and so on.

It would be foolish to try to create a package manager that supports other package managers, so features in that
vein are out of scope.

## Prior Art

- [tool-audit](https://github.com/jstutters/toolaudit)
- [dotnet-tool-list](https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet-tool-list)


            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/matthewdeanmartin/cli_tool_audit",
    "name": "cli-tool-audit",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.9",
    "maintainer_email": null,
    "keywords": "cli tooling, version numbers",
    "author": "Matthew Martin",
    "author_email": "matthewdeanmartin@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/24/c2/6ec7500017e41e959bc97e7b145c6b1aa1229a82705ce1ece9867ce28336/cli_tool_audit-3.1.0.tar.gz",
    "platform": null,
    "description": "# cli_tool_audit\n\nVerify that a list of cli tools are available. Like a requirements.txt for cli tools, but without an installer\ncomponent. Intended to work with cli tools regardless to how they were installed, e.g. via pipx, npm, etc.\n\nIf 100% of your tools are installed by the same package manager that can install tools from a list with desired\nversions, then you don't need this tool.\n\nSome useful scenarios:\n\n- Validating a developer's workstation instead of an \"install everything\" script.\n- - Validating a CI environment and failing the build when configuration has drifted\n- Validating an end user's environment before running an app where you can't install all the\n  dependencies for them.\n\n## How it works\n\nYou declare a list of cli commands and version ranges.\n\nThe tool will run `tool --version` for each tool and make best efforts to parse the result and compare it to the\ndesired version range.\n\nThe tool then can either output a report with warnings or signal failure if something is missing, the wrong version\nor can't be determined.\n\nThere is no universal method for getting a version number from a CLI tool, nor is there a universal orderable\nversion number system, so the outcome of many check may be limited to an existence check or exact version number check.\n\nHere is an example run.\n\n```text\n\u276f cli_tool_audit audit\n+--------+--------------------------+--------+----------+------------+----------+\n|  Tool  |          Found           | Parsed | Desired  |   Status   | Modified |\n+--------+--------------------------+--------+----------+------------+----------+\n|  java  | openjdk version \"17.0.6\" | 17.0.6 | >=17.0.6 | Compatible | 01/18/23 |\n|  make  |      GNU Make 3.81       | 3.81.0 |  >=3.81  | Compatible | 11/24/06 |\n|        |       Copyright (        |        |          |            |          |\n| python |      Python 3.11.1       | 3.11.1 | >=3.11.1 | Compatible | 01/13/24 |\n+--------+--------------------------+--------+----------+------------+----------+\n```\n\n## Installation\n\nYou will need to install it to your virtual environment if tools you are looking for are in your virtual environment.\nIf all the tools are global then you can pipx install. It is on the roadmap to support a pipx install for all scenarios.\n\n```shell\npipx install cli-tool-audit\n```\n\n## Usage\n\nGenerate minimal config for a few tools.\n\n```bash\ncli_tool_audit freeze python java make rustc\n```\n\nCopy result of above into your pyproject.toml. Edit as needed, especially if you don't want snapshot versioning,\nwhich is probably too strict.\n\nAudit the environment with the current configuration.\n\n```bash\ncli_tool_audit audit\n```\n\nAll commands\n\n```text\n\u276f cli_tool_audit --help\nusage: cli_tool_audit [-h] [-V] [--verbose] [--demo {pipx,venv,npm}]\n                      {interactive,freeze,audit,single,read,create,update,delete} ...\n\nAudit for existence and version number of cli tools.\n\npositional arguments:\n  {interactive,freeze,audit,single,read,create,update,delete}\n                        Subcommands.\n    interactive         Interactively edit configuration\n    freeze              Freeze the versions of specified tools\n    audit               Audit environment with current configuration\n    single              Audit one tool without configuration file\n    read                Read and list all tool configurations\n    create              Create a new tool configuration\n    update              Update an existing tool configuration\n    delete              Delete a tool configuration\n\noptions:\n  -h, --help            show this help message and exit\n  -V, --version         Show program's version number and exit.\n  --verbose             verbose output\n  --demo {pipx,venv,npm}\n                        Demo for values of npm, pipx or venv\n\n    Examples:\n\n        # Audit and report using pyproject.toml\n        cli_tool_audit audit\n\n        # Generate config for snapshots\n        cli_tool_audit freeze python java make rustc\n```\n\nNote. If you use the create/update commands and specify the `--version` switch, it must have an equal sign.\n\nHere is how to generate a freeze, a list of current versions by snapshot, for a lis tof tools. All tools will be\ncheck with `--version` unless they are well known.\n\n```shell\ncli_tool_audit freeze python java make rustc\n```\n\nThis is for programmatic usage.\n\n```python\nimport cli_tool_audit\n\nprint(cli_tool_audit.validate(file_path=\"pyproject.toml\"))\n```\n\nThe configuration file lists the tools you expect how hints on how detect the version.\n\n```toml\n[tool.cli-tools]\n# Typical example\npipx = { version = \">=1.0.0\", version_switch = \"--version\" }\n# Restrict to specific OS\nbrew = { version = \">=0.1.0\", if_os=\"darwin\" }\n# Pin to a snapshot of the output of `poetry --version`\npoetry = {version = \"Poetry (version 1.5.1)\", schema=\"snapshot\"}\n# Don't attempt to run `notepad --version`, just check if it is on the path\nnotepad = { schema = \"existence\" }\n# Any version.\nvulture = { version = \"*\" }\n# Supports ^ and ~ version ranges.\nshellcheck = { version = \"^0.8.0\" }\n# Uses semver's compatibility logic, which is not the same as an exact match.\nrustc = { version = \"1.67.0\" }\n```\n\nSee [semver3](https://python-semver.readthedocs.io/en/latest/usage/check-compatible-semver-version.html) for\ncompatibility logic for versions without operators/symbols.\n\nSee [poetry](https://python-poetry.org/docs/dependency-specification/) for version range specifiers.\n\nSee [stackoverflow](https://stackoverflow.com/a/13874620/33264) for os names.\n\n## Demos\n\nDemos will discover a bunch of executables as installed in the local virtual environment, installed by pipx or\ninstalled by npm. It will then assume that we want the current or any version and run an audit. Since we know these\nfiles already exist, the failures are centered on failing to execute, failing to guess the version switch, failure\nto parse the switch or the\ntool's version switch returning a version incompatible to what the package manager reports.\n\n```bash\ncli_tool_audit --demo=pipx --verbose\ncli_tool_audit --demo=venv --verbose\ncli_tool_audit --demo=npm --verbose\n```\n\n## How does this relate to package managers, e.g. apt, pipx, npm, choco, etc.\n\nPackage managers do far more than check for the existence of a tool. They will install it, at the desired version\nand make sure that tools and their transitive dependencies are compatible.\n\nWhat they can't do is verify what other package managers have done.\n\nThis captures your desired tools, versions and guarantees you have them by installing them.\n\n```shell\n# list everything available on one machine\npip freeze>requirements.txt\n# install it on another.\npip install -r requirements.txt\n```\n\nThis is the same thing, but for windows and .net centric apps.\n\n```shell\nchoco export requirements.txt\nchoco install -y requirements.txt\n```\n\nThere are similar patterns, for apt, brew, npm, and so on.\n\nIt would be foolish to try to create a package manager that supports other package managers, so features in that\nvein are out of scope.\n\n## Prior Art\n\n- [tool-audit](https://github.com/jstutters/toolaudit)\n- [dotnet-tool-list](https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet-tool-list)\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Audit for existence and version number of cli tools.",
    "version": "3.1.0",
    "project_urls": {
        "Bug Tracker": "https://github.com/matthewdeanmartin/cli_tool_audit/issues",
        "Change Log": "https://github.com/matthewdeanmartin/cli_tool_audit/blob/main/CHANGELOG.md",
        "Documentation": "https://matthewdeanmartin.github.io/cli_tool_audit/cli_tool_audit/index.html",
        "Homepage": "https://github.com/matthewdeanmartin/cli_tool_audit",
        "Repository": "https://github.com/matthewdeanmartin/cli_tool_audit"
    },
    "split_keywords": [
        "cli tooling",
        " version numbers"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a2662420ee70bd156f70c44dd92f941380f485b3b3cf195e9647d3f14efa56c7",
                "md5": "24ef6e1a8dfd4caa288c878cf039962f",
                "sha256": "dd39cb445f9864deab8e2aa947b1b62caf3e53036c48d9cb11ec2cde438883ae"
            },
            "downloads": -1,
            "filename": "cli_tool_audit-3.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "24ef6e1a8dfd4caa288c878cf039962f",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.9",
            "size": 37513,
            "upload_time": "2024-08-24T23:16:23",
            "upload_time_iso_8601": "2024-08-24T23:16:23.818713Z",
            "url": "https://files.pythonhosted.org/packages/a2/66/2420ee70bd156f70c44dd92f941380f485b3b3cf195e9647d3f14efa56c7/cli_tool_audit-3.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "24c26ec7500017e41e959bc97e7b145c6b1aa1229a82705ce1ece9867ce28336",
                "md5": "353fd4d8fadc0c67c33977bbd9472b37",
                "sha256": "f9b2a23c4f80f6116b36dca5f4f99ffb30844dd67288562d6795c39acbef2148"
            },
            "downloads": -1,
            "filename": "cli_tool_audit-3.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "353fd4d8fadc0c67c33977bbd9472b37",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.9",
            "size": 30883,
            "upload_time": "2024-08-24T23:16:25",
            "upload_time_iso_8601": "2024-08-24T23:16:25.511876Z",
            "url": "https://files.pythonhosted.org/packages/24/c2/6ec7500017e41e959bc97e7b145c6b1aa1229a82705ce1ece9867ce28336/cli_tool_audit-3.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-24 23:16:25",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "matthewdeanmartin",
    "github_project": "cli_tool_audit",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "tox": true,
    "lcname": "cli-tool-audit"
}
        
Elapsed time: 1.59032s