Arista Validated Design (AVD) is maintained as a GitHub project under the Apache 2 license. Users are encouraged to submit GitHub issues for feature requests and bug reports.
AVD is a community-based Free Open Source Software (FOSS) project sponsored by Arista Networks. Arista Networks supports Ansible for managing devices running the EOS operating system natively through eAPI or CloudVision Portal (CVP). This collection includes a set of Ansible roles and modules to help kick-start your automation with Arista. The various roles and templates provided are designed to be customized and extended to your needs.
The AVD Core Team is responsible for the direction and execution of the code that gets committed to the project.
The following individuals are on the AVD Core Team:
- Carl Buchmann (@carlbuchmann)
- Claus Holbech (@ClausHolbechArista)
- Tony Goda (@tgodaA)
- Julio Perez (@JulioPDX)
- Guillaume Mulocher (@gmuloc)
We welcome many forms of contributions to AVD. While we understand most contributions will commonly come from ansible power users, we encourage others to contribute in the form of docs, tutorials, and user guides. Also, if you have other ideas for contributing, don't hesitate to open an issue or have a discussion in one of the forums below.
Communication among the contributors should always occur via public channels. The following outlines the best ways to communicate and engage on all things AVD:
- #ansible | #arista on Network to Code Slack - Good for quick chats. Avoid any discussion that might need to be referenced later on, as the chat history isn't retained long.
- GitHub issues - All feature requests, bug reports, and other substantial changes should be documented in an issue.
- GitHub discussions - The preferred forum for general discussion and support issues. Ideal for shaping a feature request prior to submitting an issue.
GitHub's discussions are the best place to get help or propose rough ideas for new functionality. Their integration with GitHub allows for cross-referencing and converting posts to issues as needed. Below are some examples of categories used for discussions:
- General - General community discussion.
- Ideas - Ideas for new functionality that isn't ready for a formal feature request.
- Q&A - Request help with installing or using AVD.
The deprecation policy will be such that at least one release will make users aware of a feature that will be deprecated in the next release.
Semantic Versioning (SemVer) is used for AVD versioning.
The following documents the lifecycle of work within AVD:
- Open/request a feature enhancement or file a bug a. If bug, see here b. If feature request or enhancement, continue.
- Open a GitHub Issue
a. The issue will be reviewed. Based on the request, it will get labeled as
current
,near-term
,future
. b. It will likely only stay in current if it's trivial and quick work. c. If it gets labeled as future, the issue will be closed in the next batch of issues that get migrated and converted to GitHub discussions.
If you follow these steps, there will be a GitHub Issue opened before submitting a Pull Request (PR). However, we're quite aware that a PR may come in without ever being discussed in an Issue or Discussion. While we don't advocate for this, you should be aware of the process that will be followed for those circumstances.
Should this happen, and if you followed the project guidelines, have sample tests, and code quality, you will first be acknowledged for your work; thank you in advance. After that, the PR will be quickly reviewed to ensure that it makes sense as a contribution to the project and to gauge the work effort or issues with merging into devel. If the effort required by the core team isn't trivial, it'll likely still be a few weeks before it gets thoroughly reviewed and merged. After that, it will just depend on the current backlog.
Contributing pull requests are gladly welcomed for this repository. If you are planning a big change, please start a discussion first to make sure we'll be able to merge it.
- The
devel
branch corresponds to the release actively under development. - The release tags correspond to stable releases.
- Fork repository and create a branch based on
devel
to set up a dev environment if you want to open a PR. - See the ansible-avd release for information about active branches.
-
First, ensure that you're running the latest stable version of AVD. If you're running an older version, it's possible that the bug has already been fixed.
-
Next, check the GitHub issues list to see if the bug you've found has already been reported. If you think you may be experiencing a reported issue that hasn't already been resolved, please click "add a reaction" in the top right corner of the issue and add a thumbs up (+1). You might also want to add a comment describing how it's affecting your installation. This will allow us to prioritize bugs based on how many users are affected.
-
When submitting an issue, please be as descriptive as possible. Be sure to provide all information requests in the issue template, including:
- The environment in which AVD is running
- The exact steps that can be taken to reproduce the issue
- Expected and observed behavior
- Any error messages generated
- Screenshots (if applicable)
-
Please avoid prepending any tag (for example, "[Bug]") to the issue title. The issue will be reviewed by a maintainer after submission and the appropriate labels will be applied for categorization.
-
Keep in mind that bugs are prioritized based on their severity and how much work is required to resolve them. It may take some time for someone to address your issue.
-
First, check the GitHub issues list and Discussions to see if the feature you're requesting is already listed. If the feature you'd like to see has already been requested and is open, click "add a reaction" in the top right corner of the issue and add a thumbs up (+1). This ensures that the issue has a better chance of receiving attention. Also feel free to add a comment with any additional justification for the feature. However, note that comments with no substance other than a "+1" will be deleted. Please use GitHub's reactions feature to indicate your support.
-
Before filing a new feature request, consider starting with a GitHub Discussion. Feedback you receive there will help validate and shape the proposed feature before filing a formal issue. If the feature request doesn't get accepted into the current or near term backlog, it will get converted to a discussion anyway.
-
Good feature requests are very narrowly defined. Be sure to thoroughly describe the functionality and data models being proposed. The more effort you put into writing a feature request, the better its chance is of being implemented. Overly broad feature requests will be closed.
-
When submitting a feature request on GitHub, be sure to include all information requested by the issue template, including:
- A detailed description of the proposed functionality
- A use case for the feature; who would use it and what value it would add to AVD
- A rough description of changes necessary to the database schema (if applicable)
- Any third-party libraries or other resources which would be involved
- Please avoid prepending any tag (for example, "[Feature]") to the issue title.
The issue will be reviewed by a moderator after submission and the appropriate labels will be applied for categorization.
-
If you're interested in contributing to AVD, be sure to check out our getting started documentation for tips on setting up your development environment.
-
It's recommended to open an issue before starting work on a pull request, and discuss your idea with the AVD maintainers before beginning work. This will help prevent wasting time on something that might we might not be able to implement. When suggesting a new feature, also make sure it won't conflict with any work that's already in progress.
-
Once you've opened or identified an issue you'd like to work on, ask that it be assigned to you so that others are aware it's being worked on. A maintainer will then mark the issue as "accepted."
-
All new functionality must include relevant tests where applicable.
-
When submitting a pull request, please be sure to work off of the
devel
branch, rather thanreleases/*
. Thedevel
branch is used for ongoing development, whilereleases/*
is used for tagging stable releases. -
In most cases, it's not necessary to add a changelog entry: A maintainer will take care of this when the PR is merged. (This helps avoid merge conflicts resulting from multiple PRs being submitted simultaneously.)
-
All code submissions should meet the following criteria (CI will enforce these checks):
- Jinja2 templates follow our guidelines.
- Molecule is updated with data covering your fix.
- Molecule artifacts are updated with your coverage.
- Python syntax is valid.
- All unit tests pass successfully.
- PEP 8 compliance is enforced, with the exception that lines may be greater than 80 characters in length.
-
A PR can be opened before all the work is complete. In this situation, PR state should be set to draft. PRs marked as ready for review (not in draft) will be reviewed by the maintainer team.
-
To automate release-notes creation and make filtering process easier, it's strongly recommended to use conventional commit syntax at least for PR title. Scope should be module or role updated. As a reminder, the list below provides all supported commit types and scopes:
-
Types:
Feat
: Create a capability e.g. feature, test, dependency.Fix
: Fix an issue e.g. bug, typo, accident, misstatement.Cut
: Remove a capability e.g. feature, test, dependency.Doc
: Refactor of documentation, e.g. help files.CI
: Update CI components, e.g. molecule files or Github Actions.Bump
: Increase the version of something e.g. dependency.Test
: Add or refactor anything regarding test, e.g add a new testCases.Refactor
: A code change that MUST be just a refactoring.Revert
: Change back to the previous commit
-
Scopes:
{{ role_name }}
: AVD role impacted by PR. Required forFeat
,Cut
andFix
typesplugins
: To use when AVD plugin is impacted by PR. Required forFeat
,Cut
andFix
typesrequirements
: To use when usingBump
type and when any AVD requirement is updated
!!! info "Scopes" Scope is an optional field and can be ignore safely if your PR covers an undefined scope.
-
All development of the current AVD release occurs in the devel
branch; releases are packaged from the releases/*
branches. A releases/v*
branch should always represent a stable release in its entirety, such that installing AVD by either downloading a packaged release or cloning the releases/v*
branch provides the same code base.