Skip to content

Fix testbed_vm_info.py for ansible >= 2.14#20766

Merged
StormLiangMS merged 2 commits intosonic-net:masterfrom
wangxin:fix-testbed_vm_info.py
Sep 24, 2025
Merged

Fix testbed_vm_info.py for ansible >= 2.14#20766
StormLiangMS merged 2 commits intosonic-net:masterfrom
wangxin:fix-testbed_vm_info.py

Conversation

@wangxin
Copy link
Copy Markdown
Collaborator

@wangxin wangxin commented Sep 22, 2025

Description of PR

Summary:
Fixes # (issue)

Type of change

  • Bug fix
  • Testbed and Framework(new/improvement)
  • New Test case
    • Skipped for non-supported platforms
  • Test case improvement

Back port request

  • 202205
  • 202305
  • 202311
  • 202405
  • 202411
  • 202505

Approach

What is the motivation for this PR?

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

How did you do it?

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

How did you verify/test it?

Tested on ansible 2.13.13 and 2.19.2

Any platform specific information?

Supported testbed topology if it's a new test case?

Documentation

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
@wangxin wangxin requested a review from yxieca as a code owner September 22, 2025 14:40
@mssonicbld
Copy link
Copy Markdown
Collaborator

/azp run

@azure-pipelines
Copy link
Copy Markdown

Azure Pipelines successfully started running 1 pipeline(s).

@mssonicbld
Copy link
Copy Markdown
Collaborator

/azp run

@azure-pipelines
Copy link
Copy Markdown

Azure Pipelines successfully started running 1 pipeline(s).

Copy link
Copy Markdown
Collaborator

@StormLiangMS StormLiangMS left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@StormLiangMS StormLiangMS merged commit b2571bb into sonic-net:master Sep 24, 2025
19 checks passed
vidyac86 pushed a commit to vidyac86/sonic-mgmt that referenced this pull request Oct 23, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit to wangxin/sonic-mgmt that referenced this pull request Nov 11, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit to wangxin/sonic-mgmt that referenced this pull request Nov 11, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit to wangxin/sonic-mgmt that referenced this pull request Nov 11, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit to wangxin/sonic-mgmt that referenced this pull request Nov 11, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
mssonicbld pushed a commit that referenced this pull request Nov 11, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
StormLiangMS pushed a commit that referenced this pull request Nov 13, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.



* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit that referenced this pull request Nov 19, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.


Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit that referenced this pull request Nov 19, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
wangxin added a commit that referenced this pull request Nov 20, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.



* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
opcoder0 pushed a commit to opcoder0/sonic-mgmt that referenced this pull request Dec 8, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
gshemesh2 pushed a commit to gshemesh2/sonic-mgmt that referenced this pull request Dec 16, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Guy Shemesh <gshemesh@nvidia.com>
AharonMalkin pushed a commit to AharonMalkin/sonic-mgmt that referenced this pull request Dec 16, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Aharon Malkin <amalkin@nvidia.com>
gshemesh2 pushed a commit to gshemesh2/sonic-mgmt that referenced this pull request Dec 21, 2025
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Guy Shemesh <gshemesh@nvidia.com>
venu-nexthop pushed a commit to venu-nexthop/sonic-mgmt that referenced this pull request Jan 13, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
yifan-nexthop pushed a commit to nexthop-ai/sonic-mgmt that referenced this pull request Jan 14, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: YiFan Wang <yifan@nexthop.ai>
gshemesh2 pushed a commit to gshemesh2/sonic-mgmt that referenced this pull request Jan 26, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Guy Shemesh <gshemesh@nvidia.com>
lakshmi-nexthop pushed a commit to lakshmi-nexthop/sonic-mgmt that referenced this pull request Jan 28, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Lakshmi Yarramaneni <lakshmi@nexthop.ai>
ytzur1 pushed a commit to ytzur1/sonic-mgmt that referenced this pull request Feb 2, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Signed-off-by: Yael Tzur <ytzur@nvidia.com>
auspham pushed a commit to auspham/sonic-mgmt that referenced this pull request Feb 3, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
auspham pushed a commit to auspham/sonic-mgmt that referenced this pull request Feb 3, 2026
…sonic-net#848)

Cherry pick sonic-net#20766 to 202503 branch.

After ansible >= 2.14, custom modules are executed on the managed node
(or in an execution environment container) that only contains the
runtime bits Ansible intentionally ships there (mainly
ansible.module_utils plus Python stdlib). Controller‑only internals like
ansible.inventory.manager and ansible.parsing.dataloader are not
present. So importing them on the remote side is fundamentally
unsupported now.

This change removed the code of importing ansible API in the
testbed_vm_info.py customized module. Then this module can be executed
in sonic-mgmt docker using ansible >= 2.14.
abhishek-nexthop pushed a commit to nexthop-ai/sonic-mgmt that referenced this pull request Feb 6, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
venu-nexthop pushed a commit to venu-nexthop/sonic-mgmt that referenced this pull request Mar 27, 2026
* Fix testbed_vm_info.py for ansible >= 2.14

After ansible >= 2.14, custom modules are executed on the managed node (or in an execution environment container) that only contains the runtime bits Ansible intentionally ships there (mainly ansible.module_utils plus Python stdlib). Controller‑only internals like ansible.inventory.manager and ansible.parsing.dataloader are not present. So importing them on the remote side is fundamentally unsupported now.

This change removed the code of importing ansible API in the testbed_vm_info.py customized module. Then this module can be executed in sonic-mgmt docker using ansible >= 2.14.

Signed-off-by: Xin Wang <xiwang5@microsoft.com>

* Fix pre-commit issue and add back hashbang

---------

Signed-off-by: Xin Wang <xiwang5@microsoft.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment