Skip to content

Commit

Permalink
[platform_tests/test_power_off_reboot.py] Change power_on_seq to use …
Browse files Browse the repository at this point in the history
…grouped PDUs

* Simplify an iterator operation
* Change power_on_seq to use PDUs by PSUs rather than individual PDUs

Signed-off-by: Javier Tan javiertan@microsoft.com
  • Loading branch information
Javier-Tan committed Jan 6, 2025
1 parent f02557b commit 91d2a6d
Showing 1 changed file with 2 additions and 6 deletions.
8 changes: 2 additions & 6 deletions tests/platform_tests/test_power_off_reboot.py
Original file line number Diff line number Diff line change
Expand Up @@ -96,12 +96,8 @@ def test_power_off_reboot(duthosts, localhost, enum_supervisor_dut_hostname, con
all_outlets = pdu_ctrl.get_outlet_status()
# If PDU supports returning output_watts, making sure that all PSUs has power.
psu_to_pdus = get_grouped_pdus_by_psu(pdu_ctrl)

for psu, pdus in psu_to_pdus.items():
psu_powered = False
for pdu in pdus:
psu_powered = psu_powered or (pdu["output_watts"] != 0)
pytest_assert(psu_powered, "Not all PSUs have power output")
pytest_assert(any(pdu["output_watts"] != 0 for pdu in pdus), "Not all PSUs are getting power")

# Purpose of this list is to control sequence of turning on PSUs in power off testing.
# If there are 2 PSUs, then 3 scenarios would be covered:
Expand All @@ -110,7 +106,7 @@ def test_power_off_reboot(duthosts, localhost, enum_supervisor_dut_hostname, con
# 3. Turn off all PSUs, turn on one of the PSU, then turn on the other PSU, then check.
power_on_seq_list = []
if all_outlets:
power_on_seq_list = [[item] for item in all_outlets]
power_on_seq_list = [pdus for pdus in psu_to_pdus.values()]
power_on_seq_list.append(all_outlets)

logging.info("Got all power on sequences {}".format(power_on_seq_list))
Expand Down

0 comments on commit 91d2a6d

Please sign in to comment.