-
Notifications
You must be signed in to change notification settings - Fork 231
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feat(eos_cli_config_gen): Add support for ip name server groups #4763
base: devel
Are you sure you want to change the base?
Feat(eos_cli_config_gen): Add support for ip name server groups #4763
Conversation
Review docs on Read the Docs To test this pull request: # Create virtual environment for this testing below the current directory
python -m venv test-avd-pr-4763
# Activate the virtual environment
source test-avd-pr-4763/bin/activate
# Install all requirements including PyAVD
pip install "pyavd[ansible] @ git+https://github.com/laxmikantchintakindi/avd.git@feat/eos_cli/ip-name-server-group#subdirectory=python-avd" --force
# Point Ansible collections path to the Python virtual environment
export ANSIBLE_COLLECTIONS_PATH=$VIRTUAL_ENV/ansible_collections
# Install Ansible collection
ansible-galaxy collection install git+https://github.com/laxmikantchintakindi/avd.git#/ansible_collections/arista/avd/,feat/eos_cli/ip-name-server-group --force
# Optional: Install AVD examples
cd test-avd-pr-4763
ansible-playbook arista.avd.install_examples |
13bff48
to
52d9f5a
Compare
@@ -5,7 +5,7 @@ | |||
# Line above is used by RedHat's YAML Schema vscode extension | |||
# Use Ctrl + Space to get suggestions for every field. Autocomplete will pop up after typing 2 letters. | |||
type: dict | |||
keys: | |||
$defs: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
add default: default
on the vrf to document what you are doing in the templates
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed this defs and added all the keys in ip_name_server_groups
schema with default vrf default
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess the reason for this (==removing the defs) was because we are not currently injecting default
for ip name-servers
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok thanks
seems that default: default
would make sense for the other one as well:
site3-leaf1(config-if-Et4)#ip name-server 1.1.1.1
site3-leaf1(config)#show run se name-ser
ip name-server vrf MGMT 10.14.0.1
ip name-server vrf MGMT 192.168.17.1
ip name-server vrf default 1.1.1.1
but that would be a breaking change in terms of what we produce as the current template does not inject VRF default. so we can revisit this later.
Can you please open an issue to track this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We normally don't add default values in eos_cli_config_gen. We do not have to mirror EOS behavior on missing inputs. As long as it is possible to produce the correct config by providing correct inputs, and we never produce invalid config.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@laxmikantchintakindi - discussed with @ClausHolbechArista and for this model lets use required: true
for the VRF key.
for issue #4788 let's change it to do the same for AVD 6.0.0 (and tag it for the 6.0 milestone) and please close the other PR #4842 for now
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this should simplify your template
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added vrf required. Also added TODO 6.0 comment to make ip_name_servers[].vrf
as a required key.
3e14cbf
to
ae1ef81
Compare
python-avd/pyavd/_eos_cli_config_gen/j2templates/eos/ip-name-server-groups.j2
Outdated
Show resolved
Hide resolved
...s/arista/avd/molecule/eos_cli_config_gen/inventory/host_vars/host1/ip_name_server_groups.yml
Outdated
Show resolved
Hide resolved
fd9d66f
to
37daa62
Compare
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
3fa7b5e
to
69ae148
Compare
Conflicts have been resolved. A maintainer will review the pull request shortly. |
69ae148
to
f555179
Compare
python-avd/pyavd/_eos_cli_config_gen/j2templates/eos/ip-name-server-groups.j2
Outdated
Show resolved
Hide resolved
ansible_collections/arista/avd/molecule/eos_cli_config_gen/intended/configs/host1.cfg
Outdated
Show resolved
Hide resolved
for more information, see https://pre-commit.ci
python-avd/pyavd/_eos_cli_config_gen/schema/schema_fragments/ip_name_server_groups.schema.yml
Outdated
Show resolved
Hide resolved
python-avd/pyavd/_eos_cli_config_gen/j2templates/eos/ip-name-server-groups.j2
Outdated
Show resolved
Hide resolved
...s/arista/avd/molecule/eos_cli_config_gen/inventory/host_vars/host1/ip-name-server-groups.yml
Outdated
Show resolved
Hide resolved
python-avd/pyavd/_eos_cli_config_gen/j2templates/eos/ip-name-server-groups.j2
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Change Summary
Add support for ip name server groups
Related Issue(s)
Fixes #4698
Component(s) name
arista.avd.eos_cli_config_gen
Proposed changes
There is no input variable for applying the ip name-server group to monitor connectivity via eos_cli_config_gen. Below contains the use cause example.
ip name-server group {name_server_group}
name-server vrf {name_server_vrf} {IP}
monitor connectivity
vrf {name_server_vrf}
interface set {set_name} {loopback_name}
description {description}
!
host {host_name}
url {url}
name-server group {name_server_group}
How to test
Checklist
User Checklist
Repository Checklist