Skip to content

adding cisco and juniper support#5572

Open
rezachit wants to merge 2 commits into
mainfrom
rezachit/juniper-cisco-support
Open

adding cisco and juniper support#5572
rezachit wants to merge 2 commits into
mainfrom
rezachit/juniper-cisco-support

Conversation

@rezachit

Copy link
Copy Markdown
Contributor

adding cisco and juniper support to transceiver test for MVC800 and fix some other bugs.

@rezachit rezachit requested a review from a team as a code owner June 12, 2026 22:53
@gemini-code-assist

Copy link
Copy Markdown
Contributor

Summary of Changes

Hello, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!

This pull request enhances the transceiver test framework by introducing support for Cisco and Juniper hardware. It refactors existing configuration and validation logic to accommodate vendor-specific behaviors, such as different naming conventions for breakout ports and distinct operational mode requirements. These changes improve the robustness and flexibility of the test suite across a wider range of network devices.

Highlights

  • Vendor Support Expansion: Added support for Cisco and Juniper devices in the transceiver test suite, including specific operational mode configurations and optical power settings.
  • Refactored Interface Configuration: Centralized interface and hardware port configuration logic to better handle vendor-specific requirements, particularly for breakout ports.
  • Telemetry Validation Updates: Updated telemetry validation logic to support vendor-specific naming conventions and adjusted thresholds for optical channel and temperature sensor validation.
Using Gemini Code Assist

The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.

Invoking Gemini

You can request assistance from Gemini at any point by creating a comment using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands on the current page.

Feature Command Description
Code Review /gemini review Performs a code review for the current pull request in its current state.
Pull Request Summary /gemini summary Provides a summary of the current pull request in its current state.
Comment @gemini-code-assist Responds in comments when explicitly tagged, both in pull request comments and review comments.
Help /gemini help Displays a list of available commands.

Customization

To customize the Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.

Limitations & Feedback

Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counterproductive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for GitHub and other Google products, sign up here.

Footnotes

  1. Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution.

@OpenConfigBot

OpenConfigBot commented Jun 12, 2026

Copy link
Copy Markdown

Pull Request Functional Test Report for #5572 / 11f76ae

No tests identified for validation.

Help

@gemini-code-assist gemini-code-assist Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

Code Review

This pull request introduces support for new transceiver part numbers and implements vendor-specific configuration and telemetry validation logic, particularly for Cisco, Juniper, Nokia, Arista, and Ciena devices. Key changes include refactoring interface and hardware port lookup helpers, batched interface state toggling, and updated validation thresholds for optical, OTN, and temperature sensor components. Feedback suggests refactoring the repeated Ciena manufacturer name checks into a reusable helper function to improve maintainability.

Important

The consumer version of Gemini Code Assist on GitHub is being sunset. Starting June 18, 2026, new organization installations will be blocked, and all code review activity will officially cease on July 17, 2026.
For more details on the timeline and next steps, please review the Help Documentation.

return OperationalModeList{1, 3} // 800G : 1 (8x112G), 400G : 3 (4x112G)
case ondatra.PMD800GBASEZRP:
if dut.Vendor() == ondatra.CISCO {
// Ciena 800ZRP is not backward compatible with 400G.

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

medium

The check for the 'CIENA' manufacturer name is repeated in multiple places (lines 190, 196, and 306). To improve maintainability and facilitate future optimizations, refactor this repeated telemetry validation logic into a reusable helper function (e.g., isCienaOptics(t, dut, p)). Additionally, ensure the helper function handles varying capitalization by converting the manufacturer name to uppercase before performing the substring check.

Suggested change
// Ciena 800ZRP is not backward compatible with 400G.
if isCienaOptics(t, dut, p) {
References
  1. Refactor repeated telemetry wait or validation logic into reusable helper functions to improve maintainability and facilitate future optimizations (e.g., batching gNMI lookups) or cross-vendor support.

@rezachit rezachit assigned rezachit and unassigned rezachit Jun 12, 2026
return OperationalModeList{1, 3} // 800G : 1 (8x112G), 400G : 3 (4x112G)
case ondatra.PMD800GBASEZRP:
if dut.Vendor() == ondatra.CISCO {
// Ciena 800ZRP is not backward compatible with 400G.

Copy link
Copy Markdown

Choose a reason for hiding this comment

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

line 189 mentions Cisco, but comment mentions Ciena.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants