Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tonybaloney/wily
A Python application for tracking, reporting on timing and complexity in Python code
https://github.com/tonybaloney/wily
complexity hacktoberfest hacktoberfest-accepted python quality
Last synced: 1 day ago
JSON representation
A Python application for tracking, reporting on timing and complexity in Python code
- Host: GitHub
- URL: https://github.com/tonybaloney/wily
- Owner: tonybaloney
- License: apache-2.0
- Created: 2018-10-11T22:12:25.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-07-10T07:19:19.000Z (7 months ago)
- Last Synced: 2025-02-12T01:44:55.820Z (8 days ago)
- Topics: complexity, hacktoberfest, hacktoberfest-accepted, python, quality
- Language: Python
- Homepage:
- Size: 5.58 MB
- Stars: 1,222
- Watchers: 24
- Forks: 60
- Open Issues: 45
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-list - Wily - A Python application for tracking, reporting on timing and complexity in Python code. (Debugging & Profiling & Tracing / For Python)
- best-of-python-dev - GitHub - 32% open · ⏱️ 11.10.2023): (Code Metrics & Complexity)
- stars - tonybaloney/wily - A Python application for tracking, reporting on timing and complexity in Python code (Python)
- stars - tonybaloney/wily - A Python application for tracking, reporting on timing and complexity in Python code (Python)
README
data:image/s3,"s3://crabby-images/a6e7e/a6e7e7aa9b57bed1acc3782ab222a2dde8119d2c" alt="wily"
A command-line application for tracking, reporting on complexity of Python tests and applications.
[data:image/s3,"s3://crabby-images/bfdee/bfdeea411a0857139125ad72d749a90cd37f457b" alt="Wily"](https://wily.readthedocs.io/)
[data:image/s3,"s3://crabby-images/3693c/3693c4b4f63cdbfda26a544041f0524ae6d1e64a" alt="codecov"](https://codecov.io/gh/tonybaloney/wily) [data:image/s3,"s3://crabby-images/ddbf5/ddbf5f45ff085f4bf4c244897036692d9d6309f5" alt="Documentation Status"](https://wily.readthedocs.io/en/latest/?badge=latest) [data:image/s3,"s3://crabby-images/35860/3586085bf30d8090d17d033c0387d833918a9ab4" alt="PyPI version"](https://badge.fury.io/py/wily) [data:image/s3,"s3://crabby-images/5c72c/5c72c5e361d34990d1303891afbf1ea2285625f5" alt="Conda Version"](https://anaconda.org/conda-forge/wily) data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="black" data:image/s3,"s3://crabby-images/62db4/62db4aba8246198de962d6b74c32d2d73801ef17" alt="PyPI - Downloads"```default
wily [a]:
quick to think of things, having a very good understanding of situations and possibilities,
and often willing to use tricks to achieve an aim.
```Wily uses git to go through each revision (commit) in a branch and run complexity and code-analysis metrics over the code. You can use this to limit your code or report on trends for complexity, length etc.
## Installation
Wily can be installed via pip from Python 3.6 and above:
```console
$ pip install wily
```Alternatively, Wily packages are available on conda-forge:
```console
$ conda install -c conda-forge wily
```## Usage
See the [Documentation Site](https://wily.readthedocs.io/) for full usage guides.
Wily can be used via a command line interface, `wily`.
```console
$ wily --help
```data:image/s3,"s3://crabby-images/6773f/6773fde4188bccc1aff7f73b97d3de6e00c45425" alt="help-screen"
## Demo
Here is a demo of wily analysing a Python project, giving a summary of changes to complexity in the last 10 commits and then showing changes against a specific git revision:
data:image/s3,"s3://crabby-images/d387c/d387cd6ec957e332f034a1e67f6f6e043f205aae" alt="demo"
## Using Wily in a CI/CD pipeline
Wily can be used in a CI/CD workflow to compare the complexity of the current files against a particular revision.
By default, wily will compare against the previous revision (for a git-pre-commit hook) but you can also give a Git ref, for example `HEAD^1` is the commit before the HEAD reference.
```console
$ wily build src/
$ wily diff src/ -r HEAD^1
```Or, to compare against
```console
$ wily build src/
$ wily diff src/ -r master
```## pre-commit plugin
You can install wily as a [pre-commit](http://www.pre-commit.com/) plugin by adding the following to ``.pre-commit-config.yaml``
```yaml
repos:
- repo: local
hooks:
- id: wily
name: wily
entry: wily diff
verbose: true
language: python
additional_dependencies: [wily]
```### Command line usage
#### `wily build`
The first step to using `wily` is to build a wily cache with the statistics of your project.
```default
Usage: __main__.py build [OPTIONS] [TARGETS]...Build the wily cache
Options:
-n, --max-revisions INTEGER The maximum number of historical commits to
archive
-o, --operators TEXT List of operators, separated by commas
--help Show this message and exit.
```By default, wily will assume your project folder is a `git` directory. Wily will not build a cache if the working copy is dirty (has changed files not committed).
```console
$ wily build src/
```Limit the number of revisions (defaults to 50).
data:image/s3,"s3://crabby-images/b2d9c/b2d9c9a85a1f69d5e72e2dd13394b9c25d9e74a1" alt="wily-build"
#### `wily report`
Show a specific metric for a given file, requires that `.wily/` exists
`wily report` will print the metric and the delta between each revision.
data:image/s3,"s3://crabby-images/e9a51/e9a51ad1db419a9aab2902ff79ac22241ae87c70" alt="wily-report"
#### `wily rank`
Show the ranking for all files in a directory or a single file based on the metric provided, requires that `.wily/` exists
`wily rank` will print a table of files and their metric values.
data:image/s3,"s3://crabby-images/99406/9940611d364883a2e48eb7f77a286b049f95b10b" alt="wily-rank"
#### `wily graph`
Similar to `wily report` but instead of printing in the console, `wily` will print a graph in a browser.
data:image/s3,"s3://crabby-images/225e0/225e0a339b18e9bf53ce6140642353a08ab582ae" alt="wily-graph"
#### `wily index`
Show information about the build directory. Requires that `.wily/` exists.
`wily index` will print the configuration to the screen and list all revisions that have been analysed and the operators used.
data:image/s3,"s3://crabby-images/faea4/faea467d468f1dc98531fa9f04dc56c1ecbd2f71" alt="wily-graph"
### `wily list-metrics`
List the metrics available in the Wily operators. Each one of the metrics can be used in `wily graph` and `wily report`
```console
$ wily list-metrics
mccabe operator:
No metrics available
raw operator:
╒═════════════════╤══════════════════════╤═══════════════╤══════════════════════════╕
│ │ Name │ Description │ Type │
╞═════════════════╪══════════════════════╪═══════════════╪══════════════════════════╡
│ loc │ Lines of Code │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ lloc │ L Lines of Code │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ sloc │ S Lines of Code │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ comments │ Multi-line comments │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ multi │ Multi lines │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ blank │ blank lines │ │ MetricType.Informational │
├─────────────────┼──────────────────────┼───────────────┼──────────────────────────┤
│ single_comments │ Single comment lines │ │ MetricType.Informational │
╘═════════════════╧══════════════════════╧═══════════════╧══════════════════════════╛
cyclomatic operator:
No metrics available
maintainability operator:
╒══════╤═════════════════════════╤═════════════════╤══════════════════════════╕
│ │ Name │ Description │ Type │
╞══════╪═════════════════════════╪═════════════════╪══════════════════════════╡
│ rank │ Maintainability Ranking │ │ MetricType.Informational │
├──────┼─────────────────────────┼─────────────────┼──────────────────────────┤
│ mi │ Maintainability Index │ │ MetricType.AimLow │
╘══════╧═════════════════════════╧═════════════════╧══════════════════════════╛
```## Configuration
You can put a `wily.cfg` file in your project directory and `wily` will override the runtime settings. Here are the available options:
```ini
[wily]
# list of operators, choose from cyclomatic, maintainability, mccabe and raw
operators = cyclomatic,raw
# archiver to use, defaults to git
archiver = git
# path to analyse, defaults to .
path = /path/to/target
# max revisions to archive, defaults to 50
max_revisions = 20
```You can also override the path to the configuration with the `--config` flag on the command-line.
## IPython/Jupyter Notebooks
Wily will detect and scan all Python code in .ipynb files automatically.
You can disable this behaviour if you require by setting `ipynb_support = false` in the configuration.
You can also disable the behaviour of reporting on individual cells by setting `ipynb_cells = false`.# Credits
## Contributors
- @wcooley (Wil Cooley)
- @DahlitzFlorian (Florian Dahlitz)
- @alegonz
- @DanielChabrowski
- @jwattier
- @skarzi"cute animal doing dabbing" [Designed by Freepik](https://www.freepik.com/free-vector/cute-animal-doing-dabbing_2462508.htm)