Here are a few break changes to expect in the next major release:
- Remove the flag
--hide-empty-plays
. The default behavior is now to hide empty plays. - Rename the flag
--include-role-tasks
to--show-role-tasks
(or something else) to avoid confusion with aninclude_role
task.
WIP
- fix: Make sure the import_role tasks are always added to the graph. More info at #231.
- Changes the shape of the graphviz node to make it consistent with Mermaid. The tasks will be rectangle instead of
octagon
: https://graphviz.org/doc/info/shapes.html - fix: Remove the play name from the edge going from the playbook to the plays. This was not consistent with the other edges.
- fix: The tags on the role itself should not be evaluated. Instead, what we care about is the tasks (they inherit the tags set on the roles). More info here.
- The empty roles and blocks are no longer displayed by default. An empty role is a role with no tasks (after applying the tags
filters, for example). This is the same behavior as the option
--hide-empty-plays
but with roles. I will eventually drop--hide-empty-plays
to make this the default behavior in the future. - feat: Add the initial support for handlers to the graph with
--show-handlers
. They are by default added at the end of the play and roles only. This might change in the future to actually reflect the handlers' behavior. - feat: Add a new option
--title
to add a title to the graph by @haidaraM in #229. Default to 'Ansible Playbook Grapher'. The graphviz renderer will now use this as the title (label). The Mermaid renderer already has a title. - improvement: Make the play node label like what "ansible-playbook --list-tasks" show. This is more consistent with the actual playbook output.
- fix: The playbook
location.path
should be the absolute path + use local paths when testing by @haidaraM in #230. - docs: Add a comparison matrix for the different renderers
- (Internal) Moved some flags out of the parser to the renderer instead. The whole playbook and all the tasks and roles (except the excluded ones) are always parsed. The renderer(s) will decide later what do based on the flags
- (Internal) Refactor how the nodes and tasks indices are computed given we can now add handlers after all the tasks are parsed.
- (Internal) Add a new
display_name()
method to the node for a friendly name for the graph. This removes passing thenode_label_prefix
in multiple places.
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.7.0...v2.8.0
- fix: Blocks inside roles weren't added to the graph @haidaraM in #225
- feat: Add support for excluding specific roles in the graph view with
--exclude-roles
by @Eltryo in #219
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.6.0...v2.7.0
- feat: Add support for ignoring standalone tasks and role tasks with
--only-roles
in the graph view by @Eltryo in #218 - fix: Tasks in 'include_role' were being wrongly included in the graph by default by @haidaraM in #222
- fix: Increase Ansible and Python compatibility range to [2.16, 2.18.2[ by @haidaraM in #220
- fix(mermaid): More rounded role node for consistency with graphviz
- ci: Collapse the mermaid graphs in the job summary by @haidaraM in #221
- ci: Make sure workflows are triggered for forks
- chore(deps): bump pytest from 8.3.3 to 8.3.4 by @dependabot in #216
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.5.1...v2.6.0
- chore(deps): bump ruff from 0.7.4 to 0.8.1 by @dependabot in #211
- chore(deps): update ansible-core requirement from >=2.16,<2.17.5 to >=2.17.5,<2.18.1 by @dependabot in #210
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.5.0...v2.5.1
- feat: Adding support for reading playbooks from collections by @haidaraM in #208
- chore(deps): bump ruff from 0.7.1 to 0.7.4 by @dependabot in #209
- chore(deps): update ansible-core requirement from <2.17.3,>=2.16 to >=2.16,<2.17.5 by @dependabot in #201
- chore(deps): bump pytest-cov from 5.0.0 to 6.0.0 by @dependabot in #206
- chore(deps): bump ruff from 0.6.8 to 0.7.1 by @dependabot in #205
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.4.0...v2.5.0
- ci: Use ruff for linting and format by @haidaraM in #199
- chore(deps): bump ruff from 0.6.4 to 0.6.8 by @dependabot in #202
- chore(deps): bump pytest from 8.3.2 to 8.3.3 by @dependabot in #200
- fix: 'dict' object has no attribute 'ansible_pos' when validating arguments by @haidaraM in #204
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.3.0...v2.4.0
- feat: Add support for a JSON renderer by @haidaraM in #193
- chore(deps): update black requirement from ~=24.3 to ~=24.4 by @dependabot in #188
- chore(deps): bump pytest from 8.1.1 to 8.2.1 by @dependabot in #189
- chore(deps): bump pytest from 8.2.1 to 8.2.2 by @dependabot in #191
- chore(deps): update ansible-core requirement from <2.16.6,>=2.15 to >=2.15,<2.17.1 by @dependabot in #190
- chore(deps): bump pytest from 8.2.2 to 8.3.2 by @dependabot in #195
- chore(deps): bump pyquery from 2.0.0 to 2.0.1 by @dependabot in #197
- chore(deps): update black requirement from ~=24.4 to ~=24.8 by @dependabot in #196
- chore(deps): update ansible-core requirement from <2.17.1,>=2.16 to >=2.16,<2.17.3 by @dependabot in #194
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.2.1...v2.3.0
- fix: Only display mermaid live editor URL with the flag -vv
- chore(deps): bump pytest from 8.0.2 to 8.1.1 by @dependabot in #185
- chore(deps): bump pytest-cov from 4.1.0 to 5.0.0 by @dependabot in #182
- chore(deps): update black requirement from ~=24.2 to ~=24.3 by @dependabot in #184
- chore(deps): update ansible-core requirement from <2.16.5,>=2.15 to >=2.15,<2.16.6 by @dependabot in #183
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.2.0...v2.2.1
- feat: Add support for hiding empty plays and plays without roles #177.
- Add a new flag
--hide-empty-plays
to not show in the graph the plays that end up being empty after applying the filters. - Add a new flag
--hide-plays-without-roles
to not show in the graph the plays that end up with no roles. Only roles at the play level and include_role as tasks are considered (no import_role).
- Add a new flag
- Add support for viewing mermaid graphs in the browser with
--view --renderer mermaid-flowchart
in #181 - refactor(internal):
PlaybookNode.plays
is now a method instead of property. - refactor(internal): Do not access the
_compositions
in the child classes: use method from the CompositeNode. - chore(deps): update black requirement from ~=24.1 to ~=24.2 by @dependabot in #175
- chore(deps): bump pytest from 8.0.0 to 8.0.2 by @dependabot in #173
- fix: make sure pip install from github works by @haidaraM in #178
- chore(deps): update ansible-core requirement from <2.16.4,>=2.15 to >=2.15,<2.16.5 by @dependabot in #174
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.1.2...v2.2.0
Dependency updates:
- chore(deps): bump actions/upload-artifact from 3 to 4 by @dependabot in #166
- chore(deps): bump actions/setup-python from 4 to 5 by @dependabot in #165
- chore(deps): bump pytest from 7.4.3 to 7.4.4 by @dependabot in #168
- chore(deps): update black requirement from ~=23.11 to ~=23.12 by @dependabot in #169
- chore(deps): update lxml requirement from <5 to <6 by @dependabot in #167
- chore(deps): update ansible-core requirement from <2.16,>=2.15 to >=2.15,<2.17 by @dependabot in #164
- chore(deps): bump pytest from 7.4.4 to 8.0.0 by @dependabot in #171
- chore(deps): update black requirement from ~=23.12 to ~=24.1 by @dependabot in #172
- chore(deps): update ansible-core requirement from <2.16.1,>=2.15 to >=2.15,<2.16.4 by @dependabot in #170
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.1.1...v2.1.2
- fix: pin to ansible-core 2.15.5 before fixing the grapher
- chore(deps): bump pytest from 7.4.2 to 7.4.3 by @dependabot in #160
- chore(deps): update black requirement from ~=23.9 to ~=23.10 by @dependabot in #161
- chore(deps): bump stefanzweifel/git-auto-commit-action from 4 to 5 by @dependabot in #159
- chore(deps): update black requirement from ~=23.10 to ~=23.11 by @dependabot in #163
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.1.0...v2.1.1
- Support for ansible-core 2.15 by @haidaraM in #151.
- chore(deps): bump pytest-cov from 4.0.0 to 4.1.0 by @dependabot in #149
- chore(deps): update black requirement from ~=23.3 to ~=23.7 by @dependabot in #153
- chore(deps): bump pytest from 7.3.1 to 7.4.0 by @dependabot in #152
- chore(deps): bump pytest from 7.4.0 to 7.4.2 by @dependabot in #157
- chore(deps): update black requirement from ~=23.7 to ~=23.9 by @dependabot in #156
- chore(deps): bump actions/checkout from 3 to 4 by @dependabot in #155
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v2.0.0...v2.1.0
- 🚀🚀Add support for MermaidJS 🚀🚀. See #137
- Add generated images in the CI job summary
- Update various Dependencies: pytest, pytest-cov, ansible-core, pyquery etc...
- ci: Add dependabot for github-actions
- Rename some tests files
This version contains the following breaking changes. Some of them may likely affect you if you were using the grapher as a library inside another project:
- Completely refactor the rendering part of the grapher by making it more extensible in order to support Mermaid.
- Fill the plays, blocks and node with color to make them more visible in the output
- Rename the file
graph.py
tograph_model.py
- Use the concatenation of the playbook names as the output filename when graphing multiple playbooks instead of the first playbook.
- feat: Add test case for community downloaded roles and collections by @haidaraM in #117
- feat: Add support multiple playbooks in one graph by @haidaraM in #118
- fix: Roles usages and do not use multiple edges for role tasks by @haidaraM in #120
- feat: Add a flag to group roles by name - Revert the old behavior by @haidaraM in #122
- fix: Avoid recursive endless loop when a role references itself by @haidaraM in #123
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.1.3...v1.2.0
- fix: Render a single node when multiple playbooks use the same role by @haidaraM in #111
- fix: Improve the position of the conditions on the edges by @haidaraM in #116
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.1.2...v1.1.3
- refactor(internal): Remove useless EdgeNode by @haidaraM in #109
- chore(deps): bump pytest from 7.1.1 to 7.1.2 by @dependabot in #107
- Forbid incompatible ansible-core versions >= 2.13 by @jheidbrink in #114
- @jheidbrink made their first contribution in #114
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.1.1...v1.1.2
- ci: Ansible 2.11.8 and 2.12.2 and ubuntu-latest by @haidaraM in #103
- fix: Properly rank the edges in the graphs and sub-graphs by @haidaraM in #104
- chore(deps): bump pytest from 6.2.5 to 7.0.1 by @dependabot in #105
- chore(deps): bump pytest from 7.0.1 to 7.1.1 by @dependabot in #106
-
fix: Do not pass display as param since it's a singleton + init locale to fix warning
-
feat: Open node file when double-clicking on it from a browser #79
-
fix: Unhighlight the current node when clicking on a new one
-
fix: Use the correct LICENSE GPLv3 #100
-
Add some news messages + fix typo and type hint
-
refactor: format the code with black #102
-
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.0.2...v1.1.0
- fix: Fix include_role with loop by @haidaraM in #92
- fix: Fix include_role with loop and list index out of range by @haidaraM in #99
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.0.1...v1.0.2
Full Changelog: https://github.com/haidaraM/ansible-playbook-grapher/compare/v1.0.0...v1.0.1
- refactor: See #81
- Completely rewrite the grapher: the parser, the graph and the renderer to graphviz have been split.
- Hide some ansible internals in the parser.
- feat:
- Consider include_role as normal role instead of task #82
- feat: Curved edge label based on the path #84
- feat: Add option to automatically view the generated file #88
- feat: Add support for block #86. They are now visible in the graph.
- Add support for when on include_role.
- Only Ansible >= 2.11 is supported. Python >=3.8 is now required #94.
- fix:
- front: Refactor the JS part and fix issue when selecting/unselecting nodes
- front: Do not unhighlight the current selected node when hovering on parent node
- cli(typo): rename
--ouput-file-name
to--output-file-name
- Use the correct tooltip for edges
- style: Do not use bold style by default and apply color on nodes border
- Merge when condition with
and
- Explicitly set color luminance to avoid bright colors
- Reduce Node ID lengths. No need to use the full UUID
- Make grapher works with graphviz >= 0.18. See #91
- test:
- Make test verbose by default with
-vv
in the args - Fix test_install in GitHub Actions which was not using the correct Ansible version.
- Make test verbose by default with
- docs:
- Reformat CHANGELOG.md and README.md
- Dependencies:
- fix: Restrict graphviz to <=0.17. Fix #91
- Dependencies:
- Drop support for ansible 2.8. The grapher requires at least ansible 2.9 #74
- Fix:
- Correct graph exported display message. See #69
- CI: Run github actions on pull requests
- Feat:
- Add type annotations to the source code
- Add more debug info + improve counter
- Fix:
- Attach play to role edge to play_subgraph instead of role one
- Fix display verbosity
- Fix pytest warning (remove
rootdir
from pytest.ini) - Fix: Show task name instead of its ID on hover. See issue #57
- ci: Fix coverage
- Refactor:
- Rewriting the grapher, clean code.
- Generate node IDs from an util function
- Style: Replace some
format
by f-string - CI: Replace Travis by GitHub actions (#54)
- Dependencies:
- Bump pytest from 6.0.1 to 6.2.2 (PRs #50, #51, #62, #67)
- Bump pytest-cov from 2.10.0 to 2.11.1 (PRs #49, #65)
- Bump pyquery from 1.4.1 to 1.4.3 (PRs #58)
- Bump lxml from 4.5.2 to 4.6.2 (PRs #53, #61)
- Bump graphviz from 0.14.1 to 0.16 (PRs #52, #64)
- Bump graphviz from 0.14.1 to 0.16 (PRs #52, #64)
- Bump packaging from 20.4 to 20.9 (PRs #66)
- Fix #13: Tasks with same names are not mapped anymore to the same nodes.
- Fix: Do not add the skipped tags to the graph #24
- Do not run some tests with Ansible 2.8: Ansible 2.8 sets some global variables causing the tests to fail. To avoid that, these tests are marked to fail. This "mark" should be removed when we drop support for Ansible 2.8
- FIX. README Usage #41
- Bump pytest-cov from 2.8.1 to 2.9.0 via Dependant bot
- Bump graphviz from 0.14 to 0.14.1 via Dependant bot
- Bump pytest from 5.4.3 to 6.0.1
- Various fixes: typo, remove useless functions
- Fix playbook with relative var_file. Fix #35
- Add dependant bot to the repo:
- Update Pytest to 5.4.2
- Update graphviz to 0.14
- Add support for Ansible 2.9 (#25)
Fix issue #18 with Ansible 2.8: the CLI was refactored in ansible/ansible#50069. See #19 for the related changes.
- The grapher now requires Ansible >= 2.7.0
- New Feature: Add the support for include_role, import_role, import_playbook
- Fix #16
- Add more tests
- CLI more verbose:
-v
or-vv
etc... - Add
.dot
extension to graphviz exported file (option-s
) - ...
- Fix: Return code of the script
- Fix: Make entrypoint (main) args optional
- Pypi: Fix images URL in the description
- Add support for include_tasks #13
- Update Graphviz and lxml versions
- Fix hover on play nodes. The related tasks are properly highlighted now
- Travis: Test more versions of Ansible
- Print Ansible version used the by grapher when printing version (
ansible-playbook-grapher --version
) - Add ability to run the tests with "python setup.py test"
- Fix Pypi package description
- Other minor changes...