Skip to content

Commit

Permalink
Import duthost utils as general fixture and fix failed fixture imports
Browse files Browse the repository at this point in the history
Signed-off-by: Liam Kearney <[email protected]>
  • Loading branch information
liamkearney-msft committed Jan 16, 2025
1 parent 43def98 commit 1079df2
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 33 deletions.
46 changes: 23 additions & 23 deletions tests/common/fixtures/duthost_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
from paramiko.ssh_exception import AuthenticationException

from tests.common import config_reload
from tests.common.helpers.assertions import pytest_assert
from tests.common.helpers.assertions import pytest_assert as pt_assert
from tests.common.utilities import wait_until
from jinja2 import Template
from netaddr import valid_ipv4, valid_ipv6
Expand Down Expand Up @@ -240,12 +240,12 @@ def shutdown_ebgp(duthosts, rand_one_dut_hostname):
# Shutdown all eBGP neighbors
duthost.command("sudo config bgp shutdown all")
# Verify that the total eBGP routes are 0.
pytest_assert(wait_until(60, 2, 5, check_ebgp_routes, 0, 0, duthost),
"eBGP routes are not 0 after shutting down all neighbors on {}".format(duthost))
pytest_assert(wait_until(orch_cpu_timeout, 2, 0, check_orch_cpu_utilization, duthost, orch_cpu_threshold),
"Orch CPU utilization {} > orch cpu threshold {} after shutdown all eBGP"
.format(duthost.shell("show processes cpu | grep orchagent | awk '{print $9}'")["stdout"],
orch_cpu_threshold))
pt_assert(wait_until(60, 2, 5, check_ebgp_routes, 0, 0, duthost),
"eBGP routes are not 0 after shutting down all neighbors on {}".format(duthost))
pt_assert(wait_until(orch_cpu_timeout, 2, 0, check_orch_cpu_utilization, duthost, orch_cpu_threshold),
"Orch CPU utilization {} > orch cpu threshold {} after shutdown all eBGP"
.format(duthost.shell("show processes cpu | grep orchagent | awk '{print $9}'")["stdout"],
orch_cpu_threshold))

yield

Expand All @@ -257,13 +257,13 @@ def shutdown_ebgp(duthosts, rand_one_dut_hostname):
# Verify that total eBGP routes are what they were before shutdown of all eBGP neighbors
orig_v4_ebgp = v4ebgps[duthost.hostname]
orig_v6_ebgp = v6ebgps[duthost.hostname]
pytest_assert(wait_until(120, 10, 10, check_ebgp_routes, orig_v4_ebgp, orig_v6_ebgp, duthost),
"eBGP v4 routes are {}, and v6 route are {}, and not what they were originally after enabling "
"all neighbors on {}".format(orig_v4_ebgp, orig_v6_ebgp, duthost))
pytest_assert(wait_until(orch_cpu_timeout, 2, 0, check_orch_cpu_utilization, duthost, orch_cpu_threshold),
"Orch CPU utilization {} > orch cpu threshold {} after startup all eBGP"
.format(duthost.shell("show processes cpu | grep orchagent | awk '{print $9}'")["stdout"],
orch_cpu_threshold))
pt_assert(wait_until(120, 10, 10, check_ebgp_routes, orig_v4_ebgp, orig_v6_ebgp, duthost),
"eBGP v4 routes are {}, and v6 route are {}, and not what they were originally after enabling "
"all neighbors on {}".format(orig_v4_ebgp, orig_v6_ebgp, duthost))
pt_assert(wait_until(orch_cpu_timeout, 2, 0, check_orch_cpu_utilization, duthost, orch_cpu_threshold),
"Orch CPU utilization {} > orch cpu threshold {} after startup all eBGP"
.format(duthost.shell("show processes cpu | grep orchagent | awk '{print $9}'")["stdout"],
orch_cpu_threshold))


@pytest.fixture(scope="module")
Expand Down Expand Up @@ -624,7 +624,7 @@ def wait_bgp_sessions(duthost, timeout=120):
A helper function to wait bgp sessions on DUT
"""
bgp_neighbors = duthost.get_bgp_neighbors_per_asic(state="all")
pytest_assert(
pt_assert(
wait_until(timeout, 10, 0, duthost.check_bgp_session_state_all_asics, bgp_neighbors),
"Not all bgp sessions are established after config reload",
)
Expand Down Expand Up @@ -705,10 +705,10 @@ def duthosts_ipv6_mgmt_only(duthosts, backup_and_restore_config_db_on_duts):
finally:
ssh_client.close()

pytest_assert(len(ipv6_address[duthost.hostname]) > 0,
f"{duthost.hostname} doesn't have IPv6 Management IP address")
pytest_assert(has_available_ipv6_addr,
f"{duthost.hostname} doesn't have available IPv6 Management IP address")
pt_assert(len(ipv6_address[duthost.hostname]) > 0,
f"{duthost.hostname} doesn't have IPv6 Management IP address")
pt_assert(has_available_ipv6_addr,
f"{duthost.hostname} doesn't have available IPv6 Management IP address")

# Remove IPv4 mgmt-ip
for duthost in duthosts.nodes:
Expand Down Expand Up @@ -817,10 +817,10 @@ def assert_addr_in_output(addr_set: Dict[str, List], hostname: str,
"""
for addr in addr_set[hostname]:
if expect_exists:
pytest_assert(addr in cmd_output,
f"{addr} not appeared in {hostname} {cmd_desc}")
pt_assert(addr in cmd_output,
f"{addr} not appeared in {hostname} {cmd_desc}")
logger.info(f"{addr} exists in the output of {cmd_desc}")
else:
pytest_assert(addr not in cmd_output,
f"{hostname} {cmd_desc} still with addr {addr}")
pt_assert(addr not in cmd_output,
f"{hostname} {cmd_desc} still with addr {addr}")
logger.info(f"{addr} not exists in the output of {cmd_desc} which is expected")
3 changes: 2 additions & 1 deletion tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,8 @@
'tests.common.plugins.allure_server',
'tests.common.plugins.conditional_mark',
'tests.common.plugins.random_seed',
'tests.common.plugins.memory_utilization')
'tests.common.plugins.memory_utilization',
'tests.common.fixtures.duthost_utils')


def pytest_addoption(parser):
Expand Down
17 changes: 8 additions & 9 deletions tests/ip/test_mgmt_ipv6_only.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,10 @@
from tests.common.helpers.tacacs.tacacs_helper import ssh_remote_run_retry, tacacs_v6_context
from tests.common.helpers.ntp_helper import run_ntp, setup_ntp_context
from tests.common.helpers.telemetry_helper import setup_streaming_telemetry_context
from tests.common.helpers.syslog_helpers import run_syslog
from tests.common.helpers.syslog_helpers import run_syslog, check_default_route # noqa F401
from tests.common.helpers.gnmi_utils import GNMIEnvironment
from tests.common.fixtures.duthost_utils import duthosts_ipv6_mgmt_only # noqa F401
from tests.common.fixtures.tacacs import tacacs_creds # noqa F401


pytestmark = [
Expand Down Expand Up @@ -120,9 +121,9 @@ def test_image_download_ipv6_only(creds, duthosts_ipv6_mgmt_only, # noqa F411
@pytest.mark.parametrize("dummy_syslog_server_ip_a, dummy_syslog_server_ip_b",
[("fd82:b34f:cc99::100", None),
("fd82:b34f:cc99::100", "fd82:b34f:cc99::200")])
def test_syslog_ipv6_only(duthosts_ipv6_mgmt_only, # noqa F411
def test_syslog_ipv6_only(duthosts_ipv6_mgmt_only, check_default_route, # noqa F411
rand_selected_dut, dummy_syslog_server_ip_a,
dummy_syslog_server_ip_b, check_default_route):
dummy_syslog_server_ip_b):
# Add a temporary debug log to see if DUTs are reachable via IPv6 mgmt-ip. Will remove later
log_eth0_interface_info(duthosts_ipv6_mgmt_only)
run_syslog(rand_selected_dut, dummy_syslog_server_ip_a, dummy_syslog_server_ip_b, check_default_route)
Expand All @@ -147,9 +148,8 @@ def test_snmp_ipv6_only(duthosts_ipv6_mgmt_only, # noqa F411
assert "SONiC Software Version" in result[0], "Sysdescr not found in SNMP result from DUT IPv6 {}".format(hostipv6)


def test_ro_user_ipv6_only(localhost, ptfhost, duthosts_ipv6_mgmt_only, # noqa F411
enum_rand_one_per_hwsku_hostname,
tacacs_creds):
def test_ro_user_ipv6_only(localhost, ptfhost, duthosts_ipv6_mgmt_only, tacacs_creds, # noqa F411
enum_rand_one_per_hwsku_hostname):
duthost = duthosts_ipv6_mgmt_only[enum_rand_one_per_hwsku_hostname]
with tacacs_v6_context(ptfhost, duthost, tacacs_creds):
# Add a temporary debug log to see if DUTs are reachable via IPv6 mgmt-ip. Will remove later
Expand All @@ -162,9 +162,8 @@ def test_ro_user_ipv6_only(localhost, ptfhost, duthosts_ipv6_mgmt_only, # no
check_output(res, 'test', 'remote_user')


def test_rw_user_ipv6_only(localhost, ptfhost, duthosts_ipv6_mgmt_only, # noqa F411
enum_rand_one_per_hwsku_hostname,
tacacs_creds):
def test_rw_user_ipv6_only(localhost, ptfhost, duthosts_ipv6_mgmt_only, tacacs_creds, # noqa F411
enum_rand_one_per_hwsku_hostname):
duthost = duthosts_ipv6_mgmt_only[enum_rand_one_per_hwsku_hostname]
with tacacs_v6_context(ptfhost, duthost, tacacs_creds):
# Add a temporary debug log to see if DUTs are reachable via IPv6 mgmt-ip. Will remove later
Expand Down

0 comments on commit 1079df2

Please sign in to comment.